2015-08-30 19:10:10 +02:00
|
|
|
|
/*
|
2015-10-06 16:36:25 +02:00
|
|
|
|
* This file ("PersistentClientData.java") is part of the Actually Additions Mod for Minecraft.
|
2015-08-30 19:10:10 +02:00
|
|
|
|
* 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
|
|
|
|
|
*/
|
|
|
|
|
|
2015-09-27 15:31:43 +02:00
|
|
|
|
package ellpeck.actuallyadditions.util.playerdata;
|
2015-08-30 19:10:10 +02:00
|
|
|
|
|
|
|
|
|
import cpw.mods.fml.relauncher.Side;
|
|
|
|
|
import cpw.mods.fml.relauncher.SideOnly;
|
|
|
|
|
import ellpeck.actuallyadditions.booklet.BookletChapter;
|
|
|
|
|
import ellpeck.actuallyadditions.booklet.BookletIndexEntry;
|
|
|
|
|
import ellpeck.actuallyadditions.booklet.GuiBooklet;
|
|
|
|
|
import ellpeck.actuallyadditions.booklet.InitBooklet;
|
2015-09-10 21:25:34 +02:00
|
|
|
|
import ellpeck.actuallyadditions.booklet.page.BookletPage;
|
2015-09-27 15:31:43 +02:00
|
|
|
|
import ellpeck.actuallyadditions.util.ModUtil;
|
2015-08-30 19:10:10 +02:00
|
|
|
|
import net.minecraft.client.Minecraft;
|
|
|
|
|
import net.minecraft.nbt.CompressedStreamTools;
|
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
|
import java.io.FileInputStream;
|
|
|
|
|
import java.io.FileOutputStream;
|
|
|
|
|
|
|
|
|
|
@SideOnly(Side.CLIENT)
|
2015-09-30 06:56:33 +02:00
|
|
|
|
public class PersistentClientData{
|
2015-08-30 19:10:10 +02:00
|
|
|
|
|
|
|
|
|
private static File theFile;
|
|
|
|
|
|
2015-10-30 23:37:20 +01:00
|
|
|
|
public static void saveBookPage(BookletIndexEntry entry, BookletChapter chapter, BookletPage page, int pageInIndex, String searchWord){
|
2015-10-29 19:51:00 +01:00
|
|
|
|
NBTTagCompound baseCompound = getBaseCompound();
|
|
|
|
|
NBTTagCompound worldCompound = getCompoundForWorld(baseCompound);
|
|
|
|
|
if(worldCompound != null){
|
|
|
|
|
worldCompound.setInteger("Entry", entry == null ? -1 : InitBooklet.entries.indexOf(entry));
|
|
|
|
|
worldCompound.setInteger("Chapter", entry == null || chapter == null ? -1 : entry.chapters.indexOf(chapter));
|
|
|
|
|
worldCompound.setInteger("Page", page == null ? -1 : page.getID());
|
|
|
|
|
worldCompound.setInteger("PageInIndex", pageInIndex);
|
2015-10-30 23:37:20 +01:00
|
|
|
|
worldCompound.setString("SearchWord", searchWord);
|
2015-10-29 19:51:00 +01:00
|
|
|
|
writeCompound(baseCompound, worldCompound);
|
2015-08-30 19:10:10 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-29 19:51:00 +01:00
|
|
|
|
private static NBTTagCompound getBaseCompound(){
|
2015-10-23 16:54:33 +02:00
|
|
|
|
try{
|
|
|
|
|
return CompressedStreamTools.readCompressed(new FileInputStream(getTheFile()));
|
|
|
|
|
}
|
|
|
|
|
catch(Exception e){
|
|
|
|
|
return new NBTTagCompound();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-29 19:51:00 +01:00
|
|
|
|
private static String getName(){
|
2015-10-31 21:42:16 +01:00
|
|
|
|
if(Minecraft.getMinecraft().theWorld != null){
|
|
|
|
|
return Minecraft.getMinecraft().isIntegratedServerRunning() ? Minecraft.getMinecraft().getIntegratedServer().getFolderName() : Minecraft.getMinecraft().func_147104_D().serverIP;
|
|
|
|
|
}
|
2015-10-31 21:45:19 +01:00
|
|
|
|
else return "Invalid";
|
2015-10-23 16:54:33 +02:00
|
|
|
|
}
|
|
|
|
|
|
2015-10-29 19:51:00 +01:00
|
|
|
|
private static NBTTagCompound getCompoundForWorld(NBTTagCompound mainCompound){
|
|
|
|
|
return mainCompound.getCompoundTag(getName());
|
|
|
|
|
}
|
2015-10-23 16:54:33 +02:00
|
|
|
|
|
2015-10-29 19:51:00 +01:00
|
|
|
|
private static void writeCompound(NBTTagCompound baseCompound, NBTTagCompound worldCompound){
|
|
|
|
|
baseCompound.setTag(getName(), worldCompound);
|
|
|
|
|
try{
|
|
|
|
|
CompressedStreamTools.writeCompressed(baseCompound, new FileOutputStream(getTheFile()));
|
2015-10-23 16:54:33 +02:00
|
|
|
|
}
|
|
|
|
|
catch(Exception e){
|
|
|
|
|
ModUtil.LOGGER.fatal("Couldn't write Persistent Variable!", e);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static File getTheFile(){
|
|
|
|
|
try{
|
|
|
|
|
if(!theFile.exists()){
|
|
|
|
|
theFile.createNewFile();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
catch(Exception e){
|
|
|
|
|
ModUtil.LOGGER.fatal("Couldn't create Persistent Variables file!", e);
|
|
|
|
|
}
|
|
|
|
|
return theFile;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void setTheFile(File file){
|
|
|
|
|
theFile = file;
|
|
|
|
|
}
|
|
|
|
|
|
2015-08-30 19:10:10 +02:00
|
|
|
|
public static void openLastBookPage(GuiBooklet gui){
|
2015-10-29 19:51:00 +01:00
|
|
|
|
NBTTagCompound worldCompound = getCompoundForWorld(getBaseCompound());
|
2015-10-30 23:37:20 +01:00
|
|
|
|
if(worldCompound != null && worldCompound.hasKey("Entry")){
|
|
|
|
|
int entry = worldCompound.getInteger("Entry");
|
|
|
|
|
int chapter = worldCompound.getInteger("Chapter");
|
|
|
|
|
int page = worldCompound.getInteger("Page");
|
|
|
|
|
|
|
|
|
|
BookletIndexEntry currentIndexEntry = entry == -1 ? null : InitBooklet.entries.get(entry);
|
|
|
|
|
BookletChapter currentChapter = chapter == -1 || entry == -1 || currentIndexEntry.chapters.size() <= chapter ? null : currentIndexEntry.chapters.get(chapter);
|
|
|
|
|
BookletPage currentPage = chapter == -1 || currentChapter == null || currentChapter.pages.length <= page-1 ? null : currentChapter.pages[page-1];
|
|
|
|
|
int pageInIndex = worldCompound.getInteger("PageInIndex");
|
|
|
|
|
|
|
|
|
|
gui.openIndexEntry(currentIndexEntry, pageInIndex, true);
|
|
|
|
|
if(currentChapter != null){
|
|
|
|
|
gui.openChapter(currentChapter, currentPage);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
String searchText = worldCompound.getString("SearchWord");
|
|
|
|
|
if(!searchText.isEmpty()){
|
|
|
|
|
gui.searchField.setText(searchText);
|
|
|
|
|
gui.updateSearchBar();
|
2015-08-30 19:10:10 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2015-10-30 23:37:20 +01:00
|
|
|
|
else{
|
|
|
|
|
//If everything fails, initialize the front page
|
|
|
|
|
gui.openIndexEntry(null, 1, true);
|
|
|
|
|
}
|
2015-08-30 19:10:10 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void setBoolean(String name, boolean bool){
|
2015-10-29 19:51:00 +01:00
|
|
|
|
NBTTagCompound baseCompound = getBaseCompound();
|
|
|
|
|
NBTTagCompound worldCompound = getCompoundForWorld(baseCompound);
|
|
|
|
|
if(worldCompound != null){
|
|
|
|
|
worldCompound.setBoolean(name, bool);
|
|
|
|
|
writeCompound(baseCompound, worldCompound);
|
2015-08-30 19:10:10 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static boolean getBoolean(String name){
|
2015-10-29 19:51:00 +01:00
|
|
|
|
NBTTagCompound worldCompound = getCompoundForWorld(getBaseCompound());
|
|
|
|
|
return worldCompound != null && worldCompound.getBoolean(name);
|
2015-08-30 19:10:10 +02:00
|
|
|
|
}
|
|
|
|
|
}
|