package appeng.debug; import java.util.EnumSet; import java.util.HashSet; import net.minecraft.entity.player.EntityPlayer; import net.minecraft.item.ItemStack; import net.minecraft.tileentity.TileEntity; import net.minecraft.util.ChatComponentText; import net.minecraft.world.World; import net.minecraftforge.common.util.ForgeDirection; import appeng.api.networking.IGridConnection; import appeng.api.networking.IGridHost; import appeng.api.networking.IGridNode; import appeng.api.networking.energy.IAEPowerStorage; import appeng.api.networking.energy.IEnergyGrid; import appeng.api.networking.pathing.ControllerState; import appeng.api.networking.pathing.IPathingGrid; import appeng.api.networking.ticking.ITickManager; import appeng.api.parts.IPart; import appeng.api.parts.IPartHost; import appeng.core.features.AEFeature; import appeng.hooks.TickHandler; import appeng.items.AEBaseItem; import appeng.me.Grid; import appeng.me.GridNode; import appeng.me.cache.TickManagerCache; import appeng.parts.p2p.PartP2PTunnel; import appeng.tile.networking.TileController; import appeng.util.Platform; public class ToolDebugCard extends AEBaseItem { public ToolDebugCard() { super( ToolDebugCard.class ); setfeature( EnumSet.of( AEFeature.UnsupportedDeveloperTools, AEFeature.Creative ) ); } public String timeMeasurement(long nanos) { long ms = (long) (nanos / 100000); if ( nanos <= 100000 ) return nanos + "ns"; return (((float) ms) / 10.0f) + "ms"; } @Override public boolean onItemUseFirst(ItemStack stack, EntityPlayer player, World world, int x, int y, int z, int side, float hitX, float hitY, float hitZ) { if ( Platform.isClient() ) return false; if ( player.isSneaking() ) { int grids = 0; int totalNodes = 0; for (Grid g : TickHandler.instance.getGridList()) { grids++; totalNodes += g.getNodes().size(); } outputMsg( player, "Grids: " + grids ); outputMsg( player, "Total Nodes: " + totalNodes ); } else { TileEntity te = world.getTileEntity( x, y, z ); if ( te instanceof IGridHost ) { GridNode node = (GridNode) ((IGridHost) te).getGridNode( ForgeDirection.getOrientation( side ) ); if ( node != null ) { Grid g = node.getInternalGrid(); IGridNode center = g.getPivot(); outputMsg( player, "This Node: " + node.toString() ); outputMsg( player, "Center Node: " + center.toString() ); IPathingGrid pg = g.getCache( IPathingGrid.class ); if ( pg.getControllerState() == ControllerState.CONTROLLER_ONLINE ) { int length = 0; HashSet next = new HashSet(); next.add( node ); int maxLength = 10000; outer: while ( ! next.isEmpty() ) { HashSet current = next; next = new HashSet(); for ( IGridNode n : current ) { if ( n.getMachine() instanceof TileController ) break outer; for ( IGridConnection c : n.getConnections() ) next.add( c.getOtherSide( n ) ); } length++; if ( length > maxLength ) break; } outputMsg( player, "Cable Distance: " + length ); } if ( center.getMachine() instanceof PartP2PTunnel ) { outputMsg( player, "Freq: " + ((PartP2PTunnel) center.getMachine()).freq ); } TickManagerCache tmc = (TickManagerCache) g.getCache( ITickManager.class ); for (Class c : g.getMachineClasses()) { int o = 0; long nanos = 0; for (IGridNode oj : g.getMachines( c )) { o++; nanos += tmc.getAvgNanoTime( oj ); } if ( nanos < 0 ) { outputMsg( player, c.getSimpleName() + " - " + o ); } else { outputMsg( player, c.getSimpleName() + " - " + o + "; " + timeMeasurement( nanos ) ); } } } else outputMsg( player, "No Node Available." ); } else outputMsg( player, "Not Networked Block" ); if ( te instanceof IPartHost ) { IPart center = ((IPartHost) te).getPart( ForgeDirection.UNKNOWN ); ((IPartHost) te).markForUpdate(); if ( center != null ) { GridNode n = (GridNode) center.getGridNode(); outputMsg( player, "Node Channels: " + n.usedChannels() ); for (IGridConnection gc : n.getConnections()) { ForgeDirection fd = gc.getDirection( n ); if ( fd != ForgeDirection.UNKNOWN ) outputMsg( player, fd.toString() + ": " + gc.getUsedChannels() ); } } } if ( te instanceof IAEPowerStorage ) { IAEPowerStorage ps = (IAEPowerStorage) te; outputMsg( player, "Energy: " + ps.getAECurrentPower() + " / " + ps.getAEMaxPower() ); if ( te instanceof IGridHost ) { IGridNode node = (IGridNode) ((IGridHost) te).getGridNode( ForgeDirection.getOrientation( side ) ); if ( node != null && node.getGrid() != null ) { IEnergyGrid eg = node.getGrid().getCache( IEnergyGrid.class ); outputMsg( player, "GridEnerg: " + eg.getStoredPower() + " : " + eg.getEnergyDemand( Double.MAX_VALUE ) ); } } } } return true; } private void outputMsg(EntityPlayer player, String string) { player.addChatMessage( new ChatComponentText( string ) ); } }