Switched biomes over to use Guava's Optional, in turn removing BiomeConfigurationHandler

This commit is contained in:
Adubbz 2015-04-07 20:07:41 +10:00
parent 35864315b9
commit 8b9080067d
6 changed files with 64 additions and 116 deletions

View file

@ -8,9 +8,11 @@
package biomesoplenty.api.biome;
import com.google.common.base.Optional;
import net.minecraft.world.biome.BiomeGenBase;
public class BOPBiomes
{
public static BiomeGenBase alps;
public static Optional<BiomeGenBase> alps = Optional.absent();
}

View file

@ -1,97 +0,0 @@
/*******************************************************************************
* Copyright 2014, the Biomes O' Plenty Team
*
* This work is licensed under a Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International Public License.
*
* To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/.
******************************************************************************/
package biomesoplenty.common.config;
import java.io.File;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import net.minecraft.world.biome.BiomeGenBase;
import org.apache.commons.io.FileUtils;
import biomesoplenty.common.util.config.JsonBiome;
import biomesoplenty.core.BiomesOPlenty;
import com.google.gson.JsonSyntaxException;
public class BiomeConfigurationHandler
{
private static Map<BiomeGenBase, String> configFileMap = new HashMap();
public static void init(File configDirectory)
{
load(configDirectory);
}
private static void load(File configDirectory)
{
for (Entry<BiomeGenBase, String> entry : configFileMap.entrySet())
{
BiomeGenBase biome = entry.getKey();
String configFileName = entry.getValue();
File configFile = new File(configDirectory, configFileName + ".json");
if (configFile.exists())
{
try
{
JsonBiome jsonBiome = JsonBiome.serializer.fromJson(FileUtils.readFileToString(configFile), JsonBiome.class);
JsonBiome.configureBiomeWithJson(biome, jsonBiome);
}
catch (JsonSyntaxException e)
{
BiomesOPlenty.logger.error("An error occurred reading " + configFile.getName(), e);
}
catch (IOException e)
{
e.printStackTrace();
}
}
else
{
try
{
FileUtils.write(configFile, JsonBiome.serializer.toJson(JsonBiome.createFromBiomeGenBase(biome), JsonBiome.class));
}
catch (IOException e)
{
e.printStackTrace();
}
}
}
}
public static void translateVanillaValues(BiomeGenBase biome)
{
/*IExtendedBiome extendedBiome = ExtendedBiomeRegistry.getExtension(biome);
GenerationManager generationManager = extendedBiome.getGenerationManager();
if (extendedBiome.getBiomeOwner() == BiomeOwner.OTHER)
{
if (biome.theBiomeDecorator.cactiPerChunk > 0)
{
WorldGenCactus cactusGen = new WorldGenCactus();
IExtendedCactusGen extendedCactusGen = (IExtendedCactusGen) cactusGen;
extendedCactusGen.setCactiPerChunk(biome.theBiomeDecorator.cactiPerChunk);
generationManager.addGenerator("cactus", extendedCactusGen, Decorate.EventType.CACTUS);
biome.theBiomeDecorator.cactiPerChunk = 0;
}
}*/
}
public static Map<BiomeGenBase, String> getConfigFileMap()
{
return BiomeConfigurationHandler.configFileMap;
}
}

View file

@ -9,11 +9,21 @@
package biomesoplenty.common.init;
import static biomesoplenty.api.biome.BOPBiomes.alps;
import java.io.File;
import java.io.IOException;
import org.apache.commons.io.FileUtils;
import com.google.common.base.Optional;
import com.google.gson.JsonSyntaxException;
import net.minecraft.world.biome.BiomeGenBase;
import biomesoplenty.common.biome.ExtendedBiomeRegistry;
import biomesoplenty.common.biome.overworld.BiomeGenAlps;
import biomesoplenty.common.config.BiomeConfigurationHandler;
import biomesoplenty.common.util.config.JsonBiome;
import biomesoplenty.common.world.WorldTypeBOP;
import biomesoplenty.core.BiomesOPlenty;
public class ModBiomes
{
@ -78,20 +88,18 @@ public class ModBiomes
registerExternalBiome(BiomeGenBase.mesaPlateau, "mesa_plateau");*/
}
private static BiomeGenBase registerBiome(BiomeGenBase biome, String id)
private static Optional<BiomeGenBase> registerBiome(BiomeGenBase biome, String id)
{
biome.biomeID = getNextFreeBiomeId();
BiomeConfigurationHandler.getConfigFileMap().put(biome, id);
return biome;
return loadOrCreateConfig(biome, id);
}
private static void registerExternalBiome(BiomeGenBase biome, String id)
/*private static void registerExternalBiome(BiomeGenBase biome, String id)
{
ExtendedBiomeRegistry.createExtension(biome);
BiomeConfigurationHandler.translateVanillaValues(biome);
BiomeConfigurationHandler.getConfigFileMap().put(biome, id);
}
}*/
public static int getNextFreeBiomeId()
{
@ -111,4 +119,42 @@ public class ModBiomes
return -1;
}
private static Optional<BiomeGenBase> loadOrCreateConfig(BiomeGenBase biome, String fileName)
{
File configFile = new File(new File(BiomesOPlenty.configDirectory, "biomes"), fileName + ".json");
if (configFile.exists())
{
try
{
JsonBiome jsonBiome = JsonBiome.serializer.fromJson(FileUtils.readFileToString(configFile), JsonBiome.class);
return JsonBiome.configureBiomeWithJson(biome, jsonBiome);
}
catch (JsonSyntaxException e)
{
BiomesOPlenty.logger.error("An error occurred reading " + configFile.getName(), e);
}
catch (IOException e)
{
e.printStackTrace();
}
}
else
{
try
{
FileUtils.write(configFile, JsonBiome.serializer.toJson(JsonBiome.createFromBiomeGenBase(biome), JsonBiome.class));
return Optional.of(biome);
}
catch (IOException e)
{
e.printStackTrace();
}
}
return Optional.absent();
}
}

View file

@ -10,7 +10,6 @@ package biomesoplenty.common.init;
import java.io.File;
import biomesoplenty.common.config.BiomeConfigurationHandler;
import biomesoplenty.common.config.MiscConfigurationHandler;
public class ModConfiguration
@ -19,9 +18,4 @@ public class ModConfiguration
{
MiscConfigurationHandler.init(new File(configDirectory, "misc.cfg"));
}
public static void initEnd(File configDirectory)
{
BiomeConfigurationHandler.init(new File(configDirectory, "biomes"));
}
}

View file

@ -23,6 +23,7 @@ import biomesoplenty.api.biome.generation.IGenerator;
import biomesoplenty.common.biome.BOPBiomeManager;
import biomesoplenty.common.biome.ExtendedBiomeRegistry;
import com.google.common.base.Optional;
import com.google.common.reflect.TypeToken;
import com.google.gson.FieldNamingPolicy;
import com.google.gson.Gson;
@ -94,7 +95,7 @@ public class JsonBiome
return biome;
}
public static void configureBiomeWithJson(BiomeGenBase biome, JsonBiome jsonBiome)
public static Optional<BiomeGenBase> configureBiomeWithJson(BiomeGenBase biome, JsonBiome jsonBiome)
{
IExtendedBiome extendedBiome = ExtendedBiomeRegistry.getExtension(biome);
@ -109,7 +110,7 @@ public class JsonBiome
}
else
{
biome.biomeID = -1;
return Optional.absent();
}
}
@ -149,6 +150,10 @@ public class JsonBiome
GenerationManager generationManager = extendedBiome.getGenerationManager();
generationManager.createGeneratorTable(jsonBiome.decoration);
}
return Optional.of(biome);
}
return Optional.absent();
}
}

View file

@ -43,8 +43,7 @@ public class BiomesOPlenty
public static CommonProxy proxy;
public static Logger logger = LogManager.getLogger(MOD_ID);
private File configDirectory;
public static File configDirectory;
@EventHandler
public void preInit(FMLPreInitializationEvent event)
@ -60,7 +59,6 @@ public class BiomesOPlenty
ModGenerators.init();
ModBiomes.init();
ModHandlers.init();
ModConfiguration.initEnd(configDirectory);
}
@EventHandler