Skip to content

Commit dfd83cf

Browse files
JRoymdcfe
andauthored
Fix /tpr on legacy versions (#6212)
Commodore breaks this on legacy likely, use a provider to ensure we use the old ABI...................i love legacy Fixes #6211 --------- Co-authored-by: MD <[email protected]>
1 parent cc25a79 commit dfd83cf

File tree

4 files changed

+31
-1
lines changed

4 files changed

+31
-1
lines changed

Essentials/src/main/java/com/earth2me/essentials/Essentials.java

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -72,6 +72,7 @@
7272
import net.ess3.provider.providers.FixedHeightWorldInfoProvider;
7373
import net.ess3.provider.providers.FlatSpawnEggProvider;
7474
import net.ess3.provider.providers.LegacyBannerDataProvider;
75+
import net.ess3.provider.providers.LegacyBiomeNameProvider;
7576
import net.ess3.provider.providers.LegacyDamageEventProvider;
7677
import net.ess3.provider.providers.LegacyInventoryViewProvider;
7778
import net.ess3.provider.providers.LegacyItemUnbreakableProvider;
@@ -373,6 +374,9 @@ public void onEnable() {
373374
// Inventory View Provider
374375
providerFactory.registerProvider(LegacyInventoryViewProvider.class, BaseInventoryViewProvider.class);
375376

377+
// Biome Name Provider
378+
providerFactory.registerProvider(LegacyBiomeNameProvider.class);
379+
376380
// Biome Key Provider
377381
providerFactory.registerProvider(PaperBiomeKeyProvider.class);
378382

Essentials/src/main/java/com/earth2me/essentials/RandomTeleport.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77
import com.earth2me.essentials.utils.VersionUtil;
88
import io.papermc.lib.PaperLib;
99
import net.ess3.provider.BiomeKeyProvider;
10+
import net.ess3.provider.BiomeNameProvider;
1011
import net.ess3.provider.WorldInfoProvider;
1112
import org.bukkit.Location;
1213
import org.bukkit.Material;
@@ -238,8 +239,9 @@ private boolean isValidRandomLocation(final Location location) {
238239

239240
// Exclude biome if enum or namespaced key matches
240241
private boolean isExcludedBiome(final Location location) {
242+
final BiomeNameProvider biomeNameProvider = ess.provider(BiomeNameProvider.class);
241243
final Set<String> excluded = getExcludedBiomes();
242-
final String enumKey = location.getBlock().getBiome().name().toLowerCase();
244+
final String enumKey = biomeNameProvider.getBiomeName(location.getBlock());
243245
// Try with good old bukkit enum
244246
if (excluded.contains(enumKey)) {
245247
return true;
Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
package net.ess3.provider.providers;
2+
3+
import net.ess3.provider.BiomeNameProvider;
4+
import net.essentialsx.providers.ProviderData;
5+
import org.bukkit.block.Block;
6+
7+
import java.util.Locale;
8+
9+
@ProviderData(description = "Legacy Biome Name Provider")
10+
public class LegacyBiomeNameProvider implements BiomeNameProvider {
11+
@Override
12+
public String getBiomeName(final Block block) {
13+
// For some reason, compiling against modern versions causes this call to break, possibly related to OldEnum?
14+
// Compiling this against versions that still have proper enums allow this to work
15+
return block.getBiome().name().toLowerCase(Locale.ENGLISH);
16+
}
17+
}
Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
package net.ess3.provider;
2+
3+
import org.bukkit.block.Block;
4+
5+
public interface BiomeNameProvider extends Provider {
6+
String getBiomeName(Block block);
7+
}

0 commit comments

Comments
 (0)