From 6f183d857d97eb8f45f010b0d9975b4bb19faa9a Mon Sep 17 00:00:00 2001 From: anhgelus Date: Fri, 26 Jul 2024 21:23:43 +0000 Subject: refactor(minecraft): upgrade to 1.21 Thanks @Leo-210 for the idea --- src/main/java/world/anhgelus/manhunt/Manhunt.java | 280 ++++++++++----------- .../world/anhgelus/manhunt/mixin/ExampleMixin.java | 28 +-- 2 files changed, 154 insertions(+), 154 deletions(-) (limited to 'src/main/java/world') diff --git a/src/main/java/world/anhgelus/manhunt/Manhunt.java b/src/main/java/world/anhgelus/manhunt/Manhunt.java index 36e1be0..edee3cc 100644 --- a/src/main/java/world/anhgelus/manhunt/Manhunt.java +++ b/src/main/java/world/anhgelus/manhunt/Manhunt.java @@ -1,141 +1,141 @@ -package world.anhgelus.manhunt; - -import com.mojang.brigadier.Command; -import com.mojang.brigadier.builder.LiteralArgumentBuilder; -import com.mojang.brigadier.builder.RequiredArgumentBuilder; -import com.mojang.serialization.DataResult; -import net.fabricmc.api.ModInitializer; -import net.fabricmc.fabric.api.command.v1.CommandRegistrationCallback; -import net.fabricmc.fabric.api.entity.event.v1.ServerPlayerEvents; -import net.minecraft.command.EntitySelector; -import net.minecraft.command.arguments.EntityArgumentType; -import net.minecraft.datafixer.NbtOps; -import net.minecraft.entity.effect.StatusEffectInstance; -import net.minecraft.entity.effect.StatusEffects; -import net.minecraft.item.ItemStack; -import net.minecraft.item.Items; -import net.minecraft.nbt.CompoundTag; -import net.minecraft.nbt.NbtHelper; -import net.minecraft.nbt.Tag; -import net.minecraft.server.PlayerManager; -import net.minecraft.server.command.ServerCommandSource; -import net.minecraft.server.network.ServerPlayerEntity; -import net.minecraft.world.GameMode; -import net.minecraft.world.World; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; - -import java.util.*; - -import static com.mojang.brigadier.builder.LiteralArgumentBuilder.literal; - -public class Manhunt implements ModInitializer { - // This logger is used to write text to the console and the log file. - // It is considered best practice to use your mod id as the logger's name. - // That way, it's clear which mod wrote info, warnings, and errors. - public static final Logger LOGGER = LogManager.getLogger("manhunt"); - public static final String MOD_ID = "manhunt"; - - private final Set hunters = new HashSet<>(); - private final Set speedrunners = new HashSet<>(); - private final Map map = new HashMap<>(); - - private final Timer timer = new Timer(); - - @Override - public void onInitialize() { - LOGGER.info("Initializing Manhunt"); - - final LiteralArgumentBuilder command = literal("manhunt"); - - final LiteralArgumentBuilder track = literal("track"); - track.then(RequiredArgumentBuilder.argument("player", EntityArgumentType.player()) - .executes(context -> { - final ServerCommandSource source = context.getSource(); - final ServerPlayerEntity tracked = (ServerPlayerEntity) EntityArgumentType.getEntity(context, "player"); - final ServerPlayerEntity player = source.getPlayer(); - map.put(source.getPlayer().getUuid(), player.getUuid()); - updateCompass(player, tracked); - return Command.SINGLE_SUCCESS; - }) - ); - final LiteralArgumentBuilder team = literal("team"); - final RequiredArgumentBuilder teamP = RequiredArgumentBuilder.argument("player", EntityArgumentType.player()); - teamP.then(LiteralArgumentBuilder.literal("hunter").executes(context -> { - final ServerPlayerEntity p = (ServerPlayerEntity) EntityArgumentType.getEntity(context, "player"); - speedrunners.remove(p.getUuid()); - hunters.add(p.getUuid()); - return Command.SINGLE_SUCCESS; - })) - .then(LiteralArgumentBuilder.literal("speedrunner").executes(context -> { - final ServerPlayerEntity p = (ServerPlayerEntity) EntityArgumentType.getEntity(context, "player"); - hunters.remove(p.getUuid()); - speedrunners.add(p.getUuid()); - return Command.SINGLE_SUCCESS; - })); - team.then(teamP); - final LiteralArgumentBuilder start = literal("start"); - start.executes(context -> { - final PlayerManager pm = context.getSource().getMinecraftServer().getPlayerManager(); - for (final ServerPlayerEntity player : pm.getPlayerList()) { - speedrunners.remove(player.getUuid()); - player.kill(); - speedrunners.add(player.getUuid()); - } - for (final UUID uuid : hunters) { - final ServerPlayerEntity hunter = pm.getPlayer(uuid); - assert hunter != null; - hunter.giveItemStack(new ItemStack(Items.COMPASS)); - hunter.addStatusEffect(new StatusEffectInstance(StatusEffects.SLOWNESS, 30, 255)); - hunter.addStatusEffect(new StatusEffectInstance(StatusEffects.MINING_FATIGUE, 30, 255)); - } - timer.schedule(new TimerTask() { - @Override - public void run() { - for (final UUID uuid : hunters) { - final ServerPlayerEntity hunter = pm.getPlayer(uuid); - if (hunter == null) continue; - final ServerPlayerEntity tracked = pm.getPlayer(uuid); - if (tracked == null) continue; - updateCompass(hunter, tracked); - } - } - }, 60*1000, 60*1000); - return Command.SINGLE_SUCCESS; - }); - - command.then(track); - command.then(team); - command.then(start); - - CommandRegistrationCallback.EVENT.register((dispatcher, dedicated) -> dispatcher.register(command)); - - ServerPlayerEvents.AFTER_RESPAWN.register((oldPlayer, newPlayer, alive) -> { - if (alive) return; - final UUID uuid = oldPlayer.getUuid(); - if (hunters.contains(uuid)) { - newPlayer.giveItemStack(new ItemStack(Items.COMPASS)); - return; - } - speedrunners.remove(uuid); - if (!speedrunners.isEmpty()) return; - for (final ServerPlayerEntity player : newPlayer.server.getPlayerManager().getPlayerList()) { - player.setGameMode(GameMode.SPECTATOR); - hunters.remove(player.getUuid()); - speedrunners.remove(player.getUuid()); - } - }); - } - - private void updateCompass(ServerPlayerEntity player, ServerPlayerEntity tracked) { - final ItemStack stack = new ItemStack(Items.COMPASS); - assert stack.getTag() != null; - final CompoundTag tag = stack.getTag(); - tag.put("LodestonePos", NbtHelper.fromBlockPos(tracked.getBlockPos())); - final DataResult weird = World.CODEC.encodeStart(NbtOps.INSTANCE, player.world.getRegistryKey()); - weird.resultOrPartial(LOGGER::error).ifPresent((t) -> tag.put("LodestoneDimension", t)); - tag.putBoolean("LodestoneTracked", true); - final int slot = player.inventory.getSlotWithStack(new ItemStack(Items.COMPASS)); - player.inventory.insertStack(slot, stack); - } +package world.anhgelus.manhunt; + +import com.mojang.brigadier.Command; +import com.mojang.brigadier.builder.LiteralArgumentBuilder; +import com.mojang.brigadier.builder.RequiredArgumentBuilder; +import net.fabricmc.api.ModInitializer; +import net.fabricmc.fabric.api.command.v2.CommandRegistrationCallback; +import net.fabricmc.fabric.api.entity.event.v1.ServerPlayerEvents; +import net.minecraft.command.EntitySelector; +import net.minecraft.command.argument.EntityArgumentType; +import net.minecraft.component.DataComponentTypes; +import net.minecraft.component.type.LodestoneTrackerComponent; +import net.minecraft.entity.effect.StatusEffectInstance; +import net.minecraft.entity.effect.StatusEffects; +import net.minecraft.item.ItemStack; +import net.minecraft.item.Items; +import net.minecraft.server.PlayerManager; +import net.minecraft.server.command.ServerCommandSource; +import net.minecraft.server.network.ServerPlayerEntity; +import net.minecraft.util.math.GlobalPos; +import net.minecraft.world.GameMode; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; + +import java.util.*; + +import static com.mojang.brigadier.builder.LiteralArgumentBuilder.literal; + +public class Manhunt implements ModInitializer { + // This logger is used to write text to the console and the log file. + // It is considered best practice to use your mod id as the logger's name. + // That way, it's clear which mod wrote info, warnings, and errors. + public static final Logger LOGGER = LogManager.getLogger("manhunt"); + public static final String MOD_ID = "manhunt"; + + private final Set hunters = new HashSet<>(); + private final Set speedrunners = new HashSet<>(); + private final Map map = new HashMap<>(); + private final Map compassMap = new HashMap<>(); + + private final Timer timer = new Timer(); + + @Override + public void onInitialize() { + LOGGER.info("Initializing Manhunt"); + + final LiteralArgumentBuilder command = literal("manhunt"); + + final LiteralArgumentBuilder track = literal("track"); + track.then(RequiredArgumentBuilder.argument("player", EntityArgumentType.player()) + .executes(context -> { + final ServerCommandSource source = context.getSource(); + final ServerPlayerEntity tracked = (ServerPlayerEntity) EntityArgumentType.getEntity(context, "player"); + final ServerPlayerEntity player = source.getPlayer(); + map.put(source.getPlayer().getUuid(), player.getUuid()); + updateCompass(player, tracked); + return Command.SINGLE_SUCCESS; + }) + ); + final LiteralArgumentBuilder team = literal("team"); + final RequiredArgumentBuilder teamP = RequiredArgumentBuilder.argument("player", EntityArgumentType.player()); + teamP.then(LiteralArgumentBuilder.literal("hunter").executes(context -> { + final ServerPlayerEntity p = (ServerPlayerEntity) EntityArgumentType.getEntity(context, "player"); + speedrunners.remove(p.getUuid()); + hunters.add(p.getUuid()); + return Command.SINGLE_SUCCESS; + })) + .then(LiteralArgumentBuilder.literal("speedrunner").executes(context -> { + final ServerPlayerEntity p = (ServerPlayerEntity) EntityArgumentType.getEntity(context, "player"); + hunters.remove(p.getUuid()); + speedrunners.add(p.getUuid()); + return Command.SINGLE_SUCCESS; + })); + team.then(teamP); + final LiteralArgumentBuilder start = literal("start"); + start.executes(context -> { + final PlayerManager pm = context.getSource().getServer().getPlayerManager(); + for (final ServerPlayerEntity player : pm.getPlayerList()) { + speedrunners.remove(player.getUuid()); + player.kill(); + speedrunners.add(player.getUuid()); + } + for (final UUID uuid : hunters) { + final ServerPlayerEntity hunter = pm.getPlayer(uuid); + assert hunter != null; + hunter.giveItemStack(new ItemStack(Items.COMPASS)); + hunter.addStatusEffect(new StatusEffectInstance(StatusEffects.SLOWNESS, 30, 255)); + hunter.addStatusEffect(new StatusEffectInstance(StatusEffects.MINING_FATIGUE, 30, 255)); + } + timer.schedule(new TimerTask() { + @Override + public void run() { + for (final UUID uuid : hunters) { + final ServerPlayerEntity hunter = pm.getPlayer(uuid); + if (hunter == null) continue; + final ServerPlayerEntity tracked = pm.getPlayer(uuid); + if (tracked == null) continue; + updateCompass(hunter, tracked); + } + } + }, 60*1000, 60*1000); + return Command.SINGLE_SUCCESS; + }); + + command.then(track); + command.then(team); + command.then(start); + + CommandRegistrationCallback.EVENT.register((dispatcher, registryAccess, environment) -> dispatcher.register(command)); + + ServerPlayerEvents.AFTER_RESPAWN.register((oldPlayer, newPlayer, alive) -> { + if (alive) return; + final UUID uuid = oldPlayer.getUuid(); + if (hunters.contains(uuid)) { + newPlayer.giveItemStack(new ItemStack(Items.COMPASS)); + return; + } + speedrunners.remove(uuid); + if (!speedrunners.isEmpty()) return; + for (final ServerPlayerEntity player : newPlayer.server.getPlayerManager().getPlayerList()) { + player.changeGameMode(GameMode.SPECTATOR); + hunters.remove(player.getUuid()); + speedrunners.remove(player.getUuid()); + } + }); + } + + private void updateCompass(ServerPlayerEntity player, ServerPlayerEntity tracked) { + /* + final LodestoneTrackerComponent trackerCpnt = new LodestoneTrackerComponent(Optional.of(GlobalPos.create(tracked.getWorld().getRegistryKey(), tracked.getBlockPos())), true); + final ItemStack is = compassMap.get(player.getUuid()); + if (is == null) { + LOGGER.warn("Compass item is null"); + return; + } + final int slot = player.getInventory().getSlotWithStack(is); + is.set(DataComponentTypes.LODESTONE_TRACKER, trackerCpnt); + player.getInventory().setStack(slot, is); + */ + } } \ No newline at end of file diff --git a/src/main/java/world/anhgelus/manhunt/mixin/ExampleMixin.java b/src/main/java/world/anhgelus/manhunt/mixin/ExampleMixin.java index f3263af..0ea67b2 100644 --- a/src/main/java/world/anhgelus/manhunt/mixin/ExampleMixin.java +++ b/src/main/java/world/anhgelus/manhunt/mixin/ExampleMixin.java @@ -1,15 +1,15 @@ -package world.anhgelus.manhunt.mixin; - -import net.minecraft.server.MinecraftServer; -import org.spongepowered.asm.mixin.Mixin; -import org.spongepowered.asm.mixin.injection.At; -import org.spongepowered.asm.mixin.injection.Inject; -import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; - -@Mixin(MinecraftServer.class) -public class ExampleMixin { - @Inject(at = @At("HEAD"), method = "loadWorld") - private void init(CallbackInfo info) { - // This code is injected into the start of MinecraftServer.loadWorld()V - } +package world.anhgelus.manhunt.mixin; + +import net.minecraft.server.MinecraftServer; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +@Mixin(MinecraftServer.class) +public class ExampleMixin { + @Inject(at = @At("HEAD"), method = "loadWorld") + private void init(CallbackInfo info) { + // This code is injected into the start of MinecraftServer.loadWorld()V + } } \ No newline at end of file -- cgit v1.2.3