refactor part of the ponder registration API

This commit is contained in:
zelophed 2023-09-09 15:57:41 +02:00
parent c847680b46
commit e9b0229f71
5 changed files with 291 additions and 268 deletions

View file

@ -28,8 +28,8 @@ jei_minecraft_version = 1.19.2
jei_version = 11.2.0.254 jei_version = 11.2.0.254
curios_minecraft_version = 1.19.2 curios_minecraft_version = 1.19.2
curios_version = 5.1.1.0 curios_version = 5.1.1.0
catnip_version = 0.6.5 catnip_version = 0.7.11
ponder_version = 0.6.5 ponder_version = 0.7.12
cc_tweaked_enable = true cc_tweaked_enable = true
cc_tweaked_minecraft_version = 1.19.2 cc_tweaked_minecraft_version = 1.19.2

View file

@ -7,7 +7,7 @@ import com.simibubi.create.Create;
import com.simibubi.create.foundation.advancement.AllAdvancements; import com.simibubi.create.foundation.advancement.AllAdvancements;
import net.createmod.catnip.utility.lang.Lang; import net.createmod.catnip.utility.lang.Lang;
import net.createmod.ponder.foundation.PonderLocalization; import net.createmod.ponder.foundation.PonderIndex;
public enum AllLangPartials implements LangPartial { public enum AllLangPartials implements LangPartial {
@ -15,7 +15,7 @@ public enum AllLangPartials implements LangPartial {
INTERFACE("UI & Messages"), INTERFACE("UI & Messages"),
SUBTITLES("Subtitles", AllSoundEvents::provideLangEntries), SUBTITLES("Subtitles", AllSoundEvents::provideLangEntries),
TOOLTIPS("Item Descriptions"), TOOLTIPS("Item Descriptions"),
PONDER("Ponder Content", () -> PonderLocalization.provideLangEntries(Create.ID)), PONDER("Ponder Content", () -> PonderIndex.getLangAccess().provideLangEntries(Create.ID)),
; ;

View file

@ -1,6 +1,5 @@
package com.simibubi.create.foundation.ponder; package com.simibubi.create.foundation.ponder;
import java.util.function.BiConsumer;
import java.util.function.Predicate; import java.util.function.Predicate;
import java.util.stream.Stream; import java.util.stream.Stream;
@ -9,36 +8,40 @@ import com.simibubi.create.infrastructure.ponder.AllPonderTags;
import com.simibubi.create.infrastructure.ponder.CreatePonderIndex; import com.simibubi.create.infrastructure.ponder.CreatePonderIndex;
import net.createmod.ponder.foundation.PonderLevel; import net.createmod.ponder.foundation.PonderLevel;
import net.createmod.ponder.foundation.PonderPlugin; import net.createmod.ponder.foundation.api.registration.PonderPlugin;
import net.createmod.ponder.foundation.api.registration.PonderSceneRegistrationHelper;
import net.createmod.ponder.foundation.api.registration.PonderTagRegistrationHelper;
import net.createmod.ponder.foundation.api.registration.SharedTextRegistrationHelper;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.level.ItemLike; import net.minecraft.world.level.ItemLike;
public class CreatePonderPlugin implements PonderPlugin { public class CreatePonderPlugin implements PonderPlugin {
@Override @Override
public String getModID() { public String getModId() {
return Create.ID; return Create.ID;
} }
@Override @Override
public void registerScenes() { public void registerScenes(PonderSceneRegistrationHelper<ResourceLocation> helper) {
CreatePonderIndex.register(); CreatePonderIndex.register(helper);
} }
@Override @Override
public void registerTags() { public void registerTags(PonderTagRegistrationHelper<ResourceLocation> helper) {
AllPonderTags.register(); AllPonderTags.register(helper);
} }
@Override @Override
public void registerSharedText(BiConsumer<String, String> adder) { public void registerSharedText(SharedTextRegistrationHelper helper) {
adder.accept("rpm8", "8 RPM"); helper.registerSharedText("rpm8", "8 RPM");
adder.accept("rpm16", "16 RPM"); helper.registerSharedText("rpm16", "16 RPM");
adder.accept("rpm16_source", "Source: 16 RPM"); helper.registerSharedText("rpm16_source", "Source: 16 RPM");
adder.accept("rpm32", "32 RPM"); helper.registerSharedText("rpm32", "32 RPM");
adder.accept("movement_anchors", "With the help of Super Glue, larger structures can be moved."); helper.registerSharedText("movement_anchors", "With the help of Super Glue, larger structures can be moved.");
adder.accept("behaviour_modify_wrench", "This behaviour can be modified using a Wrench"); helper.registerSharedText("behaviour_modify_wrench", "This behaviour can be modified using a Wrench");
adder.accept("storage_on_contraption", "Inventories attached to the Contraption will pick up their drops automatically"); helper.registerSharedText("storage_on_contraption", "Inventories attached to the Contraption will pick up their drops automatically");
} }
@Override @Override

View file

@ -4,68 +4,58 @@ import com.simibubi.create.AllBlocks;
import com.simibubi.create.AllItems; import com.simibubi.create.AllItems;
import com.simibubi.create.Create; import com.simibubi.create.Create;
import com.simibubi.create.compat.Mods; import com.simibubi.create.compat.Mods;
import com.tterrag.registrate.util.entry.ItemProviderEntry;
import com.tterrag.registrate.util.entry.RegistryEntry; import com.tterrag.registrate.util.entry.RegistryEntry;
import net.createmod.ponder.foundation.CustomPonderRegistrationHelper; import net.createmod.catnip.platform.CatnipServices;
import net.createmod.ponder.foundation.PonderTag; import net.createmod.ponder.foundation.PonderTag;
import net.createmod.ponder.foundation.api.registration.PonderTagRegistrationHelper;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.item.DyeColor; import net.minecraft.world.item.DyeColor;
import net.minecraft.world.item.Items; import net.minecraft.world.item.Items;
import net.minecraft.world.level.ItemLike;
import net.minecraft.world.level.block.Block; import net.minecraft.world.level.block.Block;
import net.minecraft.world.level.block.Blocks; import net.minecraft.world.level.block.Blocks;
import net.minecraftforge.registries.ForgeRegistries; import net.minecraftforge.registries.ForgeRegistries;
public class AllPonderTags { public class AllPonderTags {
private static final CustomPonderRegistrationHelper<ItemProviderEntry<?>> HELPER = new CustomPonderRegistrationHelper<>(Create.ID, RegistryEntry::getId);
public static final PonderTag public static final PonderTag
KINETIC_RELAYS = create("kinetic_relays").item(AllBlocks.COGWHEEL.get()) KINETIC_RELAYS = create("kinetic_relays").item(AllBlocks.COGWHEEL.get())
.defaultLang("Kinetic Blocks", "Components which help relaying Rotational Force elsewhere") .defaultLang("Kinetic Blocks", "Components which help relaying Rotational Force elsewhere"),
.addToIndex(),
KINETIC_SOURCES = create("kinetic_sources").item(AllBlocks.WATER_WHEEL.get()) KINETIC_SOURCES = create("kinetic_sources").item(AllBlocks.WATER_WHEEL.get())
.defaultLang("Kinetic Sources", "Components which generate Rotational Force") .defaultLang("Kinetic Sources", "Components which generate Rotational Force"),
.addToIndex(),
KINETIC_APPLIANCES = create("kinetic_appliances").item(AllBlocks.MECHANICAL_PRESS.get()) KINETIC_APPLIANCES = create("kinetic_appliances").item(AllBlocks.MECHANICAL_PRESS.get())
.defaultLang("Kinetic Appliances", "Components which make use of Rotational Force") .defaultLang("Kinetic Appliances", "Components which make use of Rotational Force"),
.addToIndex(),
FLUIDS = create("fluids").item(AllBlocks.FLUID_PIPE.get()) FLUIDS = create("fluids").item(AllBlocks.FLUID_PIPE.get())
.defaultLang("Fluid Manipulators", "Components which help relaying and making use of Fluids") .defaultLang("Fluid Manipulators", "Components which help relaying and making use of Fluids"),
.addToIndex(),
LOGISTICS = create("logistics").item(Blocks.CHEST) LOGISTICS = create("logistics").item(Blocks.CHEST)
.defaultLang("Item Transportation", "Components which help moving items around") .defaultLang("Item Transportation", "Components which help moving items around"),
.addToIndex(),
REDSTONE = create("redstone").item(Items.REDSTONE) REDSTONE = create("redstone").item(Items.REDSTONE)
.defaultLang("Logic Components", "Components which help with redstone engineering") .defaultLang("Logic Components", "Components which help with redstone engineering"),
.addToIndex(),
DECORATION = create("decoration").item(Items.ROSE_BUSH) DECORATION = create("decoration").item(Items.ROSE_BUSH)
.defaultLang("Aesthetics", "Components used mostly for decorative purposes"), .defaultLang("Aesthetics", "Components used mostly for decorative purposes"),
CREATIVE = create("creative").item(AllBlocks.CREATIVE_CRATE.get()) CREATIVE = create("creative").item(AllBlocks.CREATIVE_CRATE.get())
.defaultLang("Creative Mode", "Components not usually available for Survival Mode") .defaultLang("Creative Mode", "Components not usually available for Survival Mode"),
.addToIndex(),
MOVEMENT_ANCHOR = create("movement_anchor").item(AllBlocks.MECHANICAL_PISTON.get()) MOVEMENT_ANCHOR = create("movement_anchor").item(AllBlocks.MECHANICAL_PISTON.get())
.defaultLang("Movement Anchors", .defaultLang("Movement Anchors",
"Components which allow the creation of moving contraptions, animating an attached structure in a variety of ways") "Components which allow the creation of moving contraptions, animating an attached structure in a variety of ways"),
.addToIndex(),
CONTRAPTION_ACTOR = create("contraption_actor").item(AllBlocks.MECHANICAL_HARVESTER.get()) CONTRAPTION_ACTOR = create("contraption_actor").item(AllBlocks.MECHANICAL_HARVESTER.get())
.defaultLang("Contraption Actors", .defaultLang("Contraption Actors",
"Components which expose special behaviour when attached to a moving contraption") "Components which expose special behaviour when attached to a moving contraption"),
.addToIndex(),
CONTRAPTION_ASSEMBLY = create("contraption_assembly").item(AllItems.SUPER_GLUE.get()) CONTRAPTION_ASSEMBLY = create("contraption_assembly").item(AllItems.SUPER_GLUE.get())
.defaultLang("Block Attachment Utility", .defaultLang("Block Attachment Utility",
"Tools and Components used to assemble structures moved as an animated Contraption") "Tools and Components used to assemble structures moved as an animated Contraption"),
.addToIndex(),
SAILS = create("windmill_sails").item(AllBlocks.WINDMILL_BEARING.get(), true, true) SAILS = create("windmill_sails").item(AllBlocks.WINDMILL_BEARING.get(), true, true)
.defaultLang("Sails for Windmill Bearings", .defaultLang("Sails for Windmill Bearings",
@ -76,13 +66,12 @@ public class AllPonderTags {
"Components which can be selected as inputs or outputs to the Mechanical Arm"), "Components which can be selected as inputs or outputs to the Mechanical Arm"),
TRAIN_RELATED = create("train_related").item(AllBlocks.TRACK.get()) TRAIN_RELATED = create("train_related").item(AllBlocks.TRACK.get())
.defaultLang("Railway Equipment", "Components used in the construction or management of Train Contraptions") .defaultLang("Railway Equipment",
.addToIndex(), "Components used in the construction or management of Train Contraptions"),
RECENTLY_UPDATED = create("recently_updated").item(AllBlocks.CLIPBOARD.get()) RECENTLY_UPDATED = create("recently_updated").item(AllBlocks.CLIPBOARD.get())
.defaultLang("Recent Changes", .defaultLang("Recent Changes",
"Components that have been added or changed significantly in the latest versions of Create") "Components that have been added or changed significantly in the latest versions of Create"),
.addToIndex(),
DISPLAY_SOURCES = create("display_sources").item(AllBlocks.DISPLAY_LINK.get(), true, true) DISPLAY_SOURCES = create("display_sources").item(AllBlocks.DISPLAY_LINK.get(), true, true)
.defaultLang("Sources for Display Links", .defaultLang("Sources for Display Links",
@ -96,8 +85,31 @@ public class AllPonderTags {
return new PonderTag(Create.asResource(id)); return new PonderTag(Create.asResource(id));
} }
public static void register() { public static void register(PonderTagRegistrationHelper<ResourceLocation> helper) {
// Add items to tags here
PonderTagRegistrationHelper<RegistryEntry<?>> HELPER = helper.withKeyFunction(RegistryEntry::getId);
PonderTagRegistrationHelper<ItemLike> itemHelper = helper.withKeyFunction(
CatnipServices.REGISTRIES::getKeyOrThrow);
helper
.registerTag(KINETIC_RELAYS, true)
.registerTag(KINETIC_SOURCES, true)
.registerTag(KINETIC_APPLIANCES, true)
.registerTag(FLUIDS, true)
.registerTag(LOGISTICS, true)
.registerTag(REDSTONE, true)
.registerTag(DECORATION, true)
.registerTag(CREATIVE, true)
.registerTag(MOVEMENT_ANCHOR, true)
.registerTag(CONTRAPTION_ACTOR, true)
.registerTag(CONTRAPTION_ASSEMBLY, true)
.registerTag(SAILS)
.registerTag(ARM_TARGETS)
.registerTag(TRAIN_RELATED, true)
.registerTag(RECENTLY_UPDATED, true)
.registerTag(DISPLAY_SOURCES)
.registerTag(DISPLAY_TARGETS);
HELPER.addToTag(RECENTLY_UPDATED) HELPER.addToTag(RECENTLY_UPDATED)
.add(AllBlocks.WATER_WHEEL) .add(AllBlocks.WATER_WHEEL)
@ -196,7 +208,9 @@ public class AllPonderTags {
.add(AllBlocks.MECHANICAL_SAW) .add(AllBlocks.MECHANICAL_SAW)
.add(AllBlocks.BLAZE_BURNER) .add(AllBlocks.BLAZE_BURNER)
.add(AllBlocks.CRUSHING_WHEEL) .add(AllBlocks.CRUSHING_WHEEL)
.add(AllBlocks.TRACK_STATION) .add(AllBlocks.TRACK_STATION);
itemHelper.addToTag(ARM_TARGETS)
.add(Blocks.COMPOSTER) .add(Blocks.COMPOSTER)
.add(Blocks.JUKEBOX) .add(Blocks.JUKEBOX)
.add(Blocks.CAMPFIRE) .add(Blocks.CAMPFIRE)
@ -241,7 +255,9 @@ public class AllPonderTags {
HELPER.addToTag(SAILS) HELPER.addToTag(SAILS)
.add(AllBlocks.SAIL) .add(AllBlocks.SAIL)
.add(AllBlocks.SAIL_FRAME) .add(AllBlocks.SAIL_FRAME);
itemHelper.addToTag(SAILS)
.add(Blocks.WHITE_WOOL); .add(Blocks.WHITE_WOOL);
HELPER.addToTag(REDSTONE) HELPER.addToTag(REDSTONE)
@ -273,7 +289,9 @@ public class AllPonderTags {
.add(AllBlocks.SECONDARY_LINEAR_CHASSIS) .add(AllBlocks.SECONDARY_LINEAR_CHASSIS)
.add(AllBlocks.RADIAL_CHASSIS) .add(AllBlocks.RADIAL_CHASSIS)
.add(AllItems.SUPER_GLUE) .add(AllItems.SUPER_GLUE)
.add(AllBlocks.STICKER) .add(AllBlocks.STICKER);
itemHelper.addToTag(CONTRAPTION_ASSEMBLY)
.add(Blocks.SLIME_BLOCK) .add(Blocks.SLIME_BLOCK)
.add(Blocks.HONEY_BLOCK); .add(Blocks.HONEY_BLOCK);
@ -291,7 +309,9 @@ public class AllPonderTags {
.add(AllBlocks.SEATS.get(DyeColor.WHITE)) .add(AllBlocks.SEATS.get(DyeColor.WHITE))
.add(AllBlocks.TRAIN_CONTROLS) .add(AllBlocks.TRAIN_CONTROLS)
.add(AllBlocks.CONTRAPTION_CONTROLS) .add(AllBlocks.CONTRAPTION_CONTROLS)
.add(AllBlocks.REDSTONE_CONTACT) .add(AllBlocks.REDSTONE_CONTACT);
itemHelper.addToTag(CONTRAPTION_ACTOR)
.add(Blocks.BELL) .add(Blocks.BELL)
.add(Blocks.DISPENSER) .add(Blocks.DISPENSER)
.add(Blocks.DROPPER); .add(Blocks.DROPPER);
@ -310,7 +330,9 @@ public class AllPonderTags {
.add(AllBlocks.STRESSOMETER) .add(AllBlocks.STRESSOMETER)
.add(AllBlocks.SPEEDOMETER) .add(AllBlocks.SPEEDOMETER)
.add(AllBlocks.FLUID_TANK) .add(AllBlocks.FLUID_TANK)
.add(AllItems.BELT_CONNECTOR) .add(AllItems.BELT_CONNECTOR);
itemHelper.addToTag(DISPLAY_SOURCES)
.add(Blocks.ENCHANTING_TABLE) .add(Blocks.ENCHANTING_TABLE)
.add(Blocks.RESPAWN_ANCHOR) .add(Blocks.RESPAWN_ANCHOR)
.add(Blocks.COMMAND_BLOCK) .add(Blocks.COMMAND_BLOCK)
@ -319,13 +341,15 @@ public class AllPonderTags {
Mods.COMPUTERCRAFT.executeIfInstalled(() -> () -> { Mods.COMPUTERCRAFT.executeIfInstalled(() -> () -> {
Block computer = ForgeRegistries.BLOCKS.getValue(Mods.COMPUTERCRAFT.rl("computer_advanced")); Block computer = ForgeRegistries.BLOCKS.getValue(Mods.COMPUTERCRAFT.rl("computer_advanced"));
if (computer != null) if (computer != null)
HELPER.addToTag(DISPLAY_SOURCES).add(computer); itemHelper.addToTag(DISPLAY_SOURCES).add(computer);
}); });
HELPER.addToTag(DISPLAY_TARGETS) HELPER.addToTag(DISPLAY_TARGETS)
.add(AllBlocks.ORANGE_NIXIE_TUBE) .add(AllBlocks.ORANGE_NIXIE_TUBE)
.add(AllBlocks.DISPLAY_BOARD) .add(AllBlocks.DISPLAY_BOARD)
.add(AllBlocks.DISPLAY_LINK) .add(AllBlocks.DISPLAY_LINK);
itemHelper.addToTag(DISPLAY_TARGETS)
.add(Blocks.OAK_SIGN) .add(Blocks.OAK_SIGN)
.add(Blocks.LECTERN); .add(Blocks.LECTERN);
} }

View file

@ -54,7 +54,8 @@ import com.tterrag.registrate.util.entry.BlockEntry;
import com.tterrag.registrate.util.entry.ItemProviderEntry; import com.tterrag.registrate.util.entry.ItemProviderEntry;
import com.tterrag.registrate.util.entry.RegistryEntry; import com.tterrag.registrate.util.entry.RegistryEntry;
import net.createmod.ponder.foundation.CustomPonderRegistrationHelper; import net.createmod.ponder.foundation.api.registration.PonderSceneRegistrationHelper;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.item.BlockItem; import net.minecraft.world.item.BlockItem;
import net.minecraft.world.level.ItemLike; import net.minecraft.world.level.ItemLike;
import net.minecraft.world.level.block.Block; import net.minecraft.world.level.block.Block;
@ -62,9 +63,6 @@ import net.minecraftforge.registries.ForgeRegistries;
import net.minecraftforge.registries.RegistryObject; import net.minecraftforge.registries.RegistryObject;
public class CreatePonderIndex { public class CreatePonderIndex {
static final CustomPonderRegistrationHelper<ItemProviderEntry<?>> HELPER = new CustomPonderRegistrationHelper<>(Create.ID, RegistryEntry::getId);
public static final List<Predicate<ItemLike>> INDEX_SCREEN_EXCLUSIONS = List.of( public static final List<Predicate<ItemLike>> INDEX_SCREEN_EXCLUSIONS = List.of(
itemLike -> { itemLike -> {
if (!(itemLike instanceof BlockItem blockItem)) if (!(itemLike instanceof BlockItem blockItem))
@ -78,10 +76,8 @@ public class CreatePonderIndex {
} }
); );
public static void register() { public static void register(PonderSceneRegistrationHelper<ResourceLocation> helper) {
// Register storyboards here PonderSceneRegistrationHelper<ItemProviderEntry<?>> HELPER = helper.withKeyFunction(RegistryEntry::getId);
// (!) Added entries require re-launch
// (!) Modifications inside storyboard methods only require re-opening the ui
HELPER.forComponents(AllBlocks.SHAFT) HELPER.forComponents(AllBlocks.SHAFT)
.addStoryBoard("shaft/relay", KineticsScenes::shaftAsRelay, AllPonderTags.KINETIC_RELAYS); .addStoryBoard("shaft/relay", KineticsScenes::shaftAsRelay, AllPonderTags.KINETIC_RELAYS);