ActuallyAdditions/src/main/java/de/ellpeck/actuallyadditions/common/ActuallyAdditions.java

158 lines
6.6 KiB
Java
Raw Normal View History

package de.ellpeck.actuallyadditions.common;
2018-05-10 11:38:58 +02:00
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
2016-05-14 13:51:18 +02:00
import de.ellpeck.actuallyadditions.api.ActuallyAdditionsAPI;
import de.ellpeck.actuallyadditions.booklet.InitBooklet;
import de.ellpeck.actuallyadditions.common.config.ConfigurationHandler;
import de.ellpeck.actuallyadditions.common.crafting.CrusherCrafting;
import de.ellpeck.actuallyadditions.common.data.WorldData;
import de.ellpeck.actuallyadditions.common.entity.InitEntities;
import de.ellpeck.actuallyadditions.common.event.CommonEvents;
import de.ellpeck.actuallyadditions.common.fluids.InitFluids;
import de.ellpeck.actuallyadditions.common.gen.AAWorldGen;
import de.ellpeck.actuallyadditions.common.inventory.GuiHandler;
import de.ellpeck.actuallyadditions.common.items.ItemCoffee;
import de.ellpeck.actuallyadditions.common.items.lens.LensMining;
import de.ellpeck.actuallyadditions.common.items.lens.LensRecipeHandler;
import de.ellpeck.actuallyadditions.common.items.lens.Lenses;
import de.ellpeck.actuallyadditions.common.material.InitArmorMaterials;
import de.ellpeck.actuallyadditions.common.material.InitToolMaterials;
import de.ellpeck.actuallyadditions.common.misc.BannerHelper;
import de.ellpeck.actuallyadditions.common.misc.DungeonLoot;
import de.ellpeck.actuallyadditions.common.misc.apiimpl.LaserRelayConnectionHandler;
import de.ellpeck.actuallyadditions.common.misc.apiimpl.MethodHandler;
import de.ellpeck.actuallyadditions.common.network.PacketHandler;
import de.ellpeck.actuallyadditions.common.proxy.IProxy;
import de.ellpeck.actuallyadditions.common.recipe.EmpowererHandler;
import de.ellpeck.actuallyadditions.common.recipe.HairyBallHandler;
import de.ellpeck.actuallyadditions.common.recipe.TreasureChestHandler;
import de.ellpeck.actuallyadditions.common.tile.TileEntityBase;
import de.ellpeck.actuallyadditions.common.update.UpdateChecker;
import de.ellpeck.actuallyadditions.common.util.compat.CompatUtil;
import net.minecraft.launchwrapper.Launch;
import net.minecraft.server.MinecraftServer;
import net.minecraft.world.World;
import net.minecraftforge.common.MinecraftForge;
2016-05-06 22:23:41 +02:00
import net.minecraftforge.fluids.FluidRegistry;
import net.minecraftforge.fml.common.FMLCommonHandler;
import net.minecraftforge.fml.common.Loader;
2016-01-07 18:20:59 +01:00
import net.minecraftforge.fml.common.Mod;
import net.minecraftforge.fml.common.Mod.EventHandler;
import net.minecraftforge.fml.common.Mod.Instance;
import net.minecraftforge.fml.common.SidedProxy;
2018-03-07 03:08:25 +01:00
import net.minecraftforge.fml.common.event.FMLInitializationEvent;
import net.minecraftforge.fml.common.event.FMLPostInitializationEvent;
import net.minecraftforge.fml.common.event.FMLPreInitializationEvent;
import net.minecraftforge.fml.common.event.FMLServerStartedEvent;
import net.minecraftforge.fml.common.event.FMLServerStoppedEvent;
2019-02-27 19:44:33 +01:00
import net.minecraftforge.fml.common.registry.GameRegistry;
2015-10-02 16:48:01 +02:00
2018-05-10 11:38:58 +02:00
@Mod(modid = ActuallyAdditions.MODID, name = ActuallyAdditions.NAME, version = ActuallyAdditions.VERSION, guiFactory = ActuallyAdditions.GUIFACTORY, dependencies = ActuallyAdditions.DEPS)
2018-03-23 03:53:13 +01:00
public class ActuallyAdditions {
2018-05-10 11:38:58 +02:00
public static final String MODID = ActuallyAdditionsAPI.MOD_ID;
public static final String NAME = "Actually Additions";
public static final String VERSION = "@VERSION@";
public static final String GUIFACTORY = "de.ellpeck.actuallyadditions.common.config.GuiFactory";
2019-05-18 20:40:53 +02:00
public static final String DEPS = "required:forge@[14.23.5.2836,);before:craftingtweaks;after:fastbench@[1.3.2,)";
public static final boolean DEOBF = (boolean) Launch.blackboard.get("fml.deobfuscatedEnvironment");
2018-05-10 11:38:58 +02:00
@Instance
public static ActuallyAdditions INSTANCE;
@SidedProxy(clientSide = "de.ellpeck.actuallyadditions.common.proxy.ClientProxy", serverSide = "de.ellpeck.actuallyadditions.common.proxy.ServerProxy")
2018-05-10 11:38:58 +02:00
public static IProxy PROXY;
public static final Logger LOGGER = LogManager.getLogger(NAME);
2018-03-23 03:53:13 +01:00
static {
2016-05-06 22:23:41 +02:00
FluidRegistry.enableUniversalBucket();
}
2018-05-10 11:38:58 +02:00
public static boolean commonCapsLoaded;
2015-06-21 02:28:49 +02:00
@EventHandler
2018-03-23 03:53:13 +01:00
public void preInit(FMLPreInitializationEvent event) {
2018-05-10 11:38:58 +02:00
ActuallyAdditions.LOGGER.info("Starting PreInitialization Phase...");
2016-05-14 13:51:18 +02:00
ActuallyAdditionsAPI.methodHandler = new MethodHandler();
ActuallyAdditionsAPI.connectionHandler = new LaserRelayConnectionHandler();
2016-05-15 12:01:26 +02:00
Lenses.init();
InitBooklet.preInit();
2018-03-23 03:53:13 +01:00
CompatUtil.registerCraftingTweaks();
commonCapsLoaded = Loader.isModLoaded("commoncapabilities");
MinecraftForge.EVENT_BUS.register(new RegistryHandler());
2015-07-17 11:17:55 +02:00
new ConfigurationHandler(event.getSuggestedConfigurationFile());
PacketHandler.init();
InitToolMaterials.init();
InitArmorMaterials.init();
2016-01-29 17:38:31 +01:00
InitFluids.init();
2016-07-03 20:57:00 +02:00
new UpdateChecker();
2018-05-10 11:38:58 +02:00
PROXY.preInit(event);
2018-05-10 11:38:58 +02:00
ActuallyAdditions.LOGGER.info("PreInitialization Finished.");
}
2015-06-21 02:28:49 +02:00
@EventHandler
2018-03-23 03:53:13 +01:00
public void init(FMLInitializationEvent event) {
2018-05-10 11:38:58 +02:00
ActuallyAdditions.LOGGER.info("Starting Initialization Phase...");
BannerHelper.init();
2017-06-17 00:48:49 +02:00
//InitAchievements.init();
2014-12-18 19:24:06 +01:00
GuiHandler.init();
2019-02-27 19:44:33 +01:00
AAWorldGen gen = new AAWorldGen();
GameRegistry.registerWorldGenerator(gen, 10000);
MinecraftForge.TERRAIN_GEN_BUS.register(gen);
2014-12-18 19:24:06 +01:00
TileEntityBase.init();
2019-02-27 19:44:33 +01:00
MinecraftForge.EVENT_BUS.register(new CommonEvents());
MinecraftForge.EVENT_BUS.register(new DungeonLoot());
2016-07-22 20:23:51 +02:00
InitEntities.init();
2018-05-10 11:38:58 +02:00
PROXY.init(event);
RegistryHandler.BLOCKS_TO_REGISTER.clear();
2018-05-10 11:38:58 +02:00
ActuallyAdditions.LOGGER.info("Initialization Finished.");
}
@EventHandler
2018-03-23 03:53:13 +01:00
public void postInit(FMLPostInitializationEvent event) {
2018-05-10 11:38:58 +02:00
ActuallyAdditions.LOGGER.info("Starting PostInitialization Phase...");
ItemCoffee.initIngredients();
CrusherCrafting.init();
HairyBallHandler.init();
TreasureChestHandler.init();
LensRecipeHandler.init();
EmpowererHandler.init();
LensMining.init();
2016-11-22 22:54:35 +01:00
InitBooklet.postInit();
2018-05-10 11:38:58 +02:00
PROXY.postInit(event);
ConfigurationHandler.redefineConfigs();
2018-03-23 03:53:13 +01:00
2018-05-10 11:38:58 +02:00
ActuallyAdditions.LOGGER.info("PostInitialization Finished.");
}
2015-06-28 03:12:32 +02:00
@EventHandler
2018-03-23 03:53:13 +01:00
public void serverStarted(FMLServerStartedEvent event) {
MinecraftServer server = FMLCommonHandler.instance().getMinecraftServerInstance();
2018-03-23 03:53:13 +01:00
if (server != null) {
World world = server.getEntityWorld();
2018-03-23 03:53:13 +01:00
if (world != null && !world.isRemote) {
WorldData.get(world, true).markDirty();
}
}
}
@EventHandler
2018-03-23 03:53:13 +01:00
public void serverStopped(FMLServerStoppedEvent event) {
WorldData.clear();
}
}