From aaecf6126a9ffcc1c76f819635f6617ba4c1ec24 Mon Sep 17 00:00:00 2001 From: SpaceToad Date: Sat, 8 Mar 2014 17:44:33 +0100 Subject: [PATCH] library is now passing directly byte arrays over the network, for #1477 --- .../builders/TileBlueprintLibrary.java | 59 +++++++++++-------- .../blueprints/BlueprintDatabase.java | 1 + .../network/serializers/ClassMapping.java | 8 +-- 3 files changed, 39 insertions(+), 29 deletions(-) diff --git a/common/buildcraft/builders/TileBlueprintLibrary.java b/common/buildcraft/builders/TileBlueprintLibrary.java index 16a03438..be0de35d 100644 --- a/common/buildcraft/builders/TileBlueprintLibrary.java +++ b/common/buildcraft/builders/TileBlueprintLibrary.java @@ -8,11 +8,13 @@ */ package buildcraft.builders; +import java.io.IOException; import java.util.ArrayList; import net.minecraft.entity.player.EntityPlayer; import net.minecraft.inventory.IInventory; import net.minecraft.item.ItemStack; +import net.minecraft.nbt.CompressedStreamTools; import net.minecraft.nbt.NBTTagCompound; import buildcraft.BuildCraftBuilders; import buildcraft.builders.blueprints.BlueprintId; @@ -216,9 +218,8 @@ public class TileBlueprintLibrary extends TileBuildCraft implements IInventory { BlueprintBase bpt = ItemBlueprint.getBlueprint(stack [1]); if (bpt != null && uploadingPlayer != null) { - NBTTagCompound nbt = new NBTTagCompound(); - bpt.writeToNBT(nbt); - RPCHandler.rpcPlayer(this, "downloadBlueprintToClient", uploadingPlayer, bpt.id, nbt); + RPCHandler.rpcPlayer(this, "downloadBlueprintToClient", + uploadingPlayer, bpt.id, bpt.getData()); uploadingPlayer = null; } } @@ -239,38 +240,50 @@ public class TileBlueprintLibrary extends TileBuildCraft implements IInventory { public void requestSelectedBlueprint () { if (selected > -1 && selected < currentPage.size()) { BlueprintBase bpt = BuildCraftBuilders.clientDB.get(currentPage.get(selected)); - NBTTagCompound nbt = new NBTTagCompound(); - bpt.writeToNBT(nbt); - RPCHandler.rpcServer(this, "uploadBlueprintToServer", bpt.id, nbt); + RPCHandler.rpcServer(this, "uploadBlueprintToServer", bpt.id, bpt.getData()); } else { RPCHandler.rpcServer(this, "uploadBlueprintToServer", null, null); } } @RPC (RPCSide.SERVER) - public void uploadBlueprintToServer (BlueprintId id, NBTTagCompound data) { - if (data != null) { - BlueprintBase bpt = BlueprintBase.loadBluePrint(data); - bpt.id = id; - BuildCraftBuilders.serverDB.add(bpt); - setInventorySlotContents(3, ItemBlueprint.getBlueprintItem(bpt)); - } else { - setInventorySlotContents(3, stack [2]); + public void uploadBlueprintToServer (BlueprintId id, byte [] data) { + try { + if (data != null) { + NBTTagCompound nbt = CompressedStreamTools.decompress(data); + BlueprintBase bpt = BlueprintBase.loadBluePrint(nbt); + bpt.setData(data); + bpt.id = id; + BuildCraftBuilders.serverDB.add(bpt); + setInventorySlotContents(3, ItemBlueprint.getBlueprintItem(bpt)); + } else { + setInventorySlotContents(3, stack[2]); + } + + setInventorySlotContents(2, null); + + downloadingPlayer = null; + } catch (IOException e) { + // TODO Auto-generated catch block + e.printStackTrace(); } - - setInventorySlotContents(2, null); - - downloadingPlayer = null; } @RPC (RPCSide.CLIENT) - public void downloadBlueprintToClient (BlueprintId id, NBTTagCompound data) { - BlueprintBase bpt = BlueprintBase.loadBluePrint(data); - bpt.id = id; + public void downloadBlueprintToClient (BlueprintId id, byte [] data) { + try { + NBTTagCompound nbt = CompressedStreamTools.decompress(data); + BlueprintBase bpt = BlueprintBase.loadBluePrint(nbt); + bpt.setData(data); + bpt.id = id; - BuildCraftBuilders.clientDB.add(bpt); - setCurrentPage(BuildCraftBuilders.clientDB.getPage (pageId)); + BuildCraftBuilders.clientDB.add(bpt); + setCurrentPage(BuildCraftBuilders.clientDB.getPage(pageId)); + } catch (IOException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } } public void selectBlueprint (int index) { diff --git a/common/buildcraft/builders/blueprints/BlueprintDatabase.java b/common/buildcraft/builders/blueprints/BlueprintDatabase.java index d940f728..738c5e79 100644 --- a/common/buildcraft/builders/blueprints/BlueprintDatabase.java +++ b/common/buildcraft/builders/blueprints/BlueprintDatabase.java @@ -163,6 +163,7 @@ public class BlueprintDatabase { NBTTagCompound nbt = CompressedStreamTools.decompress(data); BlueprintBase blueprint = BlueprintBase.loadBluePrint(nbt); + blueprint.setData(data); blueprint.id = id; loadedBlueprints.put(id, blueprint); diff --git a/common/buildcraft/core/network/serializers/ClassMapping.java b/common/buildcraft/core/network/serializers/ClassMapping.java index 049b1daf..0e527bdc 100644 --- a/common/buildcraft/core/network/serializers/ClassMapping.java +++ b/common/buildcraft/core/network/serializers/ClassMapping.java @@ -411,9 +411,7 @@ public class ClassMapping extends ClassSerializer { byte [] arr = (byte []) obj; data.writeInt (arr.length); - for (byte element : arr) { - data.writeByte(element); - } + data.writeBytes(arr); break; } @@ -496,9 +494,7 @@ public class ClassMapping extends ClassSerializer { arr = (byte []) obj; } - for (int i = 0; i < arr.length; ++i) { - arr [i] = data.readByte(); - } + data.readBytes (arr); obj = arr;