2015-10-19 17:50:43 +02:00
|
|
|
|
/*
|
|
|
|
|
* This file ("WorldData.java") is part of the Actually Additions Mod for Minecraft.
|
|
|
|
|
* It is created and owned by Ellpeck and distributed
|
|
|
|
|
* under the Actually Additions License to be found at
|
|
|
|
|
* http://github.com/Ellpeck/ActuallyAdditions/blob/master/README.md
|
|
|
|
|
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
|
|
|
|
|
*
|
|
|
|
|
* <EFBFBD> 2015 Ellpeck
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
package ellpeck.actuallyadditions.misc;
|
|
|
|
|
|
|
|
|
|
import ellpeck.actuallyadditions.util.ModUtil;
|
2015-10-22 22:18:33 +02:00
|
|
|
|
import ellpeck.actuallyadditions.util.playerdata.PersistentServerData;
|
2015-10-19 17:50:43 +02:00
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
2015-10-29 17:36:30 +01:00
|
|
|
|
import net.minecraft.nbt.NBTTagList;
|
2015-10-19 17:50:43 +02:00
|
|
|
|
import net.minecraft.server.MinecraftServer;
|
|
|
|
|
import net.minecraft.world.World;
|
|
|
|
|
import net.minecraft.world.WorldSavedData;
|
|
|
|
|
|
|
|
|
|
public class WorldData extends WorldSavedData{
|
|
|
|
|
|
|
|
|
|
public static final String DATA_TAG = ModUtil.MOD_ID+"WorldData";
|
2015-10-23 16:54:33 +02:00
|
|
|
|
public static WorldData instance;
|
2015-10-19 17:50:43 +02:00
|
|
|
|
|
2015-10-20 00:22:36 +02:00
|
|
|
|
public WorldData(String tag){
|
|
|
|
|
super(tag);
|
2015-10-19 17:50:43 +02:00
|
|
|
|
}
|
|
|
|
|
|
2015-10-23 16:54:33 +02:00
|
|
|
|
public static void makeDirty(){
|
|
|
|
|
if(instance != null){
|
|
|
|
|
instance.markDirty();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void init(MinecraftServer server){
|
|
|
|
|
if(server != null){
|
|
|
|
|
World world = server.getEntityWorld();
|
|
|
|
|
if(!world.isRemote){
|
|
|
|
|
WorldSavedData savedData = world.loadItemData(WorldData.class, WorldData.DATA_TAG);
|
|
|
|
|
//Generate new SavedData
|
|
|
|
|
if(savedData == null){
|
|
|
|
|
savedData = new WorldData(WorldData.DATA_TAG);
|
|
|
|
|
world.setItemData(WorldData.DATA_TAG, savedData);
|
|
|
|
|
}
|
|
|
|
|
//Set the current SavedData to the retreived one
|
|
|
|
|
if(savedData instanceof WorldData){
|
|
|
|
|
WorldData.instance = (WorldData)savedData;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2015-10-19 17:50:43 +02:00
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void readFromNBT(NBTTagCompound compound){
|
2015-10-22 22:18:33 +02:00
|
|
|
|
//Laser World Data
|
2015-10-29 17:36:30 +01:00
|
|
|
|
NBTTagList list = compound.getTagList("Networks", 10);
|
|
|
|
|
for(int i = 0; i < list.tagCount(); i++){
|
|
|
|
|
LaserRelayConnectionHandler.Network network = LaserRelayConnectionHandler.getInstance().readNetworkFromNBT(list.getCompoundTagAt(i));
|
|
|
|
|
LaserRelayConnectionHandler.getInstance().networks.add(network);
|
2015-10-21 00:22:50 +02:00
|
|
|
|
}
|
2015-10-22 22:18:33 +02:00
|
|
|
|
|
|
|
|
|
//Player Data
|
|
|
|
|
int dataSize = compound.getInteger("PersistentDataSize");
|
|
|
|
|
PersistentServerData.playerSaveData.clear();
|
|
|
|
|
for(int i = 0; i < dataSize; i++){
|
|
|
|
|
PersistentServerData.PlayerSave aSave = PersistentServerData.PlayerSave.fromNBT(compound, "PlayerSaveData"+i);
|
|
|
|
|
if(aSave != null){
|
|
|
|
|
PersistentServerData.playerSaveData.add(aSave);
|
|
|
|
|
}
|
|
|
|
|
}
|
2015-10-19 17:50:43 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void writeToNBT(NBTTagCompound compound){
|
2015-10-22 22:18:33 +02:00
|
|
|
|
//Laser World Data
|
2015-10-29 17:36:30 +01:00
|
|
|
|
NBTTagList list = new NBTTagList();
|
|
|
|
|
for(LaserRelayConnectionHandler.Network network : LaserRelayConnectionHandler.getInstance().networks){
|
|
|
|
|
list.appendTag(LaserRelayConnectionHandler.getInstance().writeNetworkToNBT(network));
|
2015-10-21 00:22:50 +02:00
|
|
|
|
}
|
2015-10-29 17:36:30 +01:00
|
|
|
|
compound.setTag("Networks", list);
|
2015-10-22 22:18:33 +02:00
|
|
|
|
|
|
|
|
|
//Player Data
|
|
|
|
|
compound.setInteger("PersistentDataSize", PersistentServerData.playerSaveData.size());
|
|
|
|
|
for(int i = 0; i < PersistentServerData.playerSaveData.size(); i++){
|
|
|
|
|
PersistentServerData.PlayerSave theSave = PersistentServerData.playerSaveData.get(i);
|
|
|
|
|
theSave.toNBT(compound, "PlayerSaveData"+i);
|
|
|
|
|
}
|
2015-10-19 17:50:43 +02:00
|
|
|
|
}
|
|
|
|
|
}
|