47eb2c36f3
Added /ae2 supporters Added /ae2 chunklogger
211 lines
6.4 KiB
Java
211 lines
6.4 KiB
Java
package appeng.core;
|
|
|
|
import java.io.File;
|
|
import java.util.HashMap;
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
import appeng.api.config.TunnelType;
|
|
import appeng.core.api.IIMCHandler;
|
|
import appeng.core.api.imc.IMCBlackListSpatial;
|
|
import appeng.core.api.imc.IMCGrinder;
|
|
import appeng.core.api.imc.IMCMatterCannon;
|
|
import appeng.core.api.imc.IMCP2PAttunement;
|
|
import appeng.core.api.imc.IMCSpatial;
|
|
import appeng.core.crash.CrashEnhancement;
|
|
import appeng.core.crash.CrashInfo;
|
|
import appeng.core.features.AEFeature;
|
|
import appeng.core.sync.GuiBridge;
|
|
import appeng.core.sync.network.NetworkHandler;
|
|
import appeng.hooks.TickHandler;
|
|
import appeng.integration.IntegrationRegistry;
|
|
import appeng.integration.IntegrationType;
|
|
import appeng.server.AECommand;
|
|
import appeng.services.VersionChecker;
|
|
import appeng.util.Platform;
|
|
|
|
import com.google.common.base.Stopwatch;
|
|
|
|
import cpw.mods.fml.common.FMLCommonHandler;
|
|
import cpw.mods.fml.common.Loader;
|
|
import cpw.mods.fml.common.Mod;
|
|
import cpw.mods.fml.common.Mod.EventHandler;
|
|
import cpw.mods.fml.common.event.FMLInitializationEvent;
|
|
import cpw.mods.fml.common.event.FMLInterModComms;
|
|
import cpw.mods.fml.common.event.FMLInterModComms.IMCMessage;
|
|
import cpw.mods.fml.common.event.FMLPostInitializationEvent;
|
|
import cpw.mods.fml.common.event.FMLPreInitializationEvent;
|
|
import cpw.mods.fml.common.event.FMLServerAboutToStartEvent;
|
|
import cpw.mods.fml.common.event.FMLServerStartingEvent;
|
|
import cpw.mods.fml.common.event.FMLServerStoppingEvent;
|
|
import cpw.mods.fml.common.network.NetworkRegistry;
|
|
|
|
@Mod(modid = AppEng.modid, acceptedMinecraftVersions = "[1.7.10]", name = AppEng.name, version = AEConfig.VERSION, dependencies = AppEng.dependencies, guiFactory = "appeng.client.gui.config.AEConfigGuiFactory")
|
|
public class AppEng
|
|
{
|
|
|
|
private String configPath;
|
|
|
|
public String getConfigPath()
|
|
{
|
|
return configPath;
|
|
}
|
|
|
|
public final static String modid = "appliedenergistics2";
|
|
public final static String name = "Applied Energistics 2";
|
|
|
|
HashMap<String, IIMCHandler> IMCHandlers = new HashMap();
|
|
|
|
public static AppEng instance;
|
|
|
|
public final static String dependencies =
|
|
|
|
// a few mods, AE should load after, probably.
|
|
// required-after:AppliedEnergistics2API|all;
|
|
// "after:gregtech_addon;after:Mekanism;after:IC2;after:ThermalExpansion;after:BuildCraft|Core;" +
|
|
|
|
// depend on version of forge used for build.
|
|
"after:appliedenergistics2-core;" + "required-after:Forge@[" // require forge.
|
|
+ net.minecraftforge.common.ForgeVersion.majorVersion + "." // majorVersion
|
|
+ net.minecraftforge.common.ForgeVersion.minorVersion + "." // minorVersion
|
|
+ net.minecraftforge.common.ForgeVersion.revisionVersion + "." // revisionVersion
|
|
+ net.minecraftforge.common.ForgeVersion.buildVersion + ",)"; // buildVersion
|
|
|
|
public AppEng() {
|
|
instance = this;
|
|
|
|
IMCHandlers.put( "blacklist-block-spatial", new IMCBlackListSpatial() );
|
|
IMCHandlers.put( "whitelist-spatial", new IMCSpatial() );
|
|
IMCHandlers.put( "add-grindable", new IMCGrinder() );
|
|
IMCHandlers.put( "add-mattercannon-ammo", new IMCMatterCannon() );
|
|
|
|
for (TunnelType type : TunnelType.values())
|
|
{
|
|
IMCHandlers.put( "add-p2p-attunement-" + type.name().replace( '_', '-' ).toLowerCase(), new IMCP2PAttunement() );
|
|
}
|
|
|
|
FMLCommonHandler.instance().registerCrashCallable( new CrashEnhancement( CrashInfo.MOD_VERSION ) );
|
|
}
|
|
|
|
public boolean isIntegrationEnabled(IntegrationType Name)
|
|
{
|
|
return IntegrationRegistry.instance.isEnabled( Name );
|
|
}
|
|
|
|
public Object getIntegration(IntegrationType Name)
|
|
{
|
|
return IntegrationRegistry.instance.getInstance( Name );
|
|
}
|
|
|
|
private void startService(String serviceName, Thread thread)
|
|
{
|
|
thread.setName( serviceName );
|
|
thread.setPriority( Thread.MIN_PRIORITY );
|
|
thread.start();
|
|
}
|
|
|
|
@EventHandler
|
|
void PreInit(FMLPreInitializationEvent event)
|
|
{
|
|
if ( !Loader.isModLoaded( "appliedenergistics2-core" ) )
|
|
{
|
|
CommonHelper.proxy.missingCoreMod();
|
|
}
|
|
|
|
Stopwatch star = Stopwatch.createStarted();
|
|
configPath = event.getModConfigurationDirectory().getPath() + File.separator + "AppliedEnergistics2" + File.separator;
|
|
|
|
AEConfig.instance = new AEConfig( configPath );
|
|
FacadeConfig.instance = new FacadeConfig( configPath );
|
|
|
|
AELog.info( "Starting ( PreInit )" );
|
|
|
|
CreativeTab.init();
|
|
if ( AEConfig.instance.isFeatureEnabled( AEFeature.Facades ) )
|
|
CreativeTabFacade.init();
|
|
|
|
if ( Platform.isClient() )
|
|
CommonHelper.proxy.init();
|
|
|
|
Registration.instance.PreInit( event );
|
|
|
|
if ( AEConfig.instance.isFeatureEnabled( AEFeature.VersionChecker ) )
|
|
{
|
|
AELog.info( "Starting VersionChecker" );
|
|
startService( "AE2 VersionChecker", new Thread( VersionChecker.instance = new VersionChecker() ) );
|
|
}
|
|
|
|
AELog.info( "PreInit ( end " + star.elapsed( TimeUnit.MILLISECONDS ) + "ms )" );
|
|
}
|
|
|
|
@EventHandler
|
|
void Init(FMLInitializationEvent event)
|
|
{
|
|
Stopwatch star = Stopwatch.createStarted();
|
|
AELog.info( "Init" );
|
|
|
|
Registration.instance.Init( event );
|
|
IntegrationRegistry.instance.init();
|
|
|
|
AELog.info( "Init ( end " + star.elapsed( TimeUnit.MILLISECONDS ) + "ms )" );
|
|
}
|
|
|
|
@EventHandler
|
|
void PostInit(FMLPostInitializationEvent event)
|
|
{
|
|
Stopwatch star = Stopwatch.createStarted();
|
|
AELog.info( "PostInit" );
|
|
|
|
Registration.instance.PostInit( event );
|
|
IntegrationRegistry.instance.postinit();
|
|
FMLCommonHandler.instance().registerCrashCallable( new CrashEnhancement( CrashInfo.INTEGRATION ) );
|
|
|
|
CommonHelper.proxy.postinit();
|
|
AEConfig.instance.save();
|
|
|
|
NetworkRegistry.INSTANCE.registerGuiHandler( this, GuiBridge.GUI_Handler );
|
|
NetworkHandler.instance = new NetworkHandler( "AE2" );
|
|
|
|
AELog.info( "PostInit ( end " + star.elapsed( TimeUnit.MILLISECONDS ) + "ms )" );
|
|
}
|
|
|
|
@EventHandler
|
|
public void processIMC(FMLInterModComms.IMCEvent event)
|
|
{
|
|
for (IMCMessage m : event.getMessages())
|
|
{
|
|
try
|
|
{
|
|
IIMCHandler handler = IMCHandlers.get( m.key );
|
|
if ( handler != null )
|
|
handler.post( m );
|
|
else
|
|
throw new RuntimeException( "Invalid IMC Called: " + m.key );
|
|
}
|
|
catch (Throwable t)
|
|
{
|
|
AELog.warning( "Problem detected when processing IMC " + m.key + " from " + m.getSender() );
|
|
AELog.error( t );
|
|
}
|
|
}
|
|
}
|
|
|
|
@EventHandler
|
|
public void serverStopping(FMLServerStoppingEvent event)
|
|
{
|
|
WorldSettings.getInstance().shutdown();
|
|
TickHandler.instance.shutdown();
|
|
}
|
|
|
|
@EventHandler
|
|
public void serverStarting(FMLServerAboutToStartEvent evt)
|
|
{
|
|
WorldSettings.getInstance().init();
|
|
}
|
|
|
|
@EventHandler
|
|
public void serverStarting(FMLServerStartingEvent evt)
|
|
{
|
|
evt.registerServerCommand( new AECommand( evt.getServer() ) );
|
|
}
|
|
|
|
}
|