Skip to content

Commit 3fed2ef

Browse files
committed
Merge remote-tracking branch 'origin/1.18' into 1.19.2
2 parents 94433b0 + d9b9586 commit 3fed2ef

File tree

7 files changed

+177
-1
lines changed

7 files changed

+177
-1
lines changed
Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
package org.embeddedt.modernfix.common.mixin.perf.dynamic_resources;
2+
3+
import net.minecraft.client.renderer.block.model.ItemOverrides;
4+
import net.minecraft.client.resources.model.BakedModel;
5+
import org.embeddedt.modernfix.dynamicresources.ItemOverrideBakedModel;
6+
import org.spongepowered.asm.mixin.Mixin;
7+
import org.spongepowered.asm.mixin.injection.At;
8+
import org.spongepowered.asm.mixin.injection.Inject;
9+
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
10+
11+
@Mixin(ItemOverrides.class)
12+
public class ItemOverridesMixin {
13+
@Inject(method = "resolve", at = @At("RETURN"), cancellable = true)
14+
private void getRealModel(CallbackInfoReturnable<BakedModel> cir) {
15+
BakedModel original = cir.getReturnValue();
16+
if(original instanceof ItemOverrideBakedModel) {
17+
ItemOverrideBakedModel override = (ItemOverrideBakedModel)original;
18+
cir.setReturnValue(override.getRealModel());
19+
}
20+
}
21+
}

common/src/main/java/org/embeddedt/modernfix/core/config/ModernFixEarlyConfig.java

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,8 @@ public class ModernFixEarlyConfig {
3131
private final Map<String, Option> options = new HashMap<>();
3232
private final Multimap<String, Option> optionsByCategory = HashMultimap.create();
3333

34+
private static final boolean ALLOW_OVERRIDE_OVERRIDES = Boolean.getBoolean("modernfix.unsupported.allowOverriding");
35+
3436
public static final boolean OPTIFINE_PRESENT;
3537

3638
private File configFile;
@@ -263,6 +265,9 @@ private void addMixinRule(String mixin, boolean enabled) {
263265
}
264266

265267
private void readProperties(Properties props) {
268+
if(ALLOW_OVERRIDE_OVERRIDES)
269+
LOGGER.fatal("JVM argument given to override mod overrides. Issues opened with this option present will be ignored unless they can be reproduced without.");
270+
266271
for (Map.Entry<Object, Object> entry : props.entrySet()) {
267272
String key = (String) entry.getKey();
268273
String value = (String) entry.getValue();
@@ -285,7 +290,7 @@ private void readProperties(Properties props) {
285290
continue;
286291
}
287292

288-
if(!option.isModDefined())
293+
if(ALLOW_OVERRIDE_OVERRIDES || !option.isModDefined())
289294
option.setEnabled(enabled, true);
290295
else
291296
LOGGER.warn("Option '{}' already disabled by a mod. Ignoring user configuration", key);

common/src/main/java/org/embeddedt/modernfix/dynamicresources/DynamicBakedModelProvider.java

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,7 @@
2323
import java.util.stream.Collectors;
2424

2525
public class DynamicBakedModelProvider implements Map<ResourceLocation, BakedModel> {
26+
public static DynamicBakedModelProvider currentInstance = null;
2627
private final ModelBakery bakery;
2728
private final Map<Triple<ResourceLocation, Transformation, Boolean>, BakedModel> bakedCache;
2829
private final Map<ResourceLocation, BakedModel> permanentOverrides;
@@ -73,6 +74,7 @@ public DynamicBakedModelProvider(ModelBakery bakery, Map<Triple<ResourceLocation
7374
this.bakery = bakery;
7475
this.bakedCache = cache;
7576
this.permanentOverrides = Collections.synchronizedMap(new Object2ObjectOpenHashMap<>());
77+
currentInstance = this;
7678
}
7779

7880
public void setMissingModel(BakedModel model) {
Lines changed: 77 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,77 @@
1+
package org.embeddedt.modernfix.dynamicresources;
2+
3+
import com.google.common.collect.ImmutableList;
4+
import net.minecraft.client.renderer.block.model.BakedQuad;
5+
import net.minecraft.client.renderer.block.model.ItemOverrides;
6+
import net.minecraft.client.renderer.block.model.ItemTransforms;
7+
import net.minecraft.client.renderer.texture.TextureAtlasSprite;
8+
import net.minecraft.client.resources.model.BakedModel;
9+
import net.minecraft.core.Direction;
10+
import net.minecraft.resources.ResourceLocation;
11+
import net.minecraft.world.level.block.state.BlockState;
12+
import org.jetbrains.annotations.Nullable;
13+
14+
import java.util.List;
15+
import java.util.Map;
16+
import java.util.Random;
17+
import java.util.concurrent.ConcurrentHashMap;
18+
19+
/**
20+
* Delegate model that stores the location of an actual baked model, for use in ItemOverrides.
21+
*/
22+
public class ItemOverrideBakedModel implements BakedModel {
23+
private static final Map<ResourceLocation, ItemOverrideBakedModel> OVERRIDE_MODELS = new ConcurrentHashMap<>();
24+
public final ResourceLocation realLocation;
25+
26+
private ItemOverrideBakedModel(ResourceLocation realLocation) {
27+
this.realLocation = realLocation;
28+
}
29+
30+
public static ItemOverrideBakedModel of(ResourceLocation realLocation) {
31+
return OVERRIDE_MODELS.computeIfAbsent(realLocation, ItemOverrideBakedModel::new);
32+
}
33+
34+
public BakedModel getRealModel() {
35+
return DynamicBakedModelProvider.currentInstance.get(realLocation);
36+
}
37+
38+
@Override
39+
public List<BakedQuad> getQuads(@Nullable BlockState state, @Nullable Direction direction, Random random) {
40+
return ImmutableList.of();
41+
}
42+
43+
@Override
44+
public boolean useAmbientOcclusion() {
45+
return false;
46+
}
47+
48+
@Override
49+
public boolean isGui3d() {
50+
return false;
51+
}
52+
53+
@Override
54+
public boolean usesBlockLight() {
55+
return false;
56+
}
57+
58+
@Override
59+
public boolean isCustomRenderer() {
60+
return false;
61+
}
62+
63+
@Override
64+
public TextureAtlasSprite getParticleIcon() {
65+
return null;
66+
}
67+
68+
@Override
69+
public ItemTransforms getTransforms() {
70+
return ItemTransforms.NO_TRANSFORMS;
71+
}
72+
73+
@Override
74+
public ItemOverrides getOverrides() {
75+
return null;
76+
}
77+
}

common/src/main/resources/modernfix.accesswidener

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -32,3 +32,5 @@ accessible method net/minecraft/client/gui/screens/Screen addRenderableWidget (L
3232
accessible field net/minecraft/client/KeyMapping ALL Ljava/util/Map;
3333
accessible field net/minecraft/client/renderer/block/model/multipart/MultiPart definition Lnet/minecraft/world/level/block/state/StateDefinition;
3434
accessible field net/minecraft/server/packs/resources/MultiPackResourceManager namespacedManagers Ljava/util/Map;
35+
accessible field net/minecraft/client/renderer/block/model/ItemOverrides$BakedOverride model Lnet/minecraft/client/resources/model/BakedModel;
36+
mutable field net/minecraft/client/renderer/block/model/ItemOverrides$BakedOverride model Lnet/minecraft/client/resources/model/BakedModel;
Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
package org.embeddedt.modernfix.fabric.mixin.perf.dynamic_resources;
2+
3+
import net.minecraft.client.renderer.block.model.BlockModel;
4+
import net.minecraft.client.renderer.block.model.ItemOverride;
5+
import net.minecraft.client.renderer.block.model.ItemOverrides;
6+
import net.minecraft.client.resources.model.BakedModel;
7+
import net.minecraft.client.resources.model.ModelBakery;
8+
import net.minecraft.client.resources.model.UnbakedModel;
9+
import net.minecraft.resources.ResourceLocation;
10+
import org.embeddedt.modernfix.dynamicresources.ItemOverrideBakedModel;
11+
import org.spongepowered.asm.mixin.Mixin;
12+
import org.spongepowered.asm.mixin.injection.At;
13+
import org.spongepowered.asm.mixin.injection.Inject;
14+
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
15+
16+
import java.util.function.Function;
17+
18+
@Mixin(ItemOverrides.class)
19+
public class ItemOverridesFabricMixin {
20+
@Inject(method = "bakeModel", at = @At("HEAD"), cancellable = true)
21+
private void useDynamicallyBakedModel(ModelBakery baker, BlockModel model, Function<ResourceLocation, UnbakedModel> modelGetter, ItemOverride override, CallbackInfoReturnable<BakedModel> cir) {
22+
cir.setReturnValue(ItemOverrideBakedModel.of(override.getModel()));
23+
}
24+
}
Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
package org.embeddedt.modernfix.forge.mixin.perf.dynamic_resources;
2+
3+
import net.minecraft.client.renderer.block.model.ItemOverride;
4+
import net.minecraft.client.renderer.block.model.ItemOverrides;
5+
import net.minecraft.client.renderer.texture.TextureAtlasSprite;
6+
import net.minecraft.client.resources.model.BakedModel;
7+
import net.minecraft.client.resources.model.Material;
8+
import net.minecraft.client.resources.model.ModelBakery;
9+
import net.minecraft.client.resources.model.UnbakedModel;
10+
import net.minecraft.resources.ResourceLocation;
11+
import org.embeddedt.modernfix.dynamicresources.ItemOverrideBakedModel;
12+
import org.spongepowered.asm.mixin.Final;
13+
import org.spongepowered.asm.mixin.Mixin;
14+
import org.spongepowered.asm.mixin.Shadow;
15+
import org.spongepowered.asm.mixin.injection.At;
16+
import org.spongepowered.asm.mixin.injection.Inject;
17+
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
18+
19+
import java.util.function.Function;
20+
21+
@Mixin(ItemOverrides.class)
22+
public class ItemOverridesForgeMixin {
23+
@Shadow @Final private ItemOverrides.BakedOverride[] overrides;
24+
private volatile boolean forceLoadedModels = false;
25+
26+
@Inject(method = "bakeModel", at = @At("HEAD"), cancellable = true, remap = false)
27+
private void useDynamicallyBakedModel(ModelBakery baker, UnbakedModel model, Function<ResourceLocation, UnbakedModel> function, Function<Material, TextureAtlasSprite> textureGetter, ItemOverride override, CallbackInfoReturnable<BakedModel> cir) {
28+
cir.setReturnValue(ItemOverrideBakedModel.of(override.getModel()));
29+
}
30+
31+
@Inject(method = "getOverrides", at = @At("HEAD"), remap = false)
32+
private void doForceloadModels(CallbackInfoReturnable<ItemOverrides.BakedOverride> cir) {
33+
if(!forceLoadedModels) {
34+
synchronized (this) {
35+
if(!forceLoadedModels) {
36+
for(ItemOverrides.BakedOverride override : overrides) {
37+
if(override != null && override.model instanceof ItemOverrideBakedModel)
38+
override.model = ((ItemOverrideBakedModel)override.model).getRealModel();
39+
}
40+
forceLoadedModels = true;
41+
}
42+
}
43+
}
44+
}
45+
}

0 commit comments

Comments
 (0)