2020-09-09 16:48:43 +02:00
|
|
|
package de.ellpeck.actuallyadditions.common;
|
2014-11-10 16:47:04 +01:00
|
|
|
|
2016-05-14 13:51:18 +02:00
|
|
|
import de.ellpeck.actuallyadditions.api.ActuallyAdditionsAPI;
|
2020-09-16 11:48:12 +02:00
|
|
|
import de.ellpeck.actuallyadditions.api.lens.Lens;
|
2020-09-09 16:48:43 +02:00
|
|
|
import de.ellpeck.actuallyadditions.booklet.InitBooklet;
|
2020-09-09 17:10:55 +02:00
|
|
|
import de.ellpeck.actuallyadditions.common.blocks.InitBlocks;
|
2020-09-09 16:48:43 +02:00
|
|
|
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;
|
2020-09-09 17:10:55 +02:00
|
|
|
import net.minecraft.item.ItemGroup;
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
import net.minecraft.item.Items;
|
2016-12-28 14:55:03 +01:00
|
|
|
import net.minecraft.server.MinecraftServer;
|
|
|
|
import net.minecraft.world.World;
|
2017-06-29 13:00:11 +02:00
|
|
|
import net.minecraftforge.common.MinecraftForge;
|
2020-09-09 17:10:55 +02:00
|
|
|
import net.minecraftforge.eventbus.api.Event;
|
|
|
|
import net.minecraftforge.eventbus.api.IEventBus;
|
|
|
|
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
2016-01-07 18:20:59 +01:00
|
|
|
import net.minecraftforge.fml.common.Mod;
|
2019-02-27 19:44:33 +01:00
|
|
|
import net.minecraftforge.fml.common.registry.GameRegistry;
|
2020-09-09 17:10:55 +02:00
|
|
|
import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent;
|
|
|
|
import net.minecraftforge.fml.event.lifecycle.FMLCommonSetupEvent;
|
|
|
|
import net.minecraftforge.fml.event.server.FMLServerStartedEvent;
|
|
|
|
import net.minecraftforge.fml.event.server.FMLServerStoppedEvent;
|
|
|
|
import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext;
|
2020-09-16 11:48:12 +02:00
|
|
|
import net.minecraftforge.registries.ForgeRegistries;
|
|
|
|
import net.minecraftforge.registries.ForgeRegistry;
|
|
|
|
import net.minecraftforge.registries.IForgeRegistry;
|
|
|
|
import net.minecraftforge.registries.RegistryBuilder;
|
2020-09-09 17:10:55 +02:00
|
|
|
import org.apache.logging.log4j.LogManager;
|
|
|
|
import org.apache.logging.log4j.Logger;
|
2015-10-02 16:48:01 +02:00
|
|
|
|
2020-09-09 17:10:55 +02:00
|
|
|
@Mod(ActuallyAdditions.MODID)
|
2018-03-23 03:53:13 +01:00
|
|
|
public class ActuallyAdditions {
|
2014-11-10 16:47:04 +01:00
|
|
|
|
2018-05-10 11:38:58 +02:00
|
|
|
public static final String MODID = ActuallyAdditionsAPI.MOD_ID;
|
|
|
|
public static final String NAME = "Actually Additions";
|
2020-09-09 17:10:55 +02:00
|
|
|
// public static final String VERSION = "@VERSION@";
|
|
|
|
// public static final String GUIFACTORY = "de.ellpeck.actuallyadditions.common.config.GuiFactory";
|
|
|
|
// 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");
|
2014-11-10 16:47:04 +01:00
|
|
|
|
2020-09-09 17:10:55 +02:00
|
|
|
public static final Logger LOGGER = LogManager.getLogger(MODID);
|
2018-05-10 11:38:58 +02:00
|
|
|
public static ActuallyAdditions INSTANCE;
|
2020-09-16 11:48:12 +02:00
|
|
|
|
2020-09-09 17:10:55 +02:00
|
|
|
public static boolean commonCapsLoaded = false;
|
|
|
|
|
|
|
|
// Creative Tab
|
|
|
|
public static ItemGroup aaGroup = new ItemGroup(MODID) {
|
|
|
|
@Override
|
|
|
|
public ItemStack createIcon() {
|
|
|
|
return new ItemStack(Items.PACKED_ICE); // placeholder until I've done the actual stuff @todo
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
public ActuallyAdditions() {
|
|
|
|
INSTANCE = this;
|
|
|
|
|
|
|
|
IEventBus bus = FMLJavaModLoadingContext.get().getModEventBus();
|
|
|
|
|
|
|
|
// Register registers
|
|
|
|
InitBlocks.BLOCKS.register(bus);
|
2020-09-16 11:48:12 +02:00
|
|
|
// items
|
|
|
|
Lenses.LENSES.register(bus);
|
2020-09-09 17:10:55 +02:00
|
|
|
|
|
|
|
bus.addListener(this::setup);
|
|
|
|
bus.addListener(this::clientSetup);
|
|
|
|
|
|
|
|
MinecraftForge.EVENT_BUS.register(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
private void setup(final FMLCommonSetupEvent event) {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
private void clientSetup(final FMLClientSetupEvent event) {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@SubscribeEvent
|
|
|
|
public void serverStarted(FMLServerStartedEvent event) {
|
|
|
|
// todo: come back to this if it's still needed after migrating the world save to a newer version
|
|
|
|
|
|
|
|
// MinecraftServer server = FMLCommonHandler.instance().getMinecraftServerInstance();
|
|
|
|
// if (server != null) {
|
|
|
|
// World world = server.getEntityWorld();
|
|
|
|
// if (world != null && !world.isRemote) {
|
|
|
|
// WorldData.get(world, true).markDirty();
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
@SubscribeEvent
|
|
|
|
public void serverStopped(FMLServerStoppedEvent event) {
|
|
|
|
WorldData.clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-09-09 16:48:43 +02:00
|
|
|
@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;
|
|
|
|
|
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
|
|
|
|
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...");
|
2015-02-09 17:25:05 +01:00
|
|
|
|
2016-05-14 13:51:18 +02:00
|
|
|
ActuallyAdditionsAPI.methodHandler = new MethodHandler();
|
2016-07-30 17:07:32 +02:00
|
|
|
ActuallyAdditionsAPI.connectionHandler = new LaserRelayConnectionHandler();
|
2016-05-15 12:01:26 +02:00
|
|
|
InitBooklet.preInit();
|
2018-03-23 03:53:13 +01:00
|
|
|
CompatUtil.registerCraftingTweaks();
|
2016-07-25 02:07:16 +02:00
|
|
|
|
2020-09-09 17:10:55 +02:00
|
|
|
// commonCapsLoaded = Loader.isModLoaded("commoncapabilities");
|
|
|
|
// MinecraftForge.EVENT_BUS.register(new RegistryHandler());
|
2017-06-29 13:00:11 +02:00
|
|
|
|
2015-07-17 11:17:55 +02:00
|
|
|
new ConfigurationHandler(event.getSuggestedConfigurationFile());
|
2015-06-12 19:12:06 +02:00
|
|
|
PacketHandler.init();
|
2015-07-11 05:24:04 +02:00
|
|
|
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);
|
2015-02-09 17:25:05 +01:00
|
|
|
|
2018-05-10 11:38:58 +02:00
|
|
|
ActuallyAdditions.LOGGER.info("PreInitialization Finished.");
|
2014-11-10 16:47:04 +01:00
|
|
|
}
|
|
|
|
|
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...");
|
2015-02-09 17:25:05 +01:00
|
|
|
|
2017-06-29 13:00:11 +02:00
|
|
|
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();
|
2017-03-19 16:24:58 +01:00
|
|
|
|
2018-05-10 11:38:58 +02:00
|
|
|
PROXY.init(event);
|
2017-06-29 18:36:33 +02:00
|
|
|
|
2017-06-29 18:30:02 +02:00
|
|
|
RegistryHandler.BLOCKS_TO_REGISTER.clear();
|
2016-11-22 22:25:46 +01:00
|
|
|
|
2018-05-10 11:38:58 +02:00
|
|
|
ActuallyAdditions.LOGGER.info("Initialization Finished.");
|
2016-11-22 22:25:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@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...");
|
2016-11-22 22:25:46 +01:00
|
|
|
|
2016-11-16 19:08:56 +01:00
|
|
|
ItemCoffee.initIngredients();
|
|
|
|
CrusherCrafting.init();
|
|
|
|
HairyBallHandler.init();
|
|
|
|
TreasureChestHandler.init();
|
|
|
|
LensRecipeHandler.init();
|
|
|
|
EmpowererHandler.init();
|
2016-11-23 17:46:08 +01:00
|
|
|
LensMining.init();
|
2016-11-16 19:08:56 +01:00
|
|
|
|
2016-11-22 22:54:35 +01:00
|
|
|
InitBooklet.postInit();
|
2018-05-10 11:38:58 +02:00
|
|
|
PROXY.postInit(event);
|
2015-02-09 17:25:05 +01:00
|
|
|
|
2017-08-02 04:20:47 +02:00
|
|
|
ConfigurationHandler.redefineConfigs();
|
2018-03-23 03:53:13 +01:00
|
|
|
|
2018-05-10 11:38:58 +02:00
|
|
|
ActuallyAdditions.LOGGER.info("PostInitialization Finished.");
|
2014-11-10 16:47:04 +01:00
|
|
|
}
|
|
|
|
}
|