Package appeng.core

Source Code of appeng.core.AppEng

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";

  final HashMap<String, IIMCHandler> IMCHandlers = new HashMap<String, IIMCHandler>();

  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() ) );
  }

}
TOP

Related Classes of appeng.core.AppEng

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.