2014-08-22 07:27:46 +02:00
|
|
|
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;
|
2014-08-23 02:23:48 +02:00
|
|
|
import appeng.core.AEConfig;
|
2014-08-22 07:27:46 +02:00
|
|
|
import appeng.core.AELog;
|
2014-08-23 02:23:48 +02:00
|
|
|
import appeng.core.features.AEFeature;
|
2014-08-22 07:27:46 +02:00
|
|
|
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 );
|
2014-08-23 02:23:48 +02:00
|
|
|
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" );
|
|
|
|
}
|
|
|
|
}
|
2014-08-22 07:27:46 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@SubscribeEvent
|
|
|
|
public void ChunkLoad(ChunkEvent.Unload unload)
|
|
|
|
{
|
|
|
|
if ( !unload.world.isRemote )
|
|
|
|
{
|
|
|
|
AELog.info( "Chunk Unloaded: " + unload.getChunk().xPosition + ", " + unload.getChunk().zPosition );
|
2014-08-23 02:23:48 +02:00
|
|
|
displayStack();
|
2014-08-22 07:27:46 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@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";
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|