Applied-Energistics-2-tiler.../src/main/java/appeng/debug/ToolDebugCard.java

227 lines
6.3 KiB
Java
Raw Normal View History

2014-11-14 12:02:52 +01:00
/*
* This file is part of Applied Energistics 2.
* Copyright (c) 2013 - 2014, AlgorithmX2, All rights reserved.
*
* Applied Energistics 2 is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Applied Energistics 2 is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Applied Energistics 2. If not, see <http://www.gnu.org/licenses/lgpl>.
*/
package appeng.debug;
import java.util.EnumSet;
import java.util.HashSet;
import java.util.Set;
import net.minecraft.command.ICommandSender;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.ItemStack;
import net.minecraft.tileentity.TileEntity;
2014-02-09 02:34:52 +01:00
import net.minecraft.util.ChatComponentText;
import net.minecraft.world.World;
2014-02-09 02:34:52 +01:00
import net.minecraftforge.common.util.ForgeDirection;
2014-12-29 21:59:05 +01:00
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;
2014-01-22 05:52:48 +01:00
import appeng.parts.p2p.PartP2PTunnel;
import appeng.tile.networking.TileController;
import appeng.util.Platform;
public class ToolDebugCard extends AEBaseItem
{
public ToolDebugCard()
{
this.setFeature( EnumSet.of( AEFeature.UnsupportedDeveloperTools, AEFeature.Creative ) );
}
@Override
public boolean onItemUseFirst( final ItemStack stack, final EntityPlayer player, final World world, final int x, final int y, final int z, final int side, final float hitX, final float hitY, final float hitZ )
{
if( Platform.isClient() )
2015-04-29 02:30:53 +02:00
{
return false;
2015-04-29 02:30:53 +02:00
}
if( player.isSneaking() )
{
int grids = 0;
int totalNodes = 0;
for( final Grid g : TickHandler.INSTANCE.getGridList() )
{
grids++;
2014-01-23 17:28:12 +01:00
totalNodes += g.getNodes().size();
}
2014-01-23 17:28:12 +01:00
2014-12-29 15:13:47 +01:00
this.outputMsg( player, "Grids: " + grids );
this.outputMsg( player, "Total Nodes: " + totalNodes );
}
else
{
final TileEntity te = world.getTileEntity( x, y, z );
if( te instanceof IGridHost )
{
final GridNode node = (GridNode) ( (IGridHost) te ).getGridNode( ForgeDirection.getOrientation( side ) );
if( node != null )
{
final Grid g = node.getInternalGrid();
final IGridNode center = g.getPivot();
2014-12-29 15:13:47 +01:00
this.outputMsg( player, "This Node: " + node.toString() );
this.outputMsg( player, "Center Node: " + center.toString() );
2015-02-03 12:04:13 +01:00
final IPathingGrid pg = g.getCache( IPathingGrid.class );
if( pg.getControllerState() == ControllerState.CONTROLLER_ONLINE )
{
2015-02-03 12:04:13 +01:00
Set<IGridNode> next = new HashSet<IGridNode>();
next.add( node );
2015-02-03 12:04:13 +01:00
final int maxLength = 10000;
2015-02-03 12:04:13 +01:00
2015-09-25 22:52:41 +02:00
int length = 0;
outer:
while( !next.isEmpty() )
{
final Iterable<IGridNode> current = next;
2014-09-28 22:20:14 +02:00
next = new HashSet<IGridNode>();
2015-02-03 12:04:13 +01:00
for( final IGridNode n : current )
{
if( n.getMachine() instanceof TileController )
2015-04-29 02:30:53 +02:00
{
break outer;
2015-04-29 02:30:53 +02:00
}
2015-02-03 12:04:13 +01:00
for( final IGridConnection c : n.getConnections() )
2015-04-29 02:30:53 +02:00
{
next.add( c.getOtherSide( n ) );
2015-04-29 02:30:53 +02:00
}
}
2015-02-03 12:04:13 +01:00
length++;
2015-02-03 12:04:13 +01:00
if( length > maxLength )
2015-04-29 02:30:53 +02:00
{
break;
2015-04-29 02:30:53 +02:00
}
}
2015-02-03 12:04:13 +01:00
2014-12-29 15:13:47 +01:00
this.outputMsg( player, "Cable Distance: " + length );
}
2015-02-03 12:04:13 +01:00
if( center.getMachine() instanceof PartP2PTunnel )
2014-01-22 05:52:48 +01:00
{
this.outputMsg( player, "Freq: " + ( (PartP2PTunnel) center.getMachine() ).freq );
2014-01-22 05:52:48 +01:00
}
final TickManagerCache tmc = g.getCache( ITickManager.class );
for( final Class<? extends IGridHost> c : g.getMachineClasses() )
{
int o = 0;
long nanos = 0;
for( final IGridNode oj : g.getMachines( c ) )
{
o++;
nanos += tmc.getAvgNanoTime( oj );
}
if( nanos < 0 )
{
2014-12-29 15:13:47 +01:00
this.outputMsg( player, c.getSimpleName() + " - " + o );
}
else
{
2014-12-29 15:13:47 +01:00
this.outputMsg( player, c.getSimpleName() + " - " + o + "; " + this.timeMeasurement( nanos ) );
}
}
}
else
2015-04-29 02:30:53 +02:00
{
2014-12-29 15:13:47 +01:00
this.outputMsg( player, "No Node Available." );
2015-04-29 02:30:53 +02:00
}
}
else
2015-04-29 02:30:53 +02:00
{
2014-12-29 15:13:47 +01:00
this.outputMsg( player, "Not Networked Block" );
2015-04-29 02:30:53 +02:00
}
if( te instanceof IPartHost )
{
final IPart center = ( (IPartHost) te ).getPart( ForgeDirection.UNKNOWN );
( (IPartHost) te ).markForUpdate();
if( center != null )
{
final GridNode n = (GridNode) center.getGridNode();
2014-12-29 15:13:47 +01:00
this.outputMsg( player, "Node Channels: " + n.usedChannels() );
for( final IGridConnection gc : n.getConnections() )
{
final ForgeDirection fd = gc.getDirection( n );
if( fd != ForgeDirection.UNKNOWN )
2015-04-29 02:30:53 +02:00
{
2014-12-29 15:13:47 +01:00
this.outputMsg( player, fd.toString() + ": " + gc.getUsedChannels() );
2015-04-29 02:30:53 +02:00
}
}
}
}
if( te instanceof IAEPowerStorage )
{
final IAEPowerStorage ps = (IAEPowerStorage) te;
2014-12-29 15:13:47 +01:00
this.outputMsg( player, "Energy: " + ps.getAECurrentPower() + " / " + ps.getAEMaxPower() );
if( te instanceof IGridHost )
{
final IGridNode node = ( (IGridHost) te ).getGridNode( ForgeDirection.getOrientation( side ) );
if( node != null && node.getGrid() != null )
{
final IEnergyGrid eg = node.getGrid().getCache( IEnergyGrid.class );
2014-12-29 15:13:47 +01:00
this.outputMsg( player, "GridEnergy: " + eg.getStoredPower() + " : " + eg.getEnergyDemand( Double.MAX_VALUE ) );
}
}
}
}
return true;
}
private void outputMsg( final ICommandSender player, final String string )
{
2014-02-09 02:34:52 +01:00
player.addChatMessage( new ChatComponentText( string ) );
}
public String timeMeasurement( final long nanos )
{
final long ms = nanos / 100000;
if( nanos <= 100000 )
2015-04-29 02:30:53 +02:00
{
return nanos + "ns";
2015-04-29 02:30:53 +02:00
}
return ( ms / 10.0f ) + "ms";
}
}