Implemented Importing and Exporting Tile Entities; Additional Improvements #41
@@ -30,16 +30,16 @@ public class Point3D implements Serializable {
|
|||||||
return z;
|
return z;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int setY(int y)
|
|
||||||
{
|
|
||||||
return this.y=y;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int setX(int x)
|
public int setX(int x)
|
||||||
{
|
{
|
||||||
return this.x = x;
|
return this.x = x;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int setY(int y)
|
||||||
|
{
|
||||||
|
return this.y = y;
|
||||||
|
}
|
||||||
|
|
||||||
public int setZ(int z)
|
public int setZ(int z)
|
||||||
{
|
{
|
||||||
return this.z = z;
|
return this.z = z;
|
||||||
@@ -50,14 +50,55 @@ public class Point3D implements Serializable {
|
|||||||
return new Point3D(x, y, z);
|
return new Point3D(x, y, z);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean equals(Point3D other)
|
||||||
|
{
|
||||||
|
if (other == null)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (this == other)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return (this.x == other.x && this.y == other.y && this.z == other.z);
|
||||||
|
}
|
||||||
|
|
||||||
public boolean equals(Object other)
|
public boolean equals(Object other)
|
||||||
{
|
{
|
||||||
boolean result = false;
|
return equals((Point3D) other);
|
||||||
if (other instanceof Point3D)
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode()
|
||||||
{
|
{
|
||||||
Point3D that = (Point3D) other;
|
//Time for some witchcraft.
|
||||||
result = (this.getX() == that.getX() && this.getY() == that.getY()&& this.getY() == that.getZ());
|
//The code here is inspired by a discussion on Stack Overflow regarding hash codes for 3D.
|
||||||
|
//Source: http://stackoverflow.com/questions/9858376/hashcode-for-3d-integer-coordinates-with-high-spatial-coherence
|
||||||
|
|
||||||
|
//I believe that most of the time, any points we might be hashing will be in close proximity to each other.
|
||||||
|
//For instance, points that are within the same chunk or within a few neighboring chunks. Only the low-order
|
||||||
|
//bits of each component would differ. I'll use 8 bits from Y and the 12 bits from X and Z. ~SenseiKiwi
|
||||||
|
|
||||||
|
int bit;
|
||||||
|
int hash;
|
||||||
|
int index;
|
||||||
|
|
||||||
|
hash = 0;
|
||||||
|
index = 0;
|
||||||
|
for (bit = 0; bit < 8; bit++)
|
||||||
|
{
|
||||||
|
hash |= ((y >> bit) & 1) << index;
|
||||||
|
index++;
|
||||||
|
hash |= ((x >> bit) & 1) << index;
|
||||||
|
index++;
|
||||||
|
hash |= ((z >> bit) & 1) << index;
|
||||||
|
index++;
|
||||||
}
|
}
|
||||||
return result;
|
for (; bit < 12; bit++)
|
||||||
|
{
|
||||||
|
hash |= ((x >> bit) & 1) << index;
|
||||||
|
index++;
|
||||||
|
hash |= ((z >> bit) & 1) << index;
|
||||||
|
index++;
|
||||||
|
}
|
||||||
|
return hash;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -3,6 +3,7 @@ import java.io.File;
|
|||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
|
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
@@ -12,11 +13,13 @@ import net.minecraft.block.BlockDoor;
|
|||||||
import net.minecraft.block.BlockRedstoneRepeater;
|
import net.minecraft.block.BlockRedstoneRepeater;
|
||||||
import net.minecraft.block.BlockStairs;
|
import net.minecraft.block.BlockStairs;
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
|
import net.minecraft.inventory.IInventory;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.CompressedStreamTools;
|
import net.minecraft.nbt.CompressedStreamTools;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.nbt.NBTTagList;
|
import net.minecraft.nbt.NBTTagList;
|
||||||
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.tileentity.TileEntityChest;
|
import net.minecraft.tileentity.TileEntityChest;
|
||||||
import net.minecraft.tileentity.TileEntityDispenser;
|
import net.minecraft.tileentity.TileEntityDispenser;
|
||||||
import net.minecraft.util.MathHelper;
|
import net.minecraft.util.MathHelper;
|
||||||
@@ -34,6 +37,7 @@ public class SchematicLoader
|
|||||||
{
|
{
|
||||||
private final static int EAST_DOOR_METADATA = 0;
|
private final static int EAST_DOOR_METADATA = 0;
|
||||||
private final static int NORTH_DOOR_METADATA = 3;
|
private final static int NORTH_DOOR_METADATA = 3;
|
||||||
|
private final static int MAX_VANILLA_BLOCK_ID = 158;
|
||||||
|
|
||||||
private DDProperties properties = DDProperties.instance();
|
private DDProperties properties = DDProperties.instance();
|
||||||
|
|
||||||
@@ -688,15 +692,16 @@ public class SchematicLoader
|
|||||||
//block metaData
|
//block metaData
|
||||||
byte[] blockData = new byte[0];
|
byte[] blockData = new byte[0];
|
||||||
|
|
||||||
//first 4 bytes of the block ID
|
//first 8 bits of the block ID
|
||||||
byte[] blockId = new byte[0];
|
byte[] blockId = new byte[0];
|
||||||
|
|
||||||
//second 4 bytes of the block ID
|
//additional 4 bits of the block ID
|
||||||
byte[] addId = new byte[0];
|
byte[] addId = new byte[0];
|
||||||
|
|
||||||
|
//Variables for loading tile entities
|
||||||
|
boolean blockChanged = false;
|
||||||
NBTTagList tileEntities = null;
|
NBTTagList tileEntities = null;
|
||||||
NBTTagCompound[] tileEntityList;
|
HashMap<Point3D, NBTTagCompound> pointToTileEntityMap = new HashMap<Point3D, NBTTagCompound>();
|
||||||
NBTTagList entities;
|
|
||||||
|
|
||||||
//the wooden door leading into the pocket
|
//the wooden door leading into the pocket
|
||||||
Point3D schematicEntrance = new Point3D(0,0,0);
|
Point3D schematicEntrance = new Point3D(0,0,0);
|
||||||
@@ -727,37 +732,24 @@ public class SchematicLoader
|
|||||||
System.out.println(new File(fname).exists());
|
System.out.println(new File(fname).exists());
|
||||||
input = new FileInputStream(fname);
|
input = new FileInputStream(fname);
|
||||||
}
|
}
|
||||||
NBTTagCompound nbtdata = CompressedStreamTools.readCompressed(input);
|
|
||||||
|
NBTTagCompound schematicTag = CompressedStreamTools.readCompressed(input);
|
||||||
|
input.close(); //readCompressed() probably closes the stream anyway, but close again to be sure.
|
||||||
|
|
||||||
//load size of schematic to generate
|
//load size of schematic to generate
|
||||||
width = nbtdata.getShort("Width");
|
width = schematicTag.getShort("Width");
|
||||||
height = nbtdata.getShort("Height");
|
height = schematicTag.getShort("Height");
|
||||||
length = nbtdata.getShort("Length");
|
length = schematicTag.getShort("Length");
|
||||||
|
|
||||||
//load block info
|
//load block info
|
||||||
blockId = nbtdata.getByteArray("Blocks");
|
blockId = schematicTag.getByteArray("Blocks");
|
||||||
blockData = nbtdata.getByteArray("Data");
|
blockData = schematicTag.getByteArray("Data");
|
||||||
addId = nbtdata.getByteArray("AddBlocks");
|
addId = schematicTag.getByteArray("AddBlocks");
|
||||||
|
|
||||||
//create combined block list
|
//create combined block list
|
||||||
blocks = new short[blockId.length];
|
blocks = new short[blockId.length];
|
||||||
|
|
||||||
//load ticking things
|
//Combine the split block IDs into a single short[]
|
||||||
tileEntities = nbtdata.getTagList("TileEntities");
|
|
||||||
//tileEntityList = new NBTTagCompound[width*height*length];
|
|
||||||
/**
|
|
||||||
for(int count = 0; count<tileEntities.tagCount(); count++)
|
|
||||||
{
|
|
||||||
NBTTagCompound tag = (NBTTagCompound)tileEntities.tagAt(count);
|
|
||||||
tileEntityList[tag.getInteger("y")*width*length+tag.getInteger("z")*width+tag.getInteger("x")]=tag;
|
|
||||||
}
|
|
||||||
|
|
||||||
entities = nbtdata.getTagList("Entities");
|
|
||||||
tileentities = nbtdata.getTagList("TileEntities");
|
|
||||||
**/
|
|
||||||
input.close();
|
|
||||||
|
|
||||||
//combine the split block IDs into a single short[]
|
|
||||||
for (int index = 0; index < blockId.length; index++)
|
for (int index = 0; index < blockId.length; index++)
|
||||||
{
|
{
|
||||||
if ((index >> 1) >= addId.length)
|
if ((index >> 1) >= addId.length)
|
||||||
@@ -776,6 +768,21 @@ public class SchematicLoader
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Get the list of tile entities
|
||||||
|
tileEntities = schematicTag.getTagList("TileEntities");
|
||||||
|
|
||||||
|
//Map tile entity positions to the tile entity itself using a hash map
|
||||||
|
int count = tileEntities.tagCount();
|
||||||
|
for (int index = 0; index < count; index++)
|
||||||
|
{
|
||||||
|
NBTTagCompound tileEntityData = (NBTTagCompound) tileEntities.tagAt(index);
|
||||||
|
Point3D location = new Point3D(
|
||||||
|
tileEntityData.getInteger("x"),
|
||||||
|
tileEntityData.getInteger("y"),
|
||||||
|
tileEntityData.getInteger("z"));
|
||||||
|
pointToTileEntityMap.put(location, tileEntityData);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
@@ -801,6 +808,7 @@ public class SchematicLoader
|
|||||||
|
|
||||||
//Coordinates relative to the schematic, start at 0 and increase up to max width/height/length
|
//Coordinates relative to the schematic, start at 0 and increase up to max width/height/length
|
||||||
int x, y, z;
|
int x, y, z;
|
||||||
|
Point3D schematicPoint = new Point3D(0, 0, 0);
|
||||||
|
|
||||||
//The real point where a block will be placed
|
//The real point where a block will be placed
|
||||||
int realX, realY, realZ;
|
int realX, realY, realZ;
|
||||||
@@ -816,11 +824,11 @@ public class SchematicLoader
|
|||||||
|
|
||||||
//First loop through the schematic to load in all rift locations and Monolith spawn locations.
|
//First loop through the schematic to load in all rift locations and Monolith spawn locations.
|
||||||
//Also find the entry door, which determines the final position and orientation of the dungeon.
|
//Also find the entry door, which determines the final position and orientation of the dungeon.
|
||||||
for ( x = 0; x < width; ++x)
|
for (y = 0; y < height; y++)
|
||||||
{
|
{
|
||||||
for ( y = 0; y < height; ++y)
|
for (z = 0; z < length; z++)
|
||||||
{
|
{
|
||||||
for ( z = 0; z < length; ++z)
|
for (x = 0; x < width; x++)
|
||||||
{
|
{
|
||||||
int index = y * width * length + z * width + x;
|
int index = y * width * length + z * width + x;
|
||||||
int indexBelow = (y - 1) * width * length + z * width + x;
|
int indexBelow = (y - 1) * width * length + z * width + x;
|
||||||
@@ -857,12 +865,16 @@ public class SchematicLoader
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Loop to actually place the blocks
|
//Loop to actually place the blocks
|
||||||
for (x = 0; x < width; x++)
|
|
||||||
{
|
|
||||||
for (z = 0; z < length; z++)
|
|
||||||
{
|
|
||||||
for (y = 0; y < height; y++)
|
for (y = 0; y < height; y++)
|
||||||
{
|
{
|
||||||
|
schematicPoint.setY(y);
|
||||||
|
for (z = 0; z < length; z++)
|
||||||
|
{
|
||||||
|
schematicPoint.setZ(z);
|
||||||
|
for (x = 0; x < width; x++)
|
||||||
|
{
|
||||||
|
schematicPoint.setX(x);
|
||||||
|
|
||||||
//Reinitialize pocketPoint with the current schematic coordinate system
|
//Reinitialize pocketPoint with the current schematic coordinate system
|
||||||
pocketPoint.setX(x);
|
pocketPoint.setX(x);
|
||||||
pocketPoint.setY(y);
|
pocketPoint.setY(y);
|
||||||
@@ -877,17 +889,28 @@ public class SchematicLoader
|
|||||||
int index = y * width * length + z * width + x;
|
int index = y * width * length + z * width + x;
|
||||||
int currentBlock = blocks[index];
|
int currentBlock = blocks[index];
|
||||||
int blockMetadata = blockData[index];
|
int blockMetadata = blockData[index];
|
||||||
NBTTagList tileEntity = tileEntities;
|
blockChanged = false;
|
||||||
|
|
||||||
//replace tagging blocks with air, and mod blocks with FoR
|
//replace tagging blocks with air, and mod blocks with FoR
|
||||||
if (currentBlock == Block.endPortalFrame.blockID)
|
if (currentBlock == Block.endPortalFrame.blockID)
|
||||||
{
|
{
|
||||||
currentBlock = 0;
|
currentBlock = 0;
|
||||||
|
blockChanged = true;
|
||||||
}
|
}
|
||||||
else if ((Block.blocksList[currentBlock] == null && currentBlock != 0) ||
|
else if (currentBlock == DungeonHelper.FABRIC_OF_REALITY_EXPORT_ID)
|
||||||
(currentBlock > 158 && currentBlock != mod_pocketDim.blockDimWallPerm.blockID)) //TODO- replace 158 with max vanilla block ID
|
|
||||||
{
|
{
|
||||||
currentBlock = mod_pocketDim.blockDimWall.blockID;
|
currentBlock = mod_pocketDim.blockDimWall.blockID;
|
||||||
|
blockChanged = true;
|
||||||
|
}
|
||||||
|
else if (currentBlock == DungeonHelper.PERMAFABRIC_EXPORT_ID)
|
||||||
|
{
|
||||||
|
currentBlock = mod_pocketDim.blockDimWallPerm.blockID;
|
||||||
|
blockChanged = true;
|
||||||
|
}
|
||||||
|
else if ((Block.blocksList[currentBlock] == null && currentBlock != 0) || currentBlock > MAX_VANILLA_BLOCK_ID)
|
||||||
|
{
|
||||||
|
currentBlock = mod_pocketDim.blockDimWall.blockID;
|
||||||
|
blockChanged = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Place blocks and set metadata
|
//Place blocks and set metadata
|
||||||
@@ -901,40 +924,56 @@ public class SchematicLoader
|
|||||||
if (currentBlock == Block.doorIron.blockID)
|
if (currentBlock == Block.doorIron.blockID)
|
||||||
{
|
{
|
||||||
setBlockDirectly(world, realX, realY, realZ, properties.DimensionalDoorID, fixedMetadata);
|
setBlockDirectly(world, realX, realY, realZ, properties.DimensionalDoorID, fixedMetadata);
|
||||||
|
blockChanged = true;
|
||||||
}
|
}
|
||||||
else if (currentBlock == Block.doorWood.blockID)
|
else if (currentBlock == Block.doorWood.blockID)
|
||||||
{
|
{
|
||||||
setBlockDirectly(world, realX, realY, realZ, properties.WarpDoorID, fixedMetadata);
|
setBlockDirectly(world, realX, realY, realZ, properties.WarpDoorID, fixedMetadata);
|
||||||
|
blockChanged = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
setBlockDirectly(world, realX, realY, realZ, currentBlock, fixedMetadata);
|
setBlockDirectly(world, realX, realY, realZ, currentBlock, fixedMetadata);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Fill containers (e.g. chests, dispensers)
|
//Load the tile entity at this location if any exists, but only if the block wasn't changed
|
||||||
|
if (!blockChanged)
|
||||||
|
{
|
||||||
|
NBTTagCompound tileEntityData = pointToTileEntityMap.get(schematicPoint);
|
||||||
|
|
||||||
|
if (tileEntityData != null)
|
||||||
|
{
|
||||||
|
//Change the tile entity's position
|
||||||
|
tileEntityData.setInteger("x", realX);
|
||||||
|
tileEntityData.setInteger("y", realY);
|
||||||
|
tileEntityData.setInteger("z", realZ);
|
||||||
|
//Load the tile entity into the world
|
||||||
|
world.setBlockTileEntity(realX, realY, realZ, TileEntity.createAndLoadEntity(tileEntityData));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//Fill empty chests and dispensers
|
||||||
if (Block.blocksList[currentBlock] instanceof BlockContainer)
|
if (Block.blocksList[currentBlock] instanceof BlockContainer)
|
||||||
{
|
{
|
||||||
/**
|
TileEntity tileEntity = world.getBlockTileEntity(realX, realY, realZ);
|
||||||
TileEntity tile = world.getBlockTileEntity(i+xCooe, j+yCooe, k+zCooe);
|
|
||||||
NBTTagCompound tag = this.tileEntityList[index];
|
|
||||||
if(tag!=null)
|
|
||||||
{
|
|
||||||
tile.readFromNBT(tag);
|
|
||||||
}
|
|
||||||
**/
|
|
||||||
|
|
||||||
//Fill chests
|
//Fill chests
|
||||||
if (world.getBlockTileEntity(realX, realY, realZ) instanceof TileEntityChest)
|
if (tileEntity instanceof TileEntityChest)
|
||||||
|
{
|
||||||
|
TileEntityChest chest = (TileEntityChest) tileEntity;
|
||||||
|
if (isInventoryEmpty(chest))
|
||||||
{
|
{
|
||||||
TileEntityChest chest = (TileEntityChest) world.getBlockTileEntity(realX, realY, realZ);
|
|
||||||
ChestGenHooks info = DDLoot.DungeonChestInfo;
|
ChestGenHooks info = DDLoot.DungeonChestInfo;
|
||||||
WeightedRandomChestContent.generateChestContents(rand, info.getItems(rand), chest, info.getCount(rand));
|
WeightedRandomChestContent.generateChestContents(rand, info.getItems(rand), chest, info.getCount(rand));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//Fill dispensers
|
//Fill dispensers
|
||||||
if (world.getBlockTileEntity(realX, realY, realZ) instanceof TileEntityDispenser)
|
if (tileEntity instanceof TileEntityDispenser)
|
||||||
|
{
|
||||||
|
TileEntityDispenser dispenser = (TileEntityDispenser) tileEntity;
|
||||||
|
if (isInventoryEmpty(dispenser))
|
||||||
{
|
{
|
||||||
TileEntityDispenser dispenser = (TileEntityDispenser) world.getBlockTileEntity(realX, realY, realZ);
|
|
||||||
dispenser.addItem(new ItemStack(Item.arrow, 64));
|
dispenser.addItem(new ItemStack(Item.arrow, 64));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -942,6 +981,7 @@ public class SchematicLoader
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//We'll use an extra block here to restrict the scope of these variables to just inside the block
|
//We'll use an extra block here to restrict the scope of these variables to just inside the block
|
||||||
//This is to avoid declaration conflicts with the loops below
|
//This is to avoid declaration conflicts with the loops below
|
||||||
@@ -958,7 +998,6 @@ public class SchematicLoader
|
|||||||
entranceRiftLocation.getX(),
|
entranceRiftLocation.getX(),
|
||||||
entranceRiftLocation.getY() - 1,
|
entranceRiftLocation.getY() - 1,
|
||||||
entranceRiftLocation.getZ());
|
entranceRiftLocation.getZ());
|
||||||
System.out.println("Metadata Orientation: " + sideLink.linkOrientation);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Generate the LinkData defined by the door placement, Iron Dim doors first
|
//Generate the LinkData defined by the door placement, Iron Dim doors first
|
||||||
@@ -1076,7 +1115,20 @@ public class SchematicLoader
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void transformPoint(Point3D position, Point3D srcOrigin, int angle, Point3D destOrigin)
|
private static boolean isInventoryEmpty(IInventory inventory)
|
||||||
|
{
|
||||||
|
int size = inventory.getSizeInventory();
|
||||||
|
for (int index = 0; index < size; index++)
|
||||||
|
{
|
||||||
|
if (inventory.getStackInSlot(index) != null)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void transformPoint(Point3D position, Point3D srcOrigin, int angle, Point3D destOrigin)
|
||||||
{
|
{
|
||||||
//This function receives a position (e.g. point in schematic space), translates it relative
|
//This function receives a position (e.g. point in schematic space), translates it relative
|
||||||
//to a source coordinate system (e.g. the point that will be the center of a schematic),
|
//to a source coordinate system (e.g. the point that will be the center of a schematic),
|
||||||
|
|||||||
@@ -78,7 +78,7 @@ public class CommandEndDungeonCreation extends DDCommandBase
|
|||||||
|
|
||||||
//The user must have used the 3-argument version of this command
|
//The user must have used the 3-argument version of this command
|
||||||
//Check if the current dimension is a pocket for building custom dungeons or if the override argument was used.
|
//Check if the current dimension is a pocket for building custom dungeons or if the override argument was used.
|
||||||
if (!dungeonHelper.isCustomDungeon(sender.worldObj.provider.dimensionId) ||
|
if (!dungeonHelper.isCustomDungeon(sender.worldObj.provider.dimensionId) &&
|
||||||
!command[command.length - 1].equalsIgnoreCase("override"))
|
!command[command.length - 1].equalsIgnoreCase("override"))
|
||||||
{
|
{
|
||||||
//This dimension may not be exported without overriding!
|
//This dimension may not be exported without overriding!
|
||||||
|
|||||||
@@ -11,7 +11,10 @@ import java.util.Random;
|
|||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.block.BlockContainer;
|
import net.minecraft.nbt.CompressedStreamTools;
|
||||||
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
|
import net.minecraft.nbt.NBTTagList;
|
||||||
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.WeightedRandom;
|
import net.minecraft.util.WeightedRandom;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import StevenDimDoors.mod_pocketDim.DDProperties;
|
import StevenDimDoors.mod_pocketDim.DDProperties;
|
||||||
@@ -19,12 +22,6 @@ import StevenDimDoors.mod_pocketDim.DimData;
|
|||||||
import StevenDimDoors.mod_pocketDim.DungeonGenerator;
|
import StevenDimDoors.mod_pocketDim.DungeonGenerator;
|
||||||
import StevenDimDoors.mod_pocketDim.LinkData;
|
import StevenDimDoors.mod_pocketDim.LinkData;
|
||||||
import StevenDimDoors.mod_pocketDim.mod_pocketDim;
|
import StevenDimDoors.mod_pocketDim.mod_pocketDim;
|
||||||
import StevenDimDoors.mod_pocketDim.helpers.jnbt.ByteArrayTag;
|
|
||||||
import StevenDimDoors.mod_pocketDim.helpers.jnbt.CompoundTag;
|
|
||||||
import StevenDimDoors.mod_pocketDim.helpers.jnbt.ListTag;
|
|
||||||
import StevenDimDoors.mod_pocketDim.helpers.jnbt.NBTOutputStream;
|
|
||||||
import StevenDimDoors.mod_pocketDim.helpers.jnbt.ShortTag;
|
|
||||||
import StevenDimDoors.mod_pocketDim.helpers.jnbt.Tag;
|
|
||||||
import StevenDimDoors.mod_pocketDim.items.itemDimDoor;
|
import StevenDimDoors.mod_pocketDim.items.itemDimDoor;
|
||||||
import StevenDimDoors.mod_pocketDim.util.WeightedContainer;
|
import StevenDimDoors.mod_pocketDim.util.WeightedContainer;
|
||||||
|
|
||||||
@@ -38,6 +35,10 @@ public class DungeonHelper
|
|||||||
public static final String SCHEMATIC_FILE_EXTENSION = ".schematic";
|
public static final String SCHEMATIC_FILE_EXTENSION = ".schematic";
|
||||||
private static final int DEFAULT_DUNGEON_WEIGHT = 100;
|
private static final int DEFAULT_DUNGEON_WEIGHT = 100;
|
||||||
public static final int MAX_DUNGEON_WEIGHT = 10000; //Used to prevent overflows and math breaking down
|
public static final int MAX_DUNGEON_WEIGHT = 10000; //Used to prevent overflows and math breaking down
|
||||||
|
private static final int MAX_EXPORT_RADIUS = 50;
|
||||||
|
|
||||||
|
public static final int FABRIC_OF_REALITY_EXPORT_ID = 1973;
|
||||||
|
public static final int PERMAFABRIC_EXPORT_ID = 220;
|
||||||
|
|
||||||
private static final String HUB_DUNGEON_TYPE = "Hub";
|
private static final String HUB_DUNGEON_TYPE = "Hub";
|
||||||
private static final String TRAP_DUNGEON_TYPE = "Trap";
|
private static final String TRAP_DUNGEON_TYPE = "Trap";
|
||||||
@@ -375,83 +376,96 @@ public class DungeonHelper
|
|||||||
registeredDungeons.addAll(hubs);
|
registeredDungeons.addAll(hubs);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean exportDungeon(World world, int xI, int yI, int zI, String exportPath)
|
public boolean exportDungeon(World world, int centerX, int centerY, int centerZ, String exportPath)
|
||||||
{
|
{
|
||||||
int xMin;
|
int xMin, yMin, zMin;
|
||||||
int yMin;
|
int xMax, yMax, zMax;
|
||||||
int zMin;
|
int xStart, yStart, zStart;
|
||||||
|
int xEnd, yEnd, zEnd;
|
||||||
|
|
||||||
int xMax;
|
//Find the smallest bounding box that contains all non-air blocks within a max radius around the player.
|
||||||
int yMax;
|
xMax = yMax = zMax = Integer.MIN_VALUE;
|
||||||
int zMax;
|
xMin = yMin = zMin = Integer.MAX_VALUE;
|
||||||
|
|
||||||
xMin=xMax=xI;
|
xStart = centerX - MAX_EXPORT_RADIUS;
|
||||||
yMin=yMax=yI;
|
zStart = centerZ - MAX_EXPORT_RADIUS;
|
||||||
zMin=zMax=zI;
|
yStart = Math.max(centerY - MAX_EXPORT_RADIUS, 0);
|
||||||
|
|
||||||
for (int count = 0; count < 50; count++)
|
xEnd = centerX + MAX_EXPORT_RADIUS;
|
||||||
|
zEnd = centerZ + MAX_EXPORT_RADIUS;
|
||||||
|
yEnd = Math.min(centerY + MAX_EXPORT_RADIUS, world.getActualHeight());
|
||||||
|
|
||||||
|
//This could be done more efficiently, but honestly, this is the simplest approach and it
|
||||||
|
//makes it easy for us to verify that the code is correct.
|
||||||
|
for (int y = yStart; y <= yEnd; y++)
|
||||||
{
|
{
|
||||||
if(world.getBlockId(xMin, yI, zI)!=properties.PermaFabricBlockID)
|
for (int z = zStart; z <= zEnd; z++)
|
||||||
{
|
{
|
||||||
xMin--;
|
for (int x = xStart; x <= xEnd; x++)
|
||||||
|
{
|
||||||
|
if (!world.isAirBlock(x, y, z))
|
||||||
|
{
|
||||||
|
xMax = x > xMax ? x : xMax;
|
||||||
|
zMax = z > zMax ? z : zMax;
|
||||||
|
yMax = y > yMax ? y : yMax;
|
||||||
|
|
||||||
|
xMin = x < xMin ? x : xMin;
|
||||||
|
zMin = z < zMin ? z : zMin;
|
||||||
|
yMin = y < yMin ? y : yMin;
|
||||||
}
|
}
|
||||||
if(world.getBlockId(xI, yMin, zI)!=properties.PermaFabricBlockID)
|
|
||||||
{
|
|
||||||
yMin--;
|
|
||||||
}
|
}
|
||||||
if(world.getBlockId(xI, yI, zMin)!=properties.PermaFabricBlockID)
|
|
||||||
{
|
|
||||||
zMin--;
|
|
||||||
}
|
|
||||||
if(world.getBlockId(xMax, yI, zI)!=properties.PermaFabricBlockID)
|
|
||||||
{
|
|
||||||
xMax++;
|
|
||||||
}
|
|
||||||
if(world.getBlockId(xI, yMax, zI)!=properties.PermaFabricBlockID)
|
|
||||||
{
|
|
||||||
yMax++;
|
|
||||||
}
|
|
||||||
if(world.getBlockId(xI, yI, zMax)!=properties.PermaFabricBlockID)
|
|
||||||
{
|
|
||||||
zMax++;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
short width =(short) (xMax-xMin);
|
//Export all the blocks within our selected bounding box
|
||||||
short height= (short) (yMax-yMin);
|
short width = (short) (xMax - xMin + 1);
|
||||||
short length= (short) (zMax-zMin);
|
short height = (short) (yMax - yMin + 1);
|
||||||
|
short length = (short) (zMax - zMin + 1);
|
||||||
|
|
||||||
//ArrayList<NBTTagCompound> tileEntities = new ArrayList<NBTTagCompound>();
|
|
||||||
ArrayList<Tag> tileEntites = new ArrayList<Tag>();
|
|
||||||
byte[] blocks = new byte[width * height * length];
|
byte[] blocks = new byte[width * height * length];
|
||||||
byte[] addBlocks = null;
|
byte[] addBlocks = null;
|
||||||
byte[] blockData = new byte[width * height * length];
|
byte[] blockData = new byte[width * height * length];
|
||||||
|
NBTTagList tileEntities = new NBTTagList();
|
||||||
|
|
||||||
for (int x = 0; x < width; ++x)
|
for (int y = 0; y < height; y++)
|
||||||
{
|
{
|
||||||
for (int y = 0; y < height; ++y)
|
for (int z = 0; z < length; z++)
|
||||||
{
|
{
|
||||||
for (int z = 0; z < length; ++z)
|
for (int x = 0; x < width; x++)
|
||||||
{
|
{
|
||||||
int index = y * width * length + z * width + x;
|
int index = y * width * length + z * width + x;
|
||||||
int blockID = world.getBlockId(x + xMin, y + yMin, z + zMin);
|
int blockID = world.getBlockId(x + xMin, y + yMin, z + zMin);
|
||||||
int meta= world.getBlockMetadata(x+xMin, y+yMin, z+zMin);
|
int metadata = world.getBlockMetadata(x + xMin, y + yMin, z + zMin);
|
||||||
|
boolean changed = false;
|
||||||
|
|
||||||
if (blockID == properties.DimensionalDoorID)
|
if (blockID == properties.DimensionalDoorID)
|
||||||
{
|
{
|
||||||
blockID = Block.doorIron.blockID;
|
blockID = Block.doorIron.blockID;
|
||||||
|
changed = true;
|
||||||
}
|
}
|
||||||
if (blockID == properties.WarpDoorID)
|
if (blockID == properties.WarpDoorID)
|
||||||
{
|
{
|
||||||
blockID = Block.doorWood.blockID;
|
blockID = Block.doorWood.blockID;
|
||||||
|
changed = true;
|
||||||
|
}
|
||||||
|
//Map fabric of reality and permafabric blocks to standard export IDs
|
||||||
|
if (blockID == properties.FabricBlockID)
|
||||||
|
{
|
||||||
|
blockID = FABRIC_OF_REALITY_EXPORT_ID;
|
||||||
|
changed = true;
|
||||||
|
}
|
||||||
|
if (blockID == properties.PermaFabricBlockID)
|
||||||
|
{
|
||||||
|
blockID = PERMAFABRIC_EXPORT_ID;
|
||||||
|
changed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Save 4096 IDs in an AddBlocks section
|
// Save 4096 IDs in an AddBlocks section
|
||||||
if (blockID > 255)
|
if (blockID > 255)
|
||||||
{
|
{
|
||||||
if (addBlocks == null)
|
if (addBlocks == null)
|
||||||
{ // Lazily create section
|
{
|
||||||
|
//Lazily create section
|
||||||
addBlocks = new byte[(blocks.length >> 1) + 1];
|
addBlocks = new byte[(blocks.length >> 1) + 1];
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -461,62 +475,56 @@ public class DungeonHelper
|
|||||||
}
|
}
|
||||||
|
|
||||||
blocks[index] = (byte) blockID;
|
blocks[index] = (byte) blockID;
|
||||||
blockData[index] = (byte) meta;
|
blockData[index] = (byte) metadata;
|
||||||
|
|
||||||
if (Block.blocksList[blockID] instanceof BlockContainer)
|
//Obtain and export the tile entity of the current block, if any.
|
||||||
|
//Do not obtain a tile entity if the block was changed from its original ID.
|
||||||
|
//I'm not sure if this approach is the most efficient but it works. ~SenseiKiwi
|
||||||
|
TileEntity tileEntity = !changed ? world.getBlockTileEntity(x + xMin, y + yMin, z + zMin) : null;
|
||||||
|
|
||||||
|
if (tileEntity != null)
|
||||||
{
|
{
|
||||||
//TODO fix this
|
//Get the tile entity's description as a compound NBT tag
|
||||||
/**
|
NBTTagCompound entityData = new NBTTagCompound();
|
||||||
TileEntity tileEntityBlock = world.getBlockTileEntity(x+xMin, y+yMin, z+zMin);
|
tileEntity.writeToNBT(entityData);
|
||||||
NBTTagCompound tag = new NBTTagCompound();
|
//Change the tile entity's location to the schematic coordinate system
|
||||||
tileEntityBlock.writeToNBT(tag);
|
entityData.setInteger("x", x);
|
||||||
|
entityData.setInteger("y", y);
|
||||||
|
entityData.setInteger("z", z);
|
||||||
|
|
||||||
CompoundTag tagC = new CompoundTag("TileEntity",Map.class.cast(tag.getTags()));
|
tileEntities.appendTag(entityData);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Get the list of key/values from the block
|
|
||||||
|
|
||||||
if (tagC != null)
|
|
||||||
{
|
|
||||||
tileEntites.add(tagC);
|
|
||||||
}
|
|
||||||
**/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
*
|
|
||||||
* nbtdata.setShort("Width", width);
|
|
||||||
nbtdata.setShort("Height", height);
|
|
||||||
nbtdata.setShort("Length", length);
|
|
||||||
|
|
||||||
nbtdata.setByteArray("Blocks", blocks);
|
//Write NBT tags for schematic file
|
||||||
nbtdata.setByteArray("Data", blockData);
|
NBTTagCompound schematicTag = new NBTTagCompound("Schematic");
|
||||||
*/
|
|
||||||
|
|
||||||
HashMap<String, Tag> schematic = new HashMap<String, Tag>();
|
schematicTag.setShort("Width", width);
|
||||||
|
schematicTag.setShort("Length", length);
|
||||||
|
schematicTag.setShort("Height", height);
|
||||||
|
|
||||||
schematic.put("Blocks", new ByteArrayTag("Blocks", blocks));
|
schematicTag.setByteArray("Blocks", blocks);
|
||||||
schematic.put("Data", new ByteArrayTag("Data", blockData));
|
schematicTag.setByteArray("Data", blockData);
|
||||||
|
|
||||||
schematic.put("Width", new ShortTag("Width", (short) width));
|
schematicTag.setTag("Entities", new NBTTagList());
|
||||||
schematic.put("Length", new ShortTag("Length", (short) length));
|
schematicTag.setTag("TileEntities", tileEntities);
|
||||||
schematic.put("Height", new ShortTag("Height", (short) height));
|
schematicTag.setString("Materials", "Alpha");
|
||||||
schematic.put("TileEntites", new ListTag("TileEntities", CompoundTag.class,tileEntites));
|
|
||||||
|
|
||||||
if (addBlocks != null)
|
if (addBlocks != null)
|
||||||
{
|
{
|
||||||
schematic.put("AddBlocks", new ByteArrayTag("AddBlocks", addBlocks));
|
schematicTag.setByteArray("AddBlocks", addBlocks);
|
||||||
}
|
}
|
||||||
|
|
||||||
CompoundTag schematicTag = new CompoundTag("Schematic", schematic);
|
//Write schematic data to a file
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
NBTOutputStream stream = new NBTOutputStream(new FileOutputStream(exportPath));
|
FileOutputStream outputStream = new FileOutputStream(new File(exportPath));
|
||||||
stream.writeTag(schematicTag);
|
CompressedStreamTools.writeCompressed(schematicTag, outputStream);
|
||||||
stream.close();
|
//writeCompressed() probably closes the stream on its own - call close again just in case.
|
||||||
|
//Closing twice will not throw an exception.
|
||||||
|
outputStream.close();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
catch(Exception e)
|
catch(Exception e)
|
||||||
|
|||||||
@@ -1,86 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_Byte_Array</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class ByteArrayTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final byte[] value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public ByteArrayTag(String name, byte[] value) {
|
|
||||||
super(name);
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public byte[] getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
StringBuilder hex = new StringBuilder();
|
|
||||||
for (byte b : value) {
|
|
||||||
String hexDigits = Integer.toHexString(b).toUpperCase();
|
|
||||||
if (hexDigits.length() == 1) {
|
|
||||||
hex.append("0");
|
|
||||||
}
|
|
||||||
hex.append(hexDigits).append(" ");
|
|
||||||
}
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
return "TAG_Byte_Array" + append + ": " + hex.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_Byte</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class ByteTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final byte value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public ByteTag(String name, byte value) {
|
|
||||||
super(name);
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Byte getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
return "TAG_Byte" + append + ": " + value;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,89 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_Compound</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class CompoundTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final Map<String, Tag> value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public CompoundTag(String name, Map<String, Tag> value) {
|
|
||||||
super(name);
|
|
||||||
this.value = Collections.unmodifiableMap(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Map<String, Tag> getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
StringBuilder bldr = new StringBuilder();
|
|
||||||
bldr.append("TAG_Compound" + append + ": " + value.size()
|
|
||||||
+ " entries\r\n{\r\n");
|
|
||||||
for (Map.Entry<String, Tag> entry : value.entrySet()) {
|
|
||||||
bldr.append(" "
|
|
||||||
+ entry.getValue().toString().replaceAll("\r\n", "\r\n ")
|
|
||||||
+ "\r\n");
|
|
||||||
}
|
|
||||||
bldr.append("}");
|
|
||||||
return bldr.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_Double</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class DoubleTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final double value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public DoubleTag(String name, double value) {
|
|
||||||
super(name);
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Double getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
return "TAG_Double" + append + ": " + value;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,62 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_End</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class EndTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*/
|
|
||||||
public EndTag() {
|
|
||||||
super("");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Object getValue() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "TAG_End";
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_Float</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class FloatTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final float value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public FloatTag(String name, float value) {
|
|
||||||
super(name);
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Float getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
return "TAG_Float" + append + ": " + value;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,86 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_Int_Array</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class IntArrayTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final int[] value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public IntArrayTag(String name, int[] value) {
|
|
||||||
super(name);
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int[] getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
StringBuilder hex = new StringBuilder();
|
|
||||||
for (int b : value) {
|
|
||||||
String hexDigits = Integer.toHexString(b).toUpperCase();
|
|
||||||
if (hexDigits.length() == 1) {
|
|
||||||
hex.append("0");
|
|
||||||
}
|
|
||||||
hex.append(hexDigits).append(" ");
|
|
||||||
}
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
return "TAG_Int_Array" + append + ": " + hex.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_Int</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class IntTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final int value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public IntTag(String name, int value) {
|
|
||||||
super(name);
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Integer getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
return "TAG_Int" + append + ": " + value;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,106 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_List</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class ListTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The type.
|
|
||||||
*/
|
|
||||||
private final Class<? extends Tag> type;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final List<Tag> value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param type
|
|
||||||
* The type of item in the list.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public ListTag(String name, Class<? extends Tag> type, List<? extends Tag> value) {
|
|
||||||
super(name);
|
|
||||||
this.type = type;
|
|
||||||
this.value = Collections.unmodifiableList(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the type of item in this list.
|
|
||||||
*
|
|
||||||
* @return The type of item in this list.
|
|
||||||
*/
|
|
||||||
public Class<? extends Tag> getType() {
|
|
||||||
return type;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<Tag> getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
StringBuilder bldr = new StringBuilder();
|
|
||||||
bldr.append("TAG_List" + append + ": " + value.size()
|
|
||||||
+ " entries of type " + NBTUtils.getTypeName(type)
|
|
||||||
+ "\r\n{\r\n");
|
|
||||||
for (Tag t : value) {
|
|
||||||
bldr.append(" " + t.toString().replaceAll("\r\n", "\r\n ")
|
|
||||||
+ "\r\n");
|
|
||||||
}
|
|
||||||
bldr.append("}");
|
|
||||||
return bldr.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_Long</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class LongTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final long value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public LongTag(String name, long value) {
|
|
||||||
super(name);
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Long getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
return "TAG_Long" + append + ": " + value;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,104 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
import java.nio.charset.Charset;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A class which holds constant values.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class NBTConstants {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The character set used by NBT (UTF-8).
|
|
||||||
*/
|
|
||||||
public static final Charset CHARSET = Charset.forName("UTF-8");
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Tag type constants.
|
|
||||||
*/
|
|
||||||
public static final int TYPE_END = 0, TYPE_BYTE = 1, TYPE_SHORT = 2,
|
|
||||||
TYPE_INT = 3, TYPE_LONG = 4, TYPE_FLOAT = 5, TYPE_DOUBLE = 6,
|
|
||||||
TYPE_BYTE_ARRAY = 7, TYPE_STRING = 8, TYPE_LIST = 9,
|
|
||||||
TYPE_COMPOUND = 10, TYPE_INT_ARRAY = 11;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default private constructor.
|
|
||||||
*/
|
|
||||||
private NBTConstants() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Convert a type ID to its corresponding {@link Tag} class.
|
|
||||||
*
|
|
||||||
* @param id type ID
|
|
||||||
* @return tag class
|
|
||||||
* @throws IllegalArgumentException thrown if the tag ID is not valid
|
|
||||||
*/
|
|
||||||
public static Class<? extends Tag> getClassFromType(int id) {
|
|
||||||
switch (id) {
|
|
||||||
case TYPE_END:
|
|
||||||
return EndTag.class;
|
|
||||||
case TYPE_BYTE:
|
|
||||||
return ByteTag.class;
|
|
||||||
case TYPE_SHORT:
|
|
||||||
return ShortTag.class;
|
|
||||||
case TYPE_INT:
|
|
||||||
return IntTag.class;
|
|
||||||
case TYPE_LONG:
|
|
||||||
return LongTag.class;
|
|
||||||
case TYPE_FLOAT:
|
|
||||||
return FloatTag.class;
|
|
||||||
case TYPE_DOUBLE:
|
|
||||||
return DoubleTag.class;
|
|
||||||
case TYPE_BYTE_ARRAY:
|
|
||||||
return ByteArrayTag.class;
|
|
||||||
case TYPE_STRING:
|
|
||||||
return StringTag.class;
|
|
||||||
case TYPE_LIST:
|
|
||||||
return ListTag.class;
|
|
||||||
case TYPE_COMPOUND:
|
|
||||||
return CompoundTag.class;
|
|
||||||
case TYPE_INT_ARRAY:
|
|
||||||
return IntArrayTag.class;
|
|
||||||
default:
|
|
||||||
throw new IllegalArgumentException("Unknown tag type ID of " + id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,204 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import java.io.Closeable;
|
|
||||||
import java.io.DataInputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <p>
|
|
||||||
* This class reads <strong>NBT</strong>, or <strong>Named Binary Tag</strong>
|
|
||||||
* streams, and produces an object graph of subclasses of the <code>Tag</code>
|
|
||||||
* object.
|
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* <p>
|
|
||||||
* The NBT format was created by Markus Persson, and the specification may be
|
|
||||||
* found at <a href="http://www.minecraft.net/docs/NBT.txt">
|
|
||||||
* http://www.minecraft.net/docs/NBT.txt</a>.
|
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class NBTInputStream implements Closeable {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The data input stream.
|
|
||||||
*/
|
|
||||||
private final DataInputStream is;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates a new <code>NBTInputStream</code>, which will source its data
|
|
||||||
* from the specified input stream.
|
|
||||||
*
|
|
||||||
* @param is
|
|
||||||
* The input stream.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
public NBTInputStream(InputStream is) throws IOException {
|
|
||||||
this.is = new DataInputStream(is);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Reads an NBT tag from the stream.
|
|
||||||
*
|
|
||||||
* @return The tag that was read.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
public Tag readTag() throws IOException {
|
|
||||||
return readTag(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Reads an NBT from the stream.
|
|
||||||
*
|
|
||||||
* @param depth
|
|
||||||
* The depth of this tag.
|
|
||||||
* @return The tag that was read.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private Tag readTag(int depth) throws IOException {
|
|
||||||
int type = is.readByte() & 0xFF;
|
|
||||||
|
|
||||||
String name;
|
|
||||||
if (type != NBTConstants.TYPE_END) {
|
|
||||||
int nameLength = is.readShort() & 0xFFFF;
|
|
||||||
byte[] nameBytes = new byte[nameLength];
|
|
||||||
is.readFully(nameBytes);
|
|
||||||
name = new String(nameBytes, NBTConstants.CHARSET);
|
|
||||||
} else {
|
|
||||||
name = "";
|
|
||||||
}
|
|
||||||
|
|
||||||
return readTagPayload(type, name, depth);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Reads the payload of a tag, given the name and type.
|
|
||||||
*
|
|
||||||
* @param type
|
|
||||||
* The type.
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param depth
|
|
||||||
* The depth.
|
|
||||||
* @return The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private Tag readTagPayload(int type, String name, int depth)
|
|
||||||
throws IOException {
|
|
||||||
switch (type) {
|
|
||||||
case NBTConstants.TYPE_END:
|
|
||||||
if (depth == 0) {
|
|
||||||
throw new IOException(
|
|
||||||
"TAG_End found without a TAG_Compound/TAG_List tag preceding it.");
|
|
||||||
} else {
|
|
||||||
return new EndTag();
|
|
||||||
}
|
|
||||||
case NBTConstants.TYPE_BYTE:
|
|
||||||
return new ByteTag(name, is.readByte());
|
|
||||||
case NBTConstants.TYPE_SHORT:
|
|
||||||
return new ShortTag(name, is.readShort());
|
|
||||||
case NBTConstants.TYPE_INT:
|
|
||||||
return new IntTag(name, is.readInt());
|
|
||||||
case NBTConstants.TYPE_LONG:
|
|
||||||
return new LongTag(name, is.readLong());
|
|
||||||
case NBTConstants.TYPE_FLOAT:
|
|
||||||
return new FloatTag(name, is.readFloat());
|
|
||||||
case NBTConstants.TYPE_DOUBLE:
|
|
||||||
return new DoubleTag(name, is.readDouble());
|
|
||||||
case NBTConstants.TYPE_BYTE_ARRAY:
|
|
||||||
int length = is.readInt();
|
|
||||||
byte[] bytes = new byte[length];
|
|
||||||
is.readFully(bytes);
|
|
||||||
return new ByteArrayTag(name, bytes);
|
|
||||||
case NBTConstants.TYPE_STRING:
|
|
||||||
length = is.readShort();
|
|
||||||
bytes = new byte[length];
|
|
||||||
is.readFully(bytes);
|
|
||||||
return new StringTag(name, new String(bytes, NBTConstants.CHARSET));
|
|
||||||
case NBTConstants.TYPE_LIST:
|
|
||||||
int childType = is.readByte();
|
|
||||||
length = is.readInt();
|
|
||||||
|
|
||||||
List<Tag> tagList = new ArrayList<Tag>();
|
|
||||||
for (int i = 0; i < length; ++i) {
|
|
||||||
Tag tag = readTagPayload(childType, "", depth + 1);
|
|
||||||
if (tag instanceof EndTag) {
|
|
||||||
throw new IOException("TAG_End not permitted in a list.");
|
|
||||||
}
|
|
||||||
tagList.add(tag);
|
|
||||||
}
|
|
||||||
|
|
||||||
return new ListTag(name, NBTUtils.getTypeClass(childType), tagList);
|
|
||||||
case NBTConstants.TYPE_COMPOUND:
|
|
||||||
Map<String, Tag> tagMap = new HashMap<String, Tag>();
|
|
||||||
while (true) {
|
|
||||||
Tag tag = readTag(depth + 1);
|
|
||||||
if (tag instanceof EndTag) {
|
|
||||||
break;
|
|
||||||
} else {
|
|
||||||
tagMap.put(tag.getName(), tag);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return new CompoundTag(name, tagMap);
|
|
||||||
case NBTConstants.TYPE_INT_ARRAY:
|
|
||||||
length = is.readInt();
|
|
||||||
int[] data = new int[length];
|
|
||||||
for (int i = 0; i < length; i++) {
|
|
||||||
data[i] = is.readInt();
|
|
||||||
}
|
|
||||||
return new IntArrayTag(name, data);
|
|
||||||
default:
|
|
||||||
throw new IOException("Invalid tag type: " + type + ".");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void close() throws IOException {
|
|
||||||
is.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,313 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
import java.io.Closeable;
|
|
||||||
import java.io.DataOutputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.OutputStream;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.zip.GZIPOutputStream;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <p>
|
|
||||||
* This class writes <strong>NBT</strong>, or <strong>Named Binary Tag</strong>
|
|
||||||
* <code>Tag</code> objects to an underlying <code>OutputStream</code>.
|
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* <p>
|
|
||||||
* The NBT format was created by Markus Persson, and the specification may be
|
|
||||||
* found at <a href="http://www.minecraft.net/docs/NBT.txt">
|
|
||||||
* http://www.minecraft.net/docs/NBT.txt</a>.
|
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class NBTOutputStream implements Closeable {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The output stream.
|
|
||||||
*/
|
|
||||||
private final DataOutputStream os;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates a new <code>NBTOutputStream</code>, which will write data to the
|
|
||||||
* specified underlying output stream.
|
|
||||||
*
|
|
||||||
* @param os
|
|
||||||
* The output stream.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
public NBTOutputStream(OutputStream os) throws IOException {
|
|
||||||
this.os = new DataOutputStream(new GZIPOutputStream(os));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag to write.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
public void writeTag(Tag tag) throws IOException {
|
|
||||||
int type = NBTUtils.getTypeCode(tag.getClass());
|
|
||||||
String name = tag.getName();
|
|
||||||
byte[] nameBytes = name.getBytes(NBTConstants.CHARSET);
|
|
||||||
|
|
||||||
os.writeByte(type);
|
|
||||||
os.writeShort(nameBytes.length);
|
|
||||||
os.write(nameBytes);
|
|
||||||
|
|
||||||
if (type == NBTConstants.TYPE_END) {
|
|
||||||
throw new IOException("Named TAG_End not permitted.");
|
|
||||||
}
|
|
||||||
|
|
||||||
writeTagPayload(tag);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes tag payload.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeTagPayload(Tag tag) throws IOException {
|
|
||||||
int type = NBTUtils.getTypeCode(tag.getClass());
|
|
||||||
switch (type) {
|
|
||||||
case NBTConstants.TYPE_END:
|
|
||||||
writeEndTagPayload((EndTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_BYTE:
|
|
||||||
writeByteTagPayload((ByteTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_SHORT:
|
|
||||||
writeShortTagPayload((ShortTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_INT:
|
|
||||||
writeIntTagPayload((IntTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_LONG:
|
|
||||||
writeLongTagPayload((LongTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_FLOAT:
|
|
||||||
writeFloatTagPayload((FloatTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_DOUBLE:
|
|
||||||
writeDoubleTagPayload((DoubleTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_BYTE_ARRAY:
|
|
||||||
writeByteArrayTagPayload((ByteArrayTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_STRING:
|
|
||||||
writeStringTagPayload((StringTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_LIST:
|
|
||||||
writeListTagPayload((ListTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_COMPOUND:
|
|
||||||
writeCompoundTagPayload((CompoundTag) tag);
|
|
||||||
break;
|
|
||||||
case NBTConstants.TYPE_INT_ARRAY:
|
|
||||||
writeIntArrayTagPayload((IntArrayTag) tag);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
throw new IOException("Invalid tag type: " + type + ".");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_Byte</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeByteTagPayload(ByteTag tag) throws IOException {
|
|
||||||
os.writeByte(tag.getValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_Byte_Array</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeByteArrayTagPayload(ByteArrayTag tag) throws IOException {
|
|
||||||
byte[] bytes = tag.getValue();
|
|
||||||
os.writeInt(bytes.length);
|
|
||||||
os.write(bytes);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_Compound</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeCompoundTagPayload(CompoundTag tag) throws IOException {
|
|
||||||
for (Tag childTag : tag.getValue().values()) {
|
|
||||||
writeTag(childTag);
|
|
||||||
}
|
|
||||||
os.writeByte((byte) 0); // end tag - better way?
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_List</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeListTagPayload(ListTag tag) throws IOException {
|
|
||||||
Class<? extends Tag> clazz = tag.getType();
|
|
||||||
List<Tag> tags = tag.getValue();
|
|
||||||
int size = tags.size();
|
|
||||||
|
|
||||||
os.writeByte(NBTUtils.getTypeCode(clazz));
|
|
||||||
os.writeInt(size);
|
|
||||||
for (int i = 0; i < size; ++i) {
|
|
||||||
writeTagPayload(tags.get(i));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_String</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeStringTagPayload(StringTag tag) throws IOException {
|
|
||||||
byte[] bytes = tag.getValue().getBytes(NBTConstants.CHARSET);
|
|
||||||
os.writeShort(bytes.length);
|
|
||||||
os.write(bytes);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_Double</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeDoubleTagPayload(DoubleTag tag) throws IOException {
|
|
||||||
os.writeDouble(tag.getValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_Float</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeFloatTagPayload(FloatTag tag) throws IOException {
|
|
||||||
os.writeFloat(tag.getValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_Long</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeLongTagPayload(LongTag tag) throws IOException {
|
|
||||||
os.writeLong(tag.getValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_Int</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeIntTagPayload(IntTag tag) throws IOException {
|
|
||||||
os.writeInt(tag.getValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_Short</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeShortTagPayload(ShortTag tag) throws IOException {
|
|
||||||
os.writeShort(tag.getValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes a <code>TAG_Empty</code> tag.
|
|
||||||
*
|
|
||||||
* @param tag
|
|
||||||
* The tag.
|
|
||||||
* @throws IOException
|
|
||||||
* if an I/O error occurs.
|
|
||||||
*/
|
|
||||||
private void writeEndTagPayload(EndTag tag) {
|
|
||||||
/* empty */
|
|
||||||
}
|
|
||||||
|
|
||||||
private void writeIntArrayTagPayload(IntArrayTag tag) throws IOException {
|
|
||||||
int[] data = tag.getValue();
|
|
||||||
os.writeInt(data.length);
|
|
||||||
for (int i = 0; i < data.length; i++) {
|
|
||||||
os.writeInt(data[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void close() throws IOException {
|
|
||||||
os.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,193 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A class which contains NBT-related utility methods.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class NBTUtils {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the type name of a tag.
|
|
||||||
*
|
|
||||||
* @param clazz
|
|
||||||
* The tag class.
|
|
||||||
* @return The type name.
|
|
||||||
*/
|
|
||||||
public static String getTypeName(Class<? extends Tag> clazz) {
|
|
||||||
if (clazz.equals(ByteArrayTag.class)) {
|
|
||||||
return "TAG_Byte_Array";
|
|
||||||
} else if (clazz.equals(ByteTag.class)) {
|
|
||||||
return "TAG_Byte";
|
|
||||||
} else if (clazz.equals(CompoundTag.class)) {
|
|
||||||
return "TAG_Compound";
|
|
||||||
} else if (clazz.equals(DoubleTag.class)) {
|
|
||||||
return "TAG_Double";
|
|
||||||
} else if (clazz.equals(EndTag.class)) {
|
|
||||||
return "TAG_End";
|
|
||||||
} else if (clazz.equals(FloatTag.class)) {
|
|
||||||
return "TAG_Float";
|
|
||||||
} else if (clazz.equals(IntTag.class)) {
|
|
||||||
return "TAG_Int";
|
|
||||||
} else if (clazz.equals(ListTag.class)) {
|
|
||||||
return "TAG_List";
|
|
||||||
} else if (clazz.equals(LongTag.class)) {
|
|
||||||
return "TAG_Long";
|
|
||||||
} else if (clazz.equals(ShortTag.class)) {
|
|
||||||
return "TAG_Short";
|
|
||||||
} else if (clazz.equals(StringTag.class)) {
|
|
||||||
return "TAG_String";
|
|
||||||
} else if (clazz.equals(IntArrayTag.class)) {
|
|
||||||
return "TAG_Int_Array";
|
|
||||||
} else {
|
|
||||||
throw new IllegalArgumentException("Invalid tag classs ("
|
|
||||||
+ clazz.getName() + ").");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the type code of a tag class.
|
|
||||||
*
|
|
||||||
* @param clazz
|
|
||||||
* The tag class.
|
|
||||||
* @return The type code.
|
|
||||||
* @throws IllegalArgumentException
|
|
||||||
* if the tag class is invalid.
|
|
||||||
*/
|
|
||||||
public static int getTypeCode(Class<? extends Tag> clazz) {
|
|
||||||
if (clazz.equals(ByteArrayTag.class)) {
|
|
||||||
return NBTConstants.TYPE_BYTE_ARRAY;
|
|
||||||
} else if (clazz.equals(ByteTag.class)) {
|
|
||||||
return NBTConstants.TYPE_BYTE;
|
|
||||||
} else if (clazz.equals(CompoundTag.class)) {
|
|
||||||
return NBTConstants.TYPE_COMPOUND;
|
|
||||||
} else if (clazz.equals(DoubleTag.class)) {
|
|
||||||
return NBTConstants.TYPE_DOUBLE;
|
|
||||||
} else if (clazz.equals(EndTag.class)) {
|
|
||||||
return NBTConstants.TYPE_END;
|
|
||||||
} else if (clazz.equals(FloatTag.class)) {
|
|
||||||
return NBTConstants.TYPE_FLOAT;
|
|
||||||
} else if (clazz.equals(IntTag.class)) {
|
|
||||||
return NBTConstants.TYPE_INT;
|
|
||||||
} else if (clazz.equals(ListTag.class)) {
|
|
||||||
return NBTConstants.TYPE_LIST;
|
|
||||||
} else if (clazz.equals(LongTag.class)) {
|
|
||||||
return NBTConstants.TYPE_LONG;
|
|
||||||
} else if (clazz.equals(ShortTag.class)) {
|
|
||||||
return NBTConstants.TYPE_SHORT;
|
|
||||||
} else if (clazz.equals(StringTag.class)) {
|
|
||||||
return NBTConstants.TYPE_STRING;
|
|
||||||
} else if (clazz.equals(IntArrayTag.class)) {
|
|
||||||
return NBTConstants.TYPE_INT_ARRAY;
|
|
||||||
} else {
|
|
||||||
throw new IllegalArgumentException("Invalid tag classs ("
|
|
||||||
+ clazz.getName() + ").");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the class of a type of tag.
|
|
||||||
*
|
|
||||||
* @param type
|
|
||||||
* The type.
|
|
||||||
* @return The class.
|
|
||||||
* @throws IllegalArgumentException
|
|
||||||
* if the tag type is invalid.
|
|
||||||
*/
|
|
||||||
public static Class<? extends Tag> getTypeClass(int type) {
|
|
||||||
switch (type) {
|
|
||||||
case NBTConstants.TYPE_END:
|
|
||||||
return EndTag.class;
|
|
||||||
case NBTConstants.TYPE_BYTE:
|
|
||||||
return ByteTag.class;
|
|
||||||
case NBTConstants.TYPE_SHORT:
|
|
||||||
return ShortTag.class;
|
|
||||||
case NBTConstants.TYPE_INT:
|
|
||||||
return IntTag.class;
|
|
||||||
case NBTConstants.TYPE_LONG:
|
|
||||||
return LongTag.class;
|
|
||||||
case NBTConstants.TYPE_FLOAT:
|
|
||||||
return FloatTag.class;
|
|
||||||
case NBTConstants.TYPE_DOUBLE:
|
|
||||||
return DoubleTag.class;
|
|
||||||
case NBTConstants.TYPE_BYTE_ARRAY:
|
|
||||||
return ByteArrayTag.class;
|
|
||||||
case NBTConstants.TYPE_STRING:
|
|
||||||
return StringTag.class;
|
|
||||||
case NBTConstants.TYPE_LIST:
|
|
||||||
return ListTag.class;
|
|
||||||
case NBTConstants.TYPE_COMPOUND:
|
|
||||||
return CompoundTag.class;
|
|
||||||
case NBTConstants.TYPE_INT_ARRAY:
|
|
||||||
return IntArrayTag.class;
|
|
||||||
default:
|
|
||||||
throw new IllegalArgumentException("Invalid tag type : " + type
|
|
||||||
+ ".");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default private constructor.
|
|
||||||
*/
|
|
||||||
private NBTUtils() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get child tag of a NBT structure.
|
|
||||||
*
|
|
||||||
* @param items
|
|
||||||
* @param key
|
|
||||||
* @param expected
|
|
||||||
* @return child tag
|
|
||||||
* @throws InvalidFormatException
|
|
||||||
*/
|
|
||||||
public static <T extends Tag> T getChildTag(Map<String,Tag> items, String key,
|
|
||||||
Class<T> expected) throws Exception {
|
|
||||||
if (!items.containsKey(key)) {
|
|
||||||
throw new Exception("Missing a \"" + key + "\" tag");
|
|
||||||
}
|
|
||||||
Tag tag = items.get(key);
|
|
||||||
if (!expected.isInstance(tag)) {
|
|
||||||
throw new Exception(key + " tag is not of tag type " + expected.getName());
|
|
||||||
}
|
|
||||||
return expected.cast(tag);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_Short</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class ShortTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final short value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public ShortTag(String name, short value) {
|
|
||||||
super(name);
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Short getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
return "TAG_Short" + append + ": " + value;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The <code>TAG_String</code> tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public final class StringTag extends Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
private final String value;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
* @param value
|
|
||||||
* The value.
|
|
||||||
*/
|
|
||||||
public StringTag(String name, String value) {
|
|
||||||
super(name);
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
String name = getName();
|
|
||||||
String append = "";
|
|
||||||
if (name != null && !name.equals("")) {
|
|
||||||
append = "(\"" + this.getName() + "\")";
|
|
||||||
}
|
|
||||||
return "TAG_String" + append + ": " + value;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,75 +0,0 @@
|
|||||||
package StevenDimDoors.mod_pocketDim.helpers.jnbt;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* JNBT License
|
|
||||||
*
|
|
||||||
* Copyright (c) 2010 Graham Edgecombe
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
*
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
*
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* * Neither the name of the JNBT team nor the names of its
|
|
||||||
* contributors may be used to endorse or promote products derived from
|
|
||||||
* this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
||||||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Represents a single NBT tag.
|
|
||||||
*
|
|
||||||
* @author Graham Edgecombe
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public abstract class Tag {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The name of this tag.
|
|
||||||
*/
|
|
||||||
private final String name;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the tag with the specified name.
|
|
||||||
*
|
|
||||||
* @param name
|
|
||||||
* The name.
|
|
||||||
*/
|
|
||||||
public Tag(String name) {
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the name of this tag.
|
|
||||||
*
|
|
||||||
* @return The name of this tag.
|
|
||||||
*/
|
|
||||||
public final String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the value of this tag.
|
|
||||||
*
|
|
||||||
* @return The value of this tag.
|
|
||||||
*/
|
|
||||||
public abstract Object getValue();
|
|
||||||
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user