mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-15 14:13:56 +01:00
net.minecraft.resources
This commit is contained in:
parent
71cac092ea
commit
d027a2c341
3 changed files with 75 additions and 83 deletions
|
@ -0,0 +1,71 @@
|
||||||
|
--- a/net/minecraft/resources/RegistryDataLoader.java
|
||||||
|
+++ b/net/minecraft/resources/RegistryDataLoader.java
|
||||||
|
@@ -247,13 +_,14 @@
|
||||||
|
RegistryOps<JsonElement> ops,
|
||||||
|
ResourceKey<E> resourceKey,
|
||||||
|
Resource resource,
|
||||||
|
- RegistrationInfo registrationInfo
|
||||||
|
+ RegistrationInfo registrationInfo,
|
||||||
|
+ io.papermc.paper.registry.data.util.Conversions conversions // Paper - pass conversions
|
||||||
|
) throws IOException {
|
||||||
|
try (Reader reader = resource.openAsReader()) {
|
||||||
|
JsonElement jsonElement = JsonParser.parseReader(reader);
|
||||||
|
DataResult<E> dataResult = codec.parse(ops, jsonElement);
|
||||||
|
E orThrow = dataResult.getOrThrow();
|
||||||
|
- registry.register(resourceKey, orThrow, registrationInfo);
|
||||||
|
+ io.papermc.paper.registry.PaperRegistryListenerManager.INSTANCE.registerWithListeners(registry, resourceKey, orThrow, registrationInfo, conversions); // Paper - register with listeners
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -267,6 +_,7 @@
|
||||||
|
FileToIdConverter fileToIdConverter = FileToIdConverter.registry(registry.key());
|
||||||
|
RegistryOps<JsonElement> registryOps = RegistryOps.create(JsonOps.INSTANCE, registryInfoLookup);
|
||||||
|
|
||||||
|
+ final io.papermc.paper.registry.data.util.Conversions conversions = new io.papermc.paper.registry.data.util.Conversions(registryInfoLookup); // Paper - create conversions
|
||||||
|
for (Entry<ResourceLocation, Resource> entry : fileToIdConverter.listMatchingResources(resourceManager).entrySet()) {
|
||||||
|
ResourceLocation resourceLocation = entry.getKey();
|
||||||
|
ResourceKey<E> resourceKey = ResourceKey.create(registry.key(), fileToIdConverter.fileToId(resourceLocation));
|
||||||
|
@@ -274,7 +_,7 @@
|
||||||
|
RegistrationInfo registrationInfo = REGISTRATION_INFO_CACHE.apply(resource.knownPackInfo());
|
||||||
|
|
||||||
|
try {
|
||||||
|
- loadElementFromResource(registry, codec, registryOps, resourceKey, resource, registrationInfo);
|
||||||
|
+ loadElementFromResource(registry, codec, registryOps, resourceKey, resource, registrationInfo, conversions); // Paper - pass conversions
|
||||||
|
} catch (Exception var14) {
|
||||||
|
loadingErrors.put(
|
||||||
|
resourceKey,
|
||||||
|
@@ -283,7 +_,8 @@
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- TagLoader.loadTagsForRegistry(resourceManager, registry);
|
||||||
|
+ io.papermc.paper.registry.PaperRegistryListenerManager.INSTANCE.runFreezeListeners(registry.key(), conversions); // Paper - run pre-freeze listeners
|
||||||
|
+ TagLoader.loadTagsForRegistry(resourceManager, registry, io.papermc.paper.plugin.lifecycle.event.registrar.ReloadableRegistrarEvent.Cause.INITIAL); // Paper - tag lifecycle - add cause
|
||||||
|
}
|
||||||
|
|
||||||
|
static <E> void loadContentsFromNetwork(
|
||||||
|
@@ -300,6 +_,7 @@
|
||||||
|
RegistryOps<JsonElement> registryOps1 = RegistryOps.create(JsonOps.INSTANCE, registryInfoLookup);
|
||||||
|
FileToIdConverter fileToIdConverter = FileToIdConverter.registry(registry.key());
|
||||||
|
|
||||||
|
+ final io.papermc.paper.registry.data.util.Conversions conversions = new io.papermc.paper.registry.data.util.Conversions(registryInfoLookup); // Paper - create conversions
|
||||||
|
for (RegistrySynchronization.PackedRegistryEntry packedRegistryEntry : networkedRegistryData.elements) {
|
||||||
|
ResourceKey<E> resourceKey = ResourceKey.create(registry.key(), packedRegistryEntry.id());
|
||||||
|
Optional<Tag> optional = packedRegistryEntry.data();
|
||||||
|
@@ -318,7 +_,7 @@
|
||||||
|
|
||||||
|
try {
|
||||||
|
Resource resourceOrThrow = resourceProvider.getResourceOrThrow(resourceLocation);
|
||||||
|
- loadElementFromResource(registry, codec, registryOps1, resourceKey, resourceOrThrow, NETWORK_REGISTRATION_INFO);
|
||||||
|
+ loadElementFromResource(registry, codec, registryOps1, resourceKey, resourceOrThrow, NETWORK_REGISTRATION_INFO, conversions); // Paper - pass conversions
|
||||||
|
} catch (Exception var17) {
|
||||||
|
loadingErrors.put(resourceKey, new IllegalStateException("Failed to parse local data", var17));
|
||||||
|
}
|
||||||
|
@@ -360,6 +_,7 @@
|
||||||
|
|
||||||
|
RegistryDataLoader.Loader<T> create(Lifecycle registryLifecycle, Map<ResourceKey<?>, Exception> loadingErrors) {
|
||||||
|
WritableRegistry<T> writableRegistry = new MappedRegistry<>(this.key, registryLifecycle);
|
||||||
|
+ io.papermc.paper.registry.PaperRegistryAccess.instance().registerRegistry(this.key, writableRegistry); // Paper - initialize API registry
|
||||||
|
return new RegistryDataLoader.Loader<>(this, writableRegistry, loadingErrors);
|
||||||
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
--- a/net/minecraft/resources/ResourceLocation.java
|
--- a/net/minecraft/resources/ResourceLocation.java
|
||||||
+++ b/net/minecraft/resources/ResourceLocation.java
|
+++ b/net/minecraft/resources/ResourceLocation.java
|
||||||
@@ -32,6 +32,7 @@
|
@@ -32,6 +_,7 @@
|
||||||
public static final char NAMESPACE_SEPARATOR = ':';
|
public static final char NAMESPACE_SEPARATOR = ':';
|
||||||
public static final String DEFAULT_NAMESPACE = "minecraft";
|
public static final String DEFAULT_NAMESPACE = "minecraft";
|
||||||
public static final String REALMS_NAMESPACE = "realms";
|
public static final String REALMS_NAMESPACE = "realms";
|
||||||
|
@ -8,7 +8,7 @@
|
||||||
private final String namespace;
|
private final String namespace;
|
||||||
private final String path;
|
private final String path;
|
||||||
|
|
||||||
@@ -40,6 +41,13 @@
|
@@ -40,6 +_,13 @@
|
||||||
|
|
||||||
assert isValidPath(path);
|
assert isValidPath(path);
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@
|
||||||
this.namespace = namespace;
|
this.namespace = namespace;
|
||||||
this.path = path;
|
this.path = path;
|
||||||
}
|
}
|
||||||
@@ -246,7 +254,7 @@
|
@@ -252,7 +_,7 @@
|
||||||
|
|
||||||
private static String assertValidNamespace(String namespace, String path) {
|
private static String assertValidNamespace(String namespace, String path) {
|
||||||
if (!isValidNamespace(namespace)) {
|
if (!isValidNamespace(namespace)) {
|
||||||
|
@ -31,7 +31,7 @@
|
||||||
} else {
|
} else {
|
||||||
return namespace;
|
return namespace;
|
||||||
}
|
}
|
||||||
@@ -267,7 +275,7 @@
|
@@ -277,7 +_,7 @@
|
||||||
|
|
||||||
private static String assertValidPath(String namespace, String path) {
|
private static String assertValidPath(String namespace, String path) {
|
||||||
if (!isValidPath(path)) {
|
if (!isValidPath(path)) {
|
|
@ -1,79 +0,0 @@
|
||||||
--- a/net/minecraft/resources/RegistryDataLoader.java
|
|
||||||
+++ b/net/minecraft/resources/RegistryDataLoader.java
|
|
||||||
@@ -74,7 +74,7 @@
|
|
||||||
|
|
||||||
public class RegistryDataLoader {
|
|
||||||
private static final Logger LOGGER = LogUtils.getLogger();
|
|
||||||
- private static final Comparator<ResourceKey<?>> ERROR_KEY_COMPARATOR = Comparator.comparing(ResourceKey::registry).thenComparing(ResourceKey::location);
|
|
||||||
+ private static final Comparator<ResourceKey<?>> ERROR_KEY_COMPARATOR = Comparator.<ResourceKey<?>, ResourceLocation>comparing(ResourceKey::registry).thenComparing(ResourceKey::location); // Paper - decompile fix
|
|
||||||
private static final RegistrationInfo NETWORK_REGISTRATION_INFO = new RegistrationInfo(Optional.empty(), Lifecycle.experimental());
|
|
||||||
private static final Function<Optional<KnownPack>, RegistrationInfo> REGISTRATION_INFO_CACHE = Util.memoize(knownPacks -> {
|
|
||||||
Lifecycle lifecycle = knownPacks.map(KnownPack::isVanilla).map(vanilla -> Lifecycle.stable()).orElse(Lifecycle.experimental());
|
|
||||||
@@ -238,13 +238,13 @@
|
|
||||||
}
|
|
||||||
|
|
||||||
private static <E> void loadElementFromResource(
|
|
||||||
- WritableRegistry<E> registry, Decoder<E> decoder, RegistryOps<JsonElement> ops, ResourceKey<E> key, Resource resource, RegistrationInfo entryInfo
|
|
||||||
+ WritableRegistry<E> registry, Decoder<E> decoder, RegistryOps<JsonElement> ops, ResourceKey<E> key, Resource resource, RegistrationInfo entryInfo, io.papermc.paper.registry.data.util.Conversions conversions // Paper - pass conversions
|
|
||||||
) throws IOException {
|
|
||||||
try (Reader reader = resource.openAsReader()) {
|
|
||||||
JsonElement jsonElement = JsonParser.parseReader(reader);
|
|
||||||
DataResult<E> dataResult = decoder.parse(ops, jsonElement);
|
|
||||||
E object = dataResult.getOrThrow();
|
|
||||||
- registry.register(key, object, entryInfo);
|
|
||||||
+ io.papermc.paper.registry.PaperRegistryListenerManager.INSTANCE.registerWithListeners(registry, key, object, entryInfo, conversions); // Paper - register with listeners
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -258,6 +258,7 @@
|
|
||||||
FileToIdConverter fileToIdConverter = FileToIdConverter.registry(registry.key());
|
|
||||||
RegistryOps<JsonElement> registryOps = RegistryOps.create(JsonOps.INSTANCE, infoGetter);
|
|
||||||
|
|
||||||
+ final io.papermc.paper.registry.data.util.Conversions conversions = new io.papermc.paper.registry.data.util.Conversions(infoGetter); // Paper - create conversions
|
|
||||||
for (Entry<ResourceLocation, Resource> entry : fileToIdConverter.listMatchingResources(resourceManager).entrySet()) {
|
|
||||||
ResourceLocation resourceLocation = entry.getKey();
|
|
||||||
ResourceKey<E> resourceKey = ResourceKey.create(registry.key(), fileToIdConverter.fileToId(resourceLocation));
|
|
||||||
@@ -265,7 +266,7 @@
|
|
||||||
RegistrationInfo registrationInfo = REGISTRATION_INFO_CACHE.apply(resource.knownPackInfo());
|
|
||||||
|
|
||||||
try {
|
|
||||||
- loadElementFromResource(registry, elementDecoder, registryOps, resourceKey, resource, registrationInfo);
|
|
||||||
+ loadElementFromResource(registry, elementDecoder, registryOps, resourceKey, resource, registrationInfo, conversions); // Paper - pass conversions
|
|
||||||
} catch (Exception var14) {
|
|
||||||
errors.put(
|
|
||||||
resourceKey,
|
|
||||||
@@ -274,7 +275,8 @@
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- TagLoader.loadTagsForRegistry(resourceManager, registry);
|
|
||||||
+ io.papermc.paper.registry.PaperRegistryListenerManager.INSTANCE.runFreezeListeners(registry.key(), conversions); // Paper - run pre-freeze listeners
|
|
||||||
+ TagLoader.loadTagsForRegistry(resourceManager, registry, io.papermc.paper.plugin.lifecycle.event.registrar.ReloadableRegistrarEvent.Cause.INITIAL); // Paper - tag lifecycle - add cause
|
|
||||||
}
|
|
||||||
|
|
||||||
static <E> void loadContentsFromNetwork(
|
|
||||||
@@ -291,6 +293,7 @@
|
|
||||||
RegistryOps<JsonElement> registryOps2 = RegistryOps.create(JsonOps.INSTANCE, infoGetter);
|
|
||||||
FileToIdConverter fileToIdConverter = FileToIdConverter.registry(registry.key());
|
|
||||||
|
|
||||||
+ final io.papermc.paper.registry.data.util.Conversions conversions = new io.papermc.paper.registry.data.util.Conversions(infoGetter); // Paper - create conversions
|
|
||||||
for (RegistrySynchronization.PackedRegistryEntry packedRegistryEntry : networkedRegistryData.elements) {
|
|
||||||
ResourceKey<E> resourceKey = ResourceKey.create(registry.key(), packedRegistryEntry.id());
|
|
||||||
Optional<Tag> optional = packedRegistryEntry.data();
|
|
||||||
@@ -309,7 +312,7 @@
|
|
||||||
|
|
||||||
try {
|
|
||||||
Resource resource = factory.getResourceOrThrow(resourceLocation);
|
|
||||||
- loadElementFromResource(registry, decoder, registryOps2, resourceKey, resource, NETWORK_REGISTRATION_INFO);
|
|
||||||
+ loadElementFromResource(registry, decoder, registryOps2, resourceKey, resource, NETWORK_REGISTRATION_INFO, conversions); // Paper - pass conversions
|
|
||||||
} catch (Exception var17) {
|
|
||||||
loadingErrors.put(resourceKey, new IllegalStateException("Failed to parse local data", var17));
|
|
||||||
}
|
|
||||||
@@ -349,6 +352,7 @@
|
|
||||||
|
|
||||||
RegistryDataLoader.Loader<T> create(Lifecycle lifecycle, Map<ResourceKey<?>, Exception> errors) {
|
|
||||||
WritableRegistry<T> writableRegistry = new MappedRegistry<>(this.key, lifecycle);
|
|
||||||
+ io.papermc.paper.registry.PaperRegistryAccess.instance().registerRegistry(this.key, writableRegistry); // Paper - initialize API registry
|
|
||||||
return new RegistryDataLoader.Loader<>(this, writableRegistry, errors);
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue