geforkt von Mirrors/Paper
Keep default keys in some maps
Fixes https://github.com/PaperMC/Paper/issues/7913#issuecomment-1152780671
Dieser Commit ist enthalten in:
Ursprung
e44a2dc4ac
Commit
33d48ed240
@ -691,8 +691,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
@@ -0,0 +0,0 @@
|
@@ -0,0 +0,0 @@
|
||||||
+package io.papermc.paper.configuration;
|
+package io.papermc.paper.configuration;
|
||||||
+
|
+
|
||||||
|
+import io.leangen.geantyref.GenericTypeReflector;
|
||||||
+import org.checkerframework.checker.nullness.qual.Nullable;
|
+import org.checkerframework.checker.nullness.qual.Nullable;
|
||||||
+import org.spigotmc.SpigotWorldConfig;
|
|
||||||
+import org.spongepowered.configurate.objectmapping.FieldDiscoverer;
|
+import org.spongepowered.configurate.objectmapping.FieldDiscoverer;
|
||||||
+import org.spongepowered.configurate.serialize.SerializationException;
|
+import org.spongepowered.configurate.serialize.SerializationException;
|
||||||
+import org.spongepowered.configurate.util.CheckedSupplier;
|
+import org.spongepowered.configurate.util.CheckedSupplier;
|
||||||
@ -703,6 +703,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+import java.lang.reflect.Modifier;
|
+import java.lang.reflect.Modifier;
|
||||||
+import java.util.Collections;
|
+import java.util.Collections;
|
||||||
+import java.util.HashMap;
|
+import java.util.HashMap;
|
||||||
|
+import java.util.Iterator;
|
||||||
+import java.util.Map;
|
+import java.util.Map;
|
||||||
+
|
+
|
||||||
+import static io.leangen.geantyref.GenericTypeReflector.erase;
|
+import static io.leangen.geantyref.GenericTypeReflector.erase;
|
||||||
@ -765,18 +766,41 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ return mutableInstanceFactoryDelegate.begin();
|
+ return mutableInstanceFactoryDelegate.begin();
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
+ @SuppressWarnings("unchecked")
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public void complete(Object instance, Map<Field, Object> intermediate) throws SerializationException {
|
+ public void complete(Object instance, Map<Field, Object> intermediate) throws SerializationException {
|
||||||
|
+ final Iterator<Map.Entry<Field, Object>> iter = intermediate.entrySet().iterator();
|
||||||
|
+ try {
|
||||||
|
+ while (iter.hasNext()) { // manually merge any mergeable maps
|
||||||
|
+ Map.Entry<Field, Object> entry = iter.next();
|
||||||
|
+ if (entry.getKey().isAnnotationPresent(MergeMap.class) && Map.class.isAssignableFrom(entry.getKey().getType()) && intermediate.get(entry.getKey()) instanceof Map<?, ?> map) {
|
||||||
|
+ iter.remove();
|
||||||
|
+ @Nullable Map<Object, Object> existingMap = (Map<Object, Object>) entry.getKey().get(instance);
|
||||||
|
+ if (existingMap != null) {
|
||||||
|
+ existingMap.putAll(map);
|
||||||
|
+ } else {
|
||||||
|
+ entry.getKey().set(instance, entry.getValue());
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ } catch (final IllegalAccessException e) {
|
||||||
|
+ throw new SerializationException(target.getType(), e);
|
||||||
|
+ }
|
||||||
+ mutableInstanceFactoryDelegate.complete(instance, intermediate);
|
+ mutableInstanceFactoryDelegate.complete(instance, intermediate);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public Object complete(Map<Field, Object> intermediate) throws SerializationException {
|
+ public Object complete(Map<Field, Object> intermediate) throws SerializationException {
|
||||||
+ Object value = mutableInstanceFactoryDelegate.complete(intermediate);
|
+ @Nullable Object targetInstance = InnerClassFieldDiscoverer.this.instanceMap.get(GenericTypeReflector.erase(target.getType()));
|
||||||
+ if (value instanceof ConfigurationPart.Post post) {
|
+ if (targetInstance != null) {
|
||||||
|
+ this.complete(targetInstance, intermediate);
|
||||||
|
+ } else {
|
||||||
|
+ targetInstance = mutableInstanceFactoryDelegate.complete(intermediate);
|
||||||
|
+ }
|
||||||
|
+ if (targetInstance instanceof ConfigurationPart.Post post) {
|
||||||
+ post.postProcess();
|
+ post.postProcess();
|
||||||
+ }
|
+ }
|
||||||
+ return value;
|
+ return targetInstance;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
@ -807,6 +831,31 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ return new InnerClassFieldDiscoverer(Collections.emptyMap());
|
+ return new InnerClassFieldDiscoverer(Collections.emptyMap());
|
||||||
+ }
|
+ }
|
||||||
+}
|
+}
|
||||||
|
diff --git a/src/main/java/io/papermc/paper/configuration/MergeMap.java b/src/main/java/io/papermc/paper/configuration/MergeMap.java
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/src/main/java/io/papermc/paper/configuration/MergeMap.java
|
||||||
|
@@ -0,0 +0,0 @@
|
||||||
|
+package io.papermc.paper.configuration;
|
||||||
|
+
|
||||||
|
+import java.lang.annotation.Documented;
|
||||||
|
+import java.lang.annotation.ElementType;
|
||||||
|
+import java.lang.annotation.Retention;
|
||||||
|
+import java.lang.annotation.RetentionPolicy;
|
||||||
|
+import java.lang.annotation.Target;
|
||||||
|
+
|
||||||
|
+/**
|
||||||
|
+ * For use in maps inside {@link ConfigurationPart}s that have default keys that shouldn't be removed by users
|
||||||
|
+ * <p>
|
||||||
|
+ * Note that when the config is reloaded, the maps will be merged again, so make sure this map can't accumulate
|
||||||
|
+ * keys overtime.
|
||||||
|
+ */
|
||||||
|
+@Documented
|
||||||
|
+@Target(ElementType.FIELD)
|
||||||
|
+@Retention(RetentionPolicy.RUNTIME)
|
||||||
|
+public @interface MergeMap {
|
||||||
|
+}
|
||||||
diff --git a/src/main/java/io/papermc/paper/configuration/NestedSetting.java b/src/main/java/io/papermc/paper/configuration/NestedSetting.java
|
diff --git a/src/main/java/io/papermc/paper/configuration/NestedSetting.java b/src/main/java/io/papermc/paper/configuration/NestedSetting.java
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
||||||
@ -1449,7 +1498,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ public boolean disableMobSpawnerSpawnEggTransformation = false;
|
+ public boolean disableMobSpawnerSpawnEggTransformation = false;
|
||||||
+ public boolean perPlayerMobSpawns = true;
|
+ public boolean perPlayerMobSpawns = true;
|
||||||
+ public boolean scanForLegacyEnderDragon = true;
|
+ public boolean scanForLegacyEnderDragon = true;
|
||||||
|
+ @MergeMap
|
||||||
+ public Reference2IntMap<MobCategory> spawnLimits = Util.make(new Reference2IntOpenHashMap<>(NaturalSpawner.SPAWNING_CATEGORIES.length), map -> Arrays.stream(NaturalSpawner.SPAWNING_CATEGORIES).forEach(mobCategory -> map.put(mobCategory, -1)));
|
+ public Reference2IntMap<MobCategory> spawnLimits = Util.make(new Reference2IntOpenHashMap<>(NaturalSpawner.SPAWNING_CATEGORIES.length), map -> Arrays.stream(NaturalSpawner.SPAWNING_CATEGORIES).forEach(mobCategory -> map.put(mobCategory, -1)));
|
||||||
|
+ @MergeMap
|
||||||
+ public Map<MobCategory, DespawnRange> despawnRanges = Arrays.stream(MobCategory.values()).collect(Collectors.toMap(Function.identity(), category -> new DespawnRange(category.getNoDespawnDistance(), category.getDespawnDistance())));
|
+ public Map<MobCategory, DespawnRange> despawnRanges = Arrays.stream(MobCategory.values()).collect(Collectors.toMap(Function.identity(), category -> new DespawnRange(category.getNoDespawnDistance(), category.getDespawnDistance())));
|
||||||
+
|
+
|
||||||
+ @ConfigSerializable
|
+ @ConfigSerializable
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren