From e2ce52fe816b91a3ab0a5ba01184951272272b4a Mon Sep 17 00:00:00 2001 From: Possseidon Date: Wed, 19 Jan 2022 17:39:19 +0100 Subject: [PATCH 1/6] Fix table with mouse button codes. Codes for right and middle mouse buttons were swapped. --- doc/events/mouse_click.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/doc/events/mouse_click.md b/doc/events/mouse_click.md index 83d371260..ed4f2e3eb 100644 --- a/doc/events/mouse_click.md +++ b/doc/events/mouse_click.md @@ -19,8 +19,8 @@ numerical value depending on which button on your mouse was last pressed when th Button codeMouse button 1Left button - 2Middle button - 3Right button + 2Right button + 3Middle button ## Example From 60d1d1bb18e43e571ea218e32c302808427cf0bf Mon Sep 17 00:00:00 2001 From: Toad-Dev <748280+toad-dev@users.noreply.github.com> Date: Sun, 23 Jan 2022 22:20:14 -0800 Subject: [PATCH 2/6] Fix large file uploads producing oversized packets. - Fixes #1026 - The remaining bytes counter wasn't being decremented, so the code that splits off smaller packets was unreachable. Thus all file slices were being put into a single UploadFileMessage packet. --- .../computercraft/shared/network/server/UploadFileMessage.java | 1 + 1 file changed, 1 insertion(+) diff --git a/src/main/java/dan200/computercraft/shared/network/server/UploadFileMessage.java b/src/main/java/dan200/computercraft/shared/network/server/UploadFileMessage.java index 64f854a80..38c924789 100644 --- a/src/main/java/dan200/computercraft/shared/network/server/UploadFileMessage.java +++ b/src/main/java/dan200/computercraft/shared/network/server/UploadFileMessage.java @@ -160,6 +160,7 @@ public class UploadFileMessage extends ComputerServerMessage contents.position( currentOffset ).limit( currentOffset + canWrite ); slices.add( new FileSlice( fileId, currentOffset, contents.slice() ) ); currentOffset += canWrite; + remaining -= canWrite; } contents.position( 0 ).limit( capacity ); From 87b38f42496536714b00a6e7e4924e2b0d1fd5c6 Mon Sep 17 00:00:00 2001 From: Jonathan Coates Date: Mon, 28 Feb 2022 10:32:33 +0000 Subject: [PATCH 3/6] Fix incorrect recipe name in turtle advancement --- .../data/computercraft/advancements/recipes/turtle_normal.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/resources/data/computercraft/advancements/recipes/turtle_normal.json b/src/main/resources/data/computercraft/advancements/recipes/turtle_normal.json index 482be3e1c..b3c9e4982 100644 --- a/src/main/resources/data/computercraft/advancements/recipes/turtle_normal.json +++ b/src/main/resources/data/computercraft/advancements/recipes/turtle_normal.json @@ -1,7 +1,7 @@ { "parent": "minecraft:recipes/root", "rewards": { - "recipes": [ "computercraft:normal_turtle_normal" ] + "recipes": [ "computercraft:turtle_normal" ] }, "criteria": { "has_normal": { From e01895d71981fc02270ab706f1a99b9ccc3d30ca Mon Sep 17 00:00:00 2001 From: Jonathan Coates Date: Mon, 28 Feb 2022 10:33:08 +0000 Subject: [PATCH 4/6] Remove turtle_player EntityType This was added in the 1.13 update and I'm still not sure why. Other mods seem to get away without it, so I think it's fine to remove. Also remove the fake net manager, as that's part of Forge nowadays. Fixes #1044. --- .../computercraft/client/ClientRegistry.java | 4 - .../computercraft/shared/CommonHooks.java | 16 +- .../dan200/computercraft/shared/Registry.java | 16 - .../shared/turtle/core/TurtlePlayer.java | 11 - .../shared/util/FakeNetHandler.java | 348 ------------------ 5 files changed, 12 insertions(+), 383 deletions(-) delete mode 100644 src/main/java/dan200/computercraft/shared/util/FakeNetHandler.java diff --git a/src/main/java/dan200/computercraft/client/ClientRegistry.java b/src/main/java/dan200/computercraft/client/ClientRegistry.java index d6fabaa2f..362de0760 100644 --- a/src/main/java/dan200/computercraft/client/ClientRegistry.java +++ b/src/main/java/dan200/computercraft/client/ClientRegistry.java @@ -10,7 +10,6 @@ import dan200.computercraft.client.gui.*; import dan200.computercraft.client.render.TileEntityMonitorRenderer; import dan200.computercraft.client.render.TileEntityTurtleRenderer; import dan200.computercraft.client.render.TurtleModelLoader; -import dan200.computercraft.client.render.TurtlePlayerRenderer; import dan200.computercraft.shared.Registry; import dan200.computercraft.shared.common.IColouredItem; import dan200.computercraft.shared.computer.inventory.ContainerComputerBase; @@ -33,7 +32,6 @@ import net.minecraftforge.client.event.ModelRegistryEvent; import net.minecraftforge.client.model.ModelLoader; import net.minecraftforge.client.model.ModelLoaderRegistry; import net.minecraftforge.eventbus.api.SubscribeEvent; -import net.minecraftforge.fml.client.registry.RenderingRegistry; import net.minecraftforge.fml.common.Mod; import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent; @@ -140,8 +138,6 @@ public final class ClientRegistry net.minecraftforge.fml.client.registry.ClientRegistry.bindTileEntityRenderer( Registry.ModTiles.TURTLE_NORMAL.get(), TileEntityTurtleRenderer::new ); net.minecraftforge.fml.client.registry.ClientRegistry.bindTileEntityRenderer( Registry.ModTiles.TURTLE_ADVANCED.get(), TileEntityTurtleRenderer::new ); - RenderingRegistry.registerEntityRenderingHandler( Registry.ModEntities.TURTLE_PLAYER.get(), TurtlePlayerRenderer::new ); - registerItemProperty( "state", ( stack, world, player ) -> ItemPocketComputer.getState( stack ).ordinal(), Registry.ModItems.POCKET_COMPUTER_NORMAL, Registry.ModItems.POCKET_COMPUTER_ADVANCED diff --git a/src/main/java/dan200/computercraft/shared/CommonHooks.java b/src/main/java/dan200/computercraft/shared/CommonHooks.java index d9a4870a6..842a8af3d 100644 --- a/src/main/java/dan200/computercraft/shared/CommonHooks.java +++ b/src/main/java/dan200/computercraft/shared/CommonHooks.java @@ -16,6 +16,7 @@ import dan200.computercraft.shared.computer.core.IComputer; import dan200.computercraft.shared.computer.core.IContainerComputer; import dan200.computercraft.shared.computer.core.ServerComputer; import dan200.computercraft.shared.peripheral.modem.wireless.WirelessNetwork; +import net.minecraft.entity.EntityType; import net.minecraft.inventory.container.Container; import net.minecraft.loot.ConstantRange; import net.minecraft.loot.LootPool; @@ -24,10 +25,7 @@ import net.minecraft.loot.TableLootEntry; import net.minecraft.server.MinecraftServer; import net.minecraft.server.dedicated.DedicatedServer; import net.minecraft.util.ResourceLocation; -import net.minecraftforge.event.AddReloadListenerEvent; -import net.minecraftforge.event.LootTableLoadEvent; -import net.minecraftforge.event.RegisterCommandsEvent; -import net.minecraftforge.event.TickEvent; +import net.minecraftforge.event.*; import net.minecraftforge.event.entity.player.PlayerContainerEvent; import net.minecraftforge.eventbus.api.SubscribeEvent; import net.minecraftforge.fml.common.Mod; @@ -146,4 +144,14 @@ public final class CommonHooks { event.addListener( ResourceMount.RELOAD_LISTENER ); } + + @SubscribeEvent + public static void onMissingEntityMappingsEvent( RegistryEvent.MissingMappings> event ) + { + ResourceLocation id = new ResourceLocation( ComputerCraft.MOD_ID, "turtle_player" ); + for( RegistryEvent.MissingMappings.Mapping> mapping : event.getMappings( ComputerCraft.MOD_ID ) ) + { + if( mapping.key.equals( id ) ) mapping.ignore(); + } + } } diff --git a/src/main/java/dan200/computercraft/shared/Registry.java b/src/main/java/dan200/computercraft/shared/Registry.java index 635930fcb..3d838fa58 100644 --- a/src/main/java/dan200/computercraft/shared/Registry.java +++ b/src/main/java/dan200/computercraft/shared/Registry.java @@ -60,7 +60,6 @@ import dan200.computercraft.shared.pocket.peripherals.PocketSpeaker; import dan200.computercraft.shared.pocket.recipes.PocketComputerUpgradeRecipe; import dan200.computercraft.shared.turtle.blocks.BlockTurtle; import dan200.computercraft.shared.turtle.blocks.TileTurtle; -import dan200.computercraft.shared.turtle.core.TurtlePlayer; import dan200.computercraft.shared.turtle.inventory.ContainerTurtle; import dan200.computercraft.shared.turtle.items.ItemTurtle; import dan200.computercraft.shared.turtle.recipes.TurtleRecipe; @@ -70,8 +69,6 @@ import dan200.computercraft.shared.util.*; import net.minecraft.block.AbstractBlock; import net.minecraft.block.Block; import net.minecraft.block.material.Material; -import net.minecraft.entity.EntityClassification; -import net.minecraft.entity.EntityType; import net.minecraft.inventory.container.ContainerType; import net.minecraft.item.*; import net.minecraft.item.crafting.IRecipeSerializer; @@ -296,18 +293,6 @@ public final class Registry ComputerCraftAPI.registerPocketUpgrade( ComputerCraft.PocketUpgrades.speaker = new PocketSpeaker() ); } - public static class ModEntities - { - static final DeferredRegister> ENTITIES = DeferredRegister.create( ForgeRegistries.ENTITIES, ComputerCraft.MOD_ID ); - - public static final RegistryObject> TURTLE_PLAYER = ENTITIES.register( "turtle_player", () -> - EntityType.Builder.createNothing( EntityClassification.MISC ) - .noSave() - .noSummon() - .sized( 0, 0 ) - .build( ComputerCraft.MOD_ID + ":turtle_player" ) ); - } - public static class ModContainers { static final DeferredRegister> CONTAINERS = DeferredRegister.create( ForgeRegistries.CONTAINERS, ComputerCraft.MOD_ID ); @@ -418,7 +403,6 @@ public final class Registry ModBlocks.BLOCKS.register( bus ); ModTiles.TILES.register( bus ); ModItems.ITEMS.register( bus ); - ModEntities.ENTITIES.register( bus ); ModContainers.CONTAINERS.register( bus ); } } diff --git a/src/main/java/dan200/computercraft/shared/turtle/core/TurtlePlayer.java b/src/main/java/dan200/computercraft/shared/turtle/core/TurtlePlayer.java index f388e8367..ba9b513c6 100644 --- a/src/main/java/dan200/computercraft/shared/turtle/core/TurtlePlayer.java +++ b/src/main/java/dan200/computercraft/shared/turtle/core/TurtlePlayer.java @@ -8,14 +8,11 @@ package dan200.computercraft.shared.turtle.core; import com.mojang.authlib.GameProfile; import dan200.computercraft.ComputerCraft; import dan200.computercraft.api.turtle.ITurtleAccess; -import dan200.computercraft.shared.Registry; import dan200.computercraft.shared.util.DirectionUtil; -import dan200.computercraft.shared.util.FakeNetHandler; import dan200.computercraft.shared.util.InventoryUtil; import dan200.computercraft.shared.util.WorldUtil; import net.minecraft.entity.Entity; import net.minecraft.entity.EntitySize; -import net.minecraft.entity.EntityType; import net.minecraft.entity.Pose; import net.minecraft.entity.passive.horse.AbstractHorseEntity; import net.minecraft.entity.player.ServerPlayerEntity; @@ -54,7 +51,6 @@ public final class TurtlePlayer extends FakePlayer GameProfile profile = turtle.getOwningPlayer(); TurtlePlayer player = new TurtlePlayer( world, getProfile( profile ) ); - player.connection = new FakeNetHandler( player ); player.setState( turtle ); if( profile != null && profile.getId() != null ) @@ -203,13 +199,6 @@ public final class TurtlePlayer extends FakePlayer inventory.setChanged(); } - @Nonnull - @Override - public EntityType getType() - { - return Registry.ModEntities.TURTLE_PLAYER.get(); - } - @Override public Vector3d position() { diff --git a/src/main/java/dan200/computercraft/shared/util/FakeNetHandler.java b/src/main/java/dan200/computercraft/shared/util/FakeNetHandler.java deleted file mode 100644 index 46a8fe924..000000000 --- a/src/main/java/dan200/computercraft/shared/util/FakeNetHandler.java +++ /dev/null @@ -1,348 +0,0 @@ -/* - * This file is part of ComputerCraft - http://www.computercraft.info - * Copyright Daniel Ratcliffe, 2011-2022. Do not distribute without permission. - * Send enquiries to dratcliffe@gmail.com - */ -package dan200.computercraft.shared.util; - -import io.netty.channel.ChannelHandlerContext; -import io.netty.util.concurrent.Future; -import io.netty.util.concurrent.GenericFutureListener; -import net.minecraft.network.*; -import net.minecraft.network.play.ServerPlayNetHandler; -import net.minecraft.network.play.client.*; -import net.minecraft.util.text.ITextComponent; -import net.minecraftforge.common.util.FakePlayer; - -import javax.annotation.Nonnull; -import javax.annotation.Nullable; - -public class FakeNetHandler extends ServerPlayNetHandler -{ - public FakeNetHandler( @Nonnull FakePlayer player ) - { - super( player.getLevel().getServer(), new FakeNetworkManager(), player ); - } - - @Override - public void tick() - { - } - - @Override - public void disconnect( @Nonnull ITextComponent reason ) - { - } - - @Override - public void onDisconnect( @Nonnull ITextComponent reason ) - { - } - - @Override - public void send( @Nonnull IPacket packet ) - { - } - - @Override - public void send( @Nonnull IPacket packet, @Nullable GenericFutureListener> whenSent ) - { - } - - @Override - public void handlePlayerInput( @Nonnull CInputPacket packet ) - { - } - - @Override - public void handleMoveVehicle( @Nonnull CMoveVehiclePacket packet ) - { - } - - @Override - public void handleAcceptTeleportPacket( @Nonnull CConfirmTeleportPacket packet ) - { - } - - @Override - public void handleSeenAdvancements( @Nonnull CSeenAdvancementsPacket packet ) - { - } - - @Override - public void handleCustomCommandSuggestions( @Nonnull CTabCompletePacket packet ) - { - } - - @Override - public void handleSetCommandBlock( @Nonnull CUpdateCommandBlockPacket packet ) - { - } - - @Override - public void handleSetCommandMinecart( @Nonnull CUpdateMinecartCommandBlockPacket packet ) - { - } - - @Override - public void handlePickItem( @Nonnull CPickItemPacket packet ) - { - } - - @Override - public void handleRenameItem( @Nonnull CRenameItemPacket packet ) - { - } - - @Override - public void handleSetBeaconPacket( @Nonnull CUpdateBeaconPacket packet ) - { - } - - @Override - public void handleSetStructureBlock( @Nonnull CUpdateStructureBlockPacket packet ) - { - } - - @Override - public void handleSetJigsawBlock( @Nonnull CUpdateJigsawBlockPacket packet ) - { - } - - @Override - public void handleSelectTrade( @Nonnull CSelectTradePacket packet ) - { - } - - @Override - public void handleEditBook( @Nonnull CEditBookPacket packet ) - { - } - - @Override - public void handleEntityTagQuery( @Nonnull CQueryEntityNBTPacket packet ) - { - } - - @Override - public void handleBlockEntityTagQuery( @Nonnull CQueryTileEntityNBTPacket packet ) - { - } - - @Override - public void handleMovePlayer( @Nonnull CPlayerPacket packet ) - { - } - - @Override - public void handlePlayerAction( @Nonnull CPlayerDiggingPacket packet ) - { - } - - @Override - public void handleUseItemOn( @Nonnull CPlayerTryUseItemOnBlockPacket packet ) - { - } - - @Override - public void handleUseItem( @Nonnull CPlayerTryUseItemPacket packet ) - { - } - - @Override - public void handleTeleportToEntityPacket( @Nonnull CSpectatePacket packet ) - { - } - - @Override - public void handleResourcePackResponse( @Nonnull CResourcePackStatusPacket packet ) - { - } - - @Override - public void handlePaddleBoat( @Nonnull CSteerBoatPacket packet ) - { - } - - @Override - public void handleSetCarriedItem( @Nonnull CHeldItemChangePacket packet ) - { - } - - @Override - public void handleChat( @Nonnull CChatMessagePacket packet ) - { - } - - @Override - public void handleAnimate( @Nonnull CAnimateHandPacket packet ) - { - } - - @Override - public void handlePlayerCommand( @Nonnull CEntityActionPacket packet ) - { - } - - @Override - public void handleInteract( @Nonnull CUseEntityPacket packet ) - { - } - - @Override - public void handleClientCommand( @Nonnull CClientStatusPacket packet ) - { - } - - @Override - public void handleContainerClose( @Nonnull CCloseWindowPacket packet ) - { - } - - @Override - public void handleContainerClick( @Nonnull CClickWindowPacket packet ) - { - } - - @Override - public void handlePlaceRecipe( @Nonnull CPlaceRecipePacket packet ) - { - } - - @Override - public void handleContainerButtonClick( @Nonnull CEnchantItemPacket packet ) - { - } - - @Override - public void handleSetCreativeModeSlot( @Nonnull CCreativeInventoryActionPacket packet ) - { - } - - @Override - public void handleContainerAck( @Nonnull CConfirmTransactionPacket packet ) - { - } - - @Override - public void handleSignUpdate( @Nonnull CUpdateSignPacket packet ) - { - } - - @Override - public void handleKeepAlive( @Nonnull CKeepAlivePacket packet ) - { - } - - @Override - public void handlePlayerAbilities( @Nonnull CPlayerAbilitiesPacket packet ) - { - } - - @Override - public void handleClientInformation( @Nonnull CClientSettingsPacket packet ) - { - } - - @Override - public void handleCustomPayload( @Nonnull CCustomPayloadPacket packet ) - { - } - - @Override - public void handleChangeDifficulty( @Nonnull CSetDifficultyPacket packet ) - { - } - - @Override - public void handleLockDifficulty( @Nonnull CLockDifficultyPacket packet ) - { - } - - private static class FakeNetworkManager extends NetworkManager - { - private INetHandler handler; - private ITextComponent closeReason; - - FakeNetworkManager() - { - super( PacketDirection.CLIENTBOUND ); - } - - @Override - public void channelActive( @Nonnull ChannelHandlerContext context ) - { - } - - @Override - public void setProtocol( @Nonnull ProtocolType state ) - { - } - - @Override - public void channelInactive( @Nonnull ChannelHandlerContext context ) - { - } - - @Override - public void exceptionCaught( @Nonnull ChannelHandlerContext context, @Nonnull Throwable err ) - { - } - - @Override - protected void channelRead0( @Nonnull ChannelHandlerContext context, @Nonnull IPacket packet ) - { - } - - @Override - public void setListener( @Nonnull INetHandler handler ) - { - this.handler = handler; - } - - @Override - public void send( @Nonnull IPacket packet ) - { - } - - @Override - public void send( @Nonnull IPacket packet, @Nullable GenericFutureListener> whenSent ) - { - } - - @Override - public void tick() - { - } - - @Override - public void disconnect( @Nonnull ITextComponent message ) - { - closeReason = message; - } - - @Nonnull - @Override - public INetHandler getPacketListener() - { - return handler; - } - - @Nullable - @Override - public ITextComponent getDisconnectedReason() - { - return closeReason; - } - - @Override - public void setReadOnly() - { - } - - @Override - public void setupCompression( int threshold ) - { - } - } -} From e0fcc425c6305caa017bd3ad8a4951465a2c6721 Mon Sep 17 00:00:00 2001 From: Jonathan Coates Date: Mon, 28 Feb 2022 11:00:19 +0000 Subject: [PATCH 5/6] Prevent id map being null when file is empty Fixes #1030 --- .../computercraft/shared/util/IDAssigner.java | 23 ++++++++----------- 1 file changed, 9 insertions(+), 14 deletions(-) diff --git a/src/main/java/dan200/computercraft/shared/util/IDAssigner.java b/src/main/java/dan200/computercraft/shared/util/IDAssigner.java index 862dcdc2a..82faa5fb7 100644 --- a/src/main/java/dan200/computercraft/shared/util/IDAssigner.java +++ b/src/main/java/dan200/computercraft/shared/util/IDAssigner.java @@ -45,21 +45,17 @@ public final class IDAssigner return ServerLifecycleHooks.getCurrentServer().getWorldPath( FOLDER ).toFile(); } - private static MinecraftServer getCachedServer() + private static boolean hasServerChanged() { - if( server == null ) return null; + if( server == null ) return true; MinecraftServer currentServer = server.get(); - if( currentServer == null ) return null; - - if( currentServer != ServerLifecycleHooks.getCurrentServer() ) return null; - return currentServer; + return currentServer == null || currentServer != ServerLifecycleHooks.getCurrentServer(); } public static synchronized int getNextId( String kind ) { - MinecraftServer currentServer = getCachedServer(); - if( currentServer == null ) + if( hasServerChanged() ) { // The server has changed, refetch our ID map server = new WeakReference<>( ServerLifecycleHooks.getCurrentServer() ); @@ -68,23 +64,22 @@ public final class IDAssigner dir.mkdirs(); // Load our ID file from disk + Map newIds = null; idFile = new File( dir, "ids.json" ).toPath(); if( Files.isRegularFile( idFile ) ) { try( Reader reader = Files.newBufferedReader( idFile, StandardCharsets.UTF_8 ) ) { - ids = GSON.fromJson( reader, ID_TOKEN ); + newIds = GSON.fromJson( reader, ID_TOKEN ); } catch( Exception e ) { ComputerCraft.log.error( "Cannot load id file '" + idFile + "'", e ); - ids = new HashMap<>(); } } - else - { - ids = new HashMap<>(); - } + + if( newIds == null ) newIds = new HashMap<>(); + ids = newIds; } Integer existing = ids.get( kind ); From bd36185662321297b0c24c07951535d4a5cc7432 Mon Sep 17 00:00:00 2001 From: Jonathan Coates Date: Mon, 28 Feb 2022 15:35:16 +0000 Subject: [PATCH 6/6] Bump version Holding off until Forge releases for 1.18.2 --- gradle.properties | 2 +- .../data/computercraft/lua/rom/help/changelog.md | 8 ++++++++ .../resources/data/computercraft/lua/rom/help/whatsnew.md | 8 +++++--- 3 files changed, 14 insertions(+), 4 deletions(-) diff --git a/gradle.properties b/gradle.properties index e031b2d60..1595760c5 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,5 +1,5 @@ # Mod properties -mod_version=1.100.2 +mod_version=1.100.3 # Minecraft properties (update mods.toml when changing) mc_version=1.16.5 diff --git a/src/main/resources/data/computercraft/lua/rom/help/changelog.md b/src/main/resources/data/computercraft/lua/rom/help/changelog.md index e833dd2bf..4d5888949 100644 --- a/src/main/resources/data/computercraft/lua/rom/help/changelog.md +++ b/src/main/resources/data/computercraft/lua/rom/help/changelog.md @@ -1,3 +1,11 @@ +# New features in CC: Tweaked 1.100.3 + +Several bug fixes: +* Fix client disconnect when uploading large files. +* Correctly handling empty computer ID file. +* Fix the normal turtle recipe not being unlocked. +* Remove turtle fake EntityType. + # New features in CC: Tweaked 1.100.2 Several bug fixes: diff --git a/src/main/resources/data/computercraft/lua/rom/help/whatsnew.md b/src/main/resources/data/computercraft/lua/rom/help/whatsnew.md index bbd0e76f2..ce9e428f4 100644 --- a/src/main/resources/data/computercraft/lua/rom/help/whatsnew.md +++ b/src/main/resources/data/computercraft/lua/rom/help/whatsnew.md @@ -1,7 +1,9 @@ -New features in CC: Tweaked 1.100.2 +New features in CC: Tweaked 1.100.3 Several bug fixes: -* Fix wired modems swapping the modem/peripheral block state. -* Remove debugging logging line from `turtle.attack`. +* Fix client disconnect when uploading large files. +* Correctly handling empty computer ID file. +* Fix the normal turtle recipe not being unlocked. +* Remove turtle fake EntityType. Type "help changelog" to see the full version history.