Package appeng.server.subcommands

Source Code of appeng.server.subcommands.ChunkLogger

package appeng.server.subcommands;

import net.minecraft.command.ICommandSender;
import net.minecraft.server.MinecraftServer;
import net.minecraft.util.ChatComponentTranslation;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.event.world.ChunkEvent;
import appeng.core.AEConfig;
import appeng.core.AELog;
import appeng.core.features.AEFeature;
import appeng.server.ISubCommand;
import cpw.mods.fml.common.eventhandler.SubscribeEvent;

public class ChunkLogger implements ISubCommand
{

  boolean enabled = false;

  @SubscribeEvent
  public void ChunkLoad(ChunkEvent.Load load)
  {
    if ( !load.world.isRemote )
    {
      AELog.info( "Chunk Loaded:   " + load.getChunk().xPosition + ", " + load.getChunk().zPosition );
      displayStack();
    }
  }

  private void displayStack()
  {
    if ( AEConfig.instance.isFeatureEnabled( AEFeature.ChunkLoggerTrace ) )
    {
      boolean output = false;
      for (StackTraceElement e : Thread.currentThread().getStackTrace())
      {
        if ( output )
          AELog.info( "    " + e.getClassName() + "." + e.getMethodName() + " (" + e.getLineNumber() + ")" );
        else
        {
          output = e.getClassName().contains( "EventBus" ) && e.getMethodName().contains( "post" );
        }
      }
    }
  }

  @SubscribeEvent
  public void ChunkLoad(ChunkEvent.Unload unload)
  {
    if ( !unload.world.isRemote )
    {
      AELog.info( "Chunk Unloaded: " + unload.getChunk().xPosition + ", " + unload.getChunk().zPosition );
      displayStack();
    }
  }

  @Override
  public void call(MinecraftServer srv, String[] data, ICommandSender sender)
  {
    enabled = !enabled;

    if ( enabled )
    {
      MinecraftForge.EVENT_BUS.register( this );
      sender.addChatMessage( new ChatComponentTranslation( "commands.ae2.ChunkLoggerOn" ) );
    }
    else
    {
      MinecraftForge.EVENT_BUS.unregister( this );
      sender.addChatMessage( new ChatComponentTranslation( "commands.ae2.ChunkLoggerOff" ) );
    }
  }

  @Override
  public String getHelp(MinecraftServer srv)
  {
    return "commands.ae2.ChunkLogger";
  }

}
TOP

Related Classes of appeng.server.subcommands.ChunkLogger

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.