From 161dcbe52d73ee63559325837417b59789c05b87 Mon Sep 17 00:00:00 2001 From: jchung01 Date: Thu, 1 Feb 2024 14:56:24 -0800 Subject: [PATCH] Auto-add CT chickens to Roost stockTextures No longer need to specify custom chicken names in the config! --- .../universaltweaks/config/UTConfigMods.java | 15 ++------------- .../universaltweaks/core/UTMixinLoader.java | 2 +- .../mods/roost/mixin/UTProxyClientMixin.java | 7 ++++--- 3 files changed, 7 insertions(+), 17 deletions(-) diff --git a/src/main/java/mod/acgaming/universaltweaks/config/UTConfigMods.java b/src/main/java/mod/acgaming/universaltweaks/config/UTConfigMods.java index 0acfadd6..d0be993e 100644 --- a/src/main/java/mod/acgaming/universaltweaks/config/UTConfigMods.java +++ b/src/main/java/mod/acgaming/universaltweaks/config/UTConfigMods.java @@ -520,22 +520,11 @@ public static class RoostCategory @Config.Comment ({ "Improves load time by registering CT chickens early for Roost to detect them", - "Note: All CT chickens must be specified in \"Custom Chickens\" for this tweak to work!", - "Note: In your .zs files, to use ContentTweaker's MaterialSystem Parts, you must:", + "Note: If you would like to use ContentTweaker's MaterialSystem Parts for the layed item, in your script you must:", "1) Use '#loader finalize_contenttweaker', not '#loader contenttweaker'", "2) Use the Material Part Bracket Handler to reference the item" }) - public boolean utRoostEarlyRegisterCTChickens = false; - - @Config.RequiresMcRestart - @Config.Name("Custom Chickens") - @Config.Comment - ({ - "Adds custom chickens from mods (e.g. ContentTweaker) to Roost's stock texture check", - "Syntax: name", - "name Chicken name", - }) - public String[] utRoostChickenMods = new String[] {}; + public boolean utRoostEarlyRegisterCTChickens = true; } public static class SimpleDifficultyCategory diff --git a/src/main/java/mod/acgaming/universaltweaks/core/UTMixinLoader.java b/src/main/java/mod/acgaming/universaltweaks/core/UTMixinLoader.java index 8b33fab3..dd766765 100644 --- a/src/main/java/mod/acgaming/universaltweaks/core/UTMixinLoader.java +++ b/src/main/java/mod/acgaming/universaltweaks/core/UTMixinLoader.java @@ -95,7 +95,7 @@ public boolean shouldMixinConfigQueue(String mixinConfig) case "mixins.mods.crafttweaker.json": return Loader.isModLoaded("crafttweaker"); case "mixins.mods.roost.json": - return Loader.isModLoaded("roost"); + return Loader.isModLoaded("roost") && Loader.isModLoaded("contenttweaker"); case "mixins.mods.storagedrawers.client.json": return Loader.isModLoaded("storagedrawers"); case "mixins.mods.thaumcraft.entities.client.json": diff --git a/src/main/java/mod/acgaming/universaltweaks/mods/roost/mixin/UTProxyClientMixin.java b/src/main/java/mod/acgaming/universaltweaks/mods/roost/mixin/UTProxyClientMixin.java index d3a8f732..d3633f62 100644 --- a/src/main/java/mod/acgaming/universaltweaks/mods/roost/mixin/UTProxyClientMixin.java +++ b/src/main/java/mod/acgaming/universaltweaks/mods/roost/mixin/UTProxyClientMixin.java @@ -1,12 +1,13 @@ package mod.acgaming.universaltweaks.mods.roost.mixin; -import java.util.Arrays; import java.util.stream.Collectors; import java.util.stream.Stream; import com.google.common.collect.ImmutableSet; import net.minecraftforge.fml.common.event.FMLLoadCompleteEvent; +import com.teamacronymcoders.contenttweaker.modules.chickens.ChickenFactory; +import com.teamacronymcoders.contenttweaker.modules.chickens.ChickenRepresentation; import com.timwoodcreates.roost.RoostTextures; import com.timwoodcreates.roost.proxy.ProxyClient; import mod.acgaming.universaltweaks.UniversalTweaks; @@ -24,11 +25,11 @@ public class UTProxyClientMixin @Inject(method = "loadComplete", at = @At("HEAD")) public void utRoostLoadComplete(FMLLoadCompleteEvent e, CallbackInfo ci) { - if (UTConfigMods.ROOST.utRoostChickenMods.length == 0) return; + if (!UTConfigMods.ROOST.utRoostEarlyRegisterCTChickens) return; if (UTConfigGeneral.DEBUG.utDebugToggle) UniversalTweaks.LOGGER.debug("UTProxyClientMixin ::: Rebuild roost stock textures"); // stockTextures is immutable set, use stream to rebuild RoostTextures.stockTextures = Stream.concat(RoostTextures.stockTextures.stream(), - Arrays.stream(UTConfigMods.ROOST.utRoostChickenMods)) + ChickenFactory.CHICKEN_REPRESENTATIONS.stream().map(ChickenRepresentation::getName)) .collect(Collectors.collectingAndThen(Collectors.toSet(), ImmutableSet::copyOf)); } } \ No newline at end of file