Skip to content

Commit

Permalink
Fixed registry unfreezing on 1.21.3
Browse files Browse the repository at this point in the history
  • Loading branch information
WillFP committed Nov 4, 2024
1 parent a455915 commit 6b8f49d
Showing 1 changed file with 21 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import org.bukkit.craftbukkit.CraftRegistry
import org.bukkit.craftbukkit.CraftServer
import org.bukkit.craftbukkit.util.CraftNamespacedKey
import org.bukkit.enchantments.Enchantment
import java.lang.reflect.Modifier
import java.util.IdentityHashMap
import java.util.function.BiFunction

Expand All @@ -34,6 +35,11 @@ class ModernEnchantmentRegisterer : ModernEnchantmentRegistererProxy {
.filter { it.type.isPrimitive }[0]
.apply { isAccessible = true }

private val allTags = MappedRegistry::class.java
.declaredFields
.filter { it.type.name.contains("TagSet") }[0]
.apply { isAccessible = true }

private val unregisteredIntrusiveHoldersField = MappedRegistry::class.java
.declaredFields
.last { it.type == Map::class.java }
Expand Down Expand Up @@ -81,6 +87,21 @@ class ModernEnchantmentRegisterer : ModernEnchantmentRegistererProxy {
IdentityHashMap<net.minecraft.world.item.enchantment.Enchantment,
Holder.Reference<net.minecraft.world.item.enchantment.Enchantment>>()
)

/*
Creating an unbound tag set requires using reflection because the inner class is
package-private, so we just find the method manually.
*/

val unboundTagSet = MappedRegistry::class.java
.declaredClasses[0]
.declaredMethods
.filter { Modifier.isStatic(it.modifiers) }
.filter { it.parameterCount == 0 }[0]
.apply { isAccessible = true }
.invoke(null)

allTags.set(enchantmentRegistry, unboundTagSet)
}

override fun register(enchant: EcoEnchantBase): Enchantment {
Expand Down

0 comments on commit 6b8f49d

Please sign in to comment.