diff --git a/build.gradle b/build.gradle index 2bfa673..3c659e0 100644 --- a/build.gradle +++ b/build.gradle @@ -10,7 +10,6 @@ buildscript { } plugins { - id 'eclipse' id 'idea' id 'net.minecraftforge.gradle' version '[6.0.16,6.2)' id 'org.parchmentmc.librarian.forgegradle' version '1.+' @@ -26,7 +25,7 @@ base { } java { - toolchain.languageVersion = JavaLanguageVersion.of(21) + toolchain.languageVersion = JavaLanguageVersion.of(17) } minecraft { @@ -45,8 +44,6 @@ minecraft { // Simply re-run your setup task after changing the mappings to update your workspace. mappings channel: mapping_channel, version: mapping_version - // Tell FG to not automatically create the reobf tasks, as we now use Official mappings at runtime, If you don't use them at dev time then you'll have to fix your reobf yourself. - reobf = false // When true, this property will have all Eclipse/IntelliJ IDEA run configurations run the "prepareX" task for the given run configuration before launching the game. // In most cases, it is not necessary to enable. @@ -90,6 +87,12 @@ minecraft { // You can set various levels here. // Please read: https://stackoverflow.com/questions/2031163/when-to-use-the-different-log-levels property 'forge.logging.console.level', 'debug' + + mods { + "${mod_id}" { + source sourceSets.main + } + } } client { @@ -196,18 +199,9 @@ tasks.named('jar', Jar).configure { "Implementation-Vendor" : mod_authors, "Implementation-Timestamp": new Date().format("yyyy-MM-dd'T'HH:mm:ssZ")]) } + finalizedBy 'reobfJar' } tasks.withType(JavaCompile).configureEach { options.encoding = 'UTF-8' // Use the UTF-8 charset for Java compilation -} - -// Merge the resources and classes into the same directory. -// This is done because java expects modules to be in a single directory. -// And if we have it in multiple we have to do performance intensive hacks like having the UnionFileSystem -// This will eventually be migrated to ForgeGradle so modders don't need to manually do it. But that is later. -sourceSets.each { - def dir = layout.buildDirectory.dir("sourcesSets/$it.name") - it.output.resourcesDir = dir - it.java.destinationDirectory = dir -} +} \ No newline at end of file diff --git a/gradle.properties b/gradle.properties index 837c73a..c9e7c53 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,17 +1,17 @@ org.gradle.jvmargs=-Xmx3G org.gradle.daemon=false # The Minecraft version must agree with the Forge version to get a valid artifact -minecraft_version=1.21.4 +minecraft_version=1.20 # The Minecraft version range can use any release version of Minecraft as bounds. # Snapshots, pre-releases, and release candidates are not guaranteed to sort properly # as they do not follow standard versioning conventions. -minecraft_version_range=[1.21.4,1.22) +minecraft_version_range=[1.20] # The Forge version must agree with the Minecraft version to get a valid artifact -forge_version=54.1.0 +forge_version=46.0.14 # The Forge version range can use any version of Forge as bounds or match the loader version range -forge_version_range=[54,) +forge_version_range=[46,) # The loader version range can only use the major version of Forge/FML as bounds -loader_version_range=[54,) +loader_version_range=[46,) # The mapping channel to use for mappings. # The default set of supported mapping channels are ["official", "snapshot", "snapshot_nodoc", "stable", "stable_nodoc"]. # Additional mapping channels can be registered through the "channelProviders" extension in a Gradle plugin. @@ -29,7 +29,7 @@ loader_version_range=[54,) mapping_channel=official # The mapping version to query from the mapping channel. # This must match the format required by the mapping channel. -mapping_version=1.21.4 +mapping_version=1.20 # The unique mod identifier for the mod. Must be lowercase in English locale. Must fit the regex [a-z][a-z0-9_]{1,63} # Must match the String constant located in the main mod class annotated with @Mod. mod_id=xp2items diff --git a/src/main/java/com/jenny/xp2items/Xp2Items.java b/src/main/java/com/jenny/xp2items/Xp2Items.java index c6924ec..50fda7b 100644 --- a/src/main/java/com/jenny/xp2items/Xp2Items.java +++ b/src/main/java/com/jenny/xp2items/Xp2Items.java @@ -14,8 +14,8 @@ public class Xp2Items { public static final String MODID = "xp2items"; - public Xp2Items(FMLJavaModLoadingContext context) { - IEventBus modEventBus = context.getModEventBus(); + public Xp2Items() { + IEventBus modEventBus = FMLJavaModLoadingContext.get().getModEventBus(); items.register(modEventBus); creativeTab.register(modEventBus); diff --git a/src/main/java/com/jenny/xp2items/items/items.java b/src/main/java/com/jenny/xp2items/items/items.java index 95d08a6..ca12a7f 100644 --- a/src/main/java/com/jenny/xp2items/items/items.java +++ b/src/main/java/com/jenny/xp2items/items/items.java @@ -1,8 +1,5 @@ package com.jenny.xp2items.items; -import net.minecraft.core.registries.Registries; -import net.minecraft.resources.ResourceKey; -import net.minecraft.resources.ResourceLocation; import net.minecraft.world.item.Item; import net.minecraftforge.eventbus.api.IEventBus; import net.minecraftforge.registries.DeferredRegister; @@ -14,7 +11,7 @@ import static com.jenny.xp2items.Xp2Items.MODID; public class items { public static final DeferredRegister ITEMS = DeferredRegister.create(ForgeRegistries.ITEMS, MODID); - public static final RegistryObject XP_TALISMAN = ITEMS.register("xp_talisman", () -> new xpTalisman(new Item.Properties().setId(ResourceKey.create(Registries.ITEM, ResourceLocation.fromNamespaceAndPath(MODID, "xp_talisman"))).stacksTo(1))); + public static final RegistryObject XP_TALISMAN = ITEMS.register("xp_talisman", () -> new xpTalisman(new Item.Properties().stacksTo(1))); public static void register(IEventBus bus) { ITEMS.register(bus); diff --git a/src/main/java/com/jenny/xp2items/items/xpTalisman.java b/src/main/java/com/jenny/xp2items/items/xpTalisman.java index b3c7477..34cfc60 100644 --- a/src/main/java/com/jenny/xp2items/items/xpTalisman.java +++ b/src/main/java/com/jenny/xp2items/items/xpTalisman.java @@ -7,7 +7,7 @@ import net.minecraft.sounds.SoundEvents; import net.minecraft.sounds.SoundSource; import net.minecraft.util.Mth; import net.minecraft.world.InteractionHand; -import net.minecraft.world.InteractionResult; +import net.minecraft.world.InteractionResultHolder; import net.minecraft.world.entity.item.ItemEntity; import net.minecraft.world.entity.player.Player; import net.minecraft.world.item.Item; @@ -69,7 +69,7 @@ public class xpTalisman extends Item { } @Override - public @NotNull InteractionResult use(@NotNull Level level, @NotNull Player player, @NotNull InteractionHand interactionHand) { + public InteractionResultHolder use(@NotNull Level level, @NotNull Player player, @NotNull InteractionHand interactionHand) { if (!level.isClientSide) { if (ServerConfig.C_XP_AMOUNT.get() > 0) { // xp amount mode spawnItem(level, (ServerPlayer) player); @@ -79,6 +79,6 @@ public class xpTalisman extends Item { } else { effects(level, player); } - return InteractionResult.SUCCESS; + return InteractionResultHolder.success(player.getItemInHand(interactionHand)); } } diff --git a/src/main/resources/xp2items.mixins.json b/src/main/resources/xp2items.mixins.json index ddd3d5a..9a9db48 100644 --- a/src/main/resources/xp2items.mixins.json +++ b/src/main/resources/xp2items.mixins.json @@ -2,7 +2,7 @@ "required": true, "minVersion": "0.8", "package": "com.jenny.xp2items.mixins", - "compatibilityLevel": "JAVA_21", + "compatibilityLevel": "JAVA_17", "refmap": "xp2items.refmap.json", "client": [ ],