library is now passing directly byte arrays over the network, for #1477
This commit is contained in:
parent
c8ebad37c3
commit
aaecf6126a
3 changed files with 39 additions and 29 deletions
|
@ -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,19 +240,20 @@ 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) {
|
||||
public void uploadBlueprintToServer (BlueprintId id, byte [] data) {
|
||||
try {
|
||||
if (data != null) {
|
||||
BlueprintBase bpt = BlueprintBase.loadBluePrint(data);
|
||||
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));
|
||||
|
@ -262,15 +264,26 @@ public class TileBlueprintLibrary extends TileBuildCraft implements IInventory {
|
|||
setInventorySlotContents(2, null);
|
||||
|
||||
downloadingPlayer = null;
|
||||
} catch (IOException e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
@RPC (RPCSide.CLIENT)
|
||||
public void downloadBlueprintToClient (BlueprintId id, NBTTagCompound data) {
|
||||
BlueprintBase bpt = BlueprintBase.loadBluePrint(data);
|
||||
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));
|
||||
} catch (IOException e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
public void selectBlueprint (int index) {
|
||||
|
|
|
@ -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);
|
||||
|
|
|
@ -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;
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue