blob: 6b4054b2bea4ba38b1fddcc27498a6d223116c12 [file] [log] [blame] [raw]
package li.cil.oc.common.item
import cpw.mods.fml.common.network.Player
import li.cil.oc.Config
import li.cil.oc.api.network._
import li.cil.oc.server.PacketSender
import net.minecraft.client.renderer.texture.IconRegister
import net.minecraft.entity.player.EntityPlayer
import net.minecraft.item.ItemStack
import net.minecraft.nbt.NBTTagCompound
import net.minecraft.world.World
import net.minecraftforge.common.ForgeDirection
import java.util
class Analyzer(val parent: Delegator) extends Delegate {
val unlocalizedName = "Analyzer"
override def addInformation(item: ItemStack, player: EntityPlayer, tooltip: util.List[String], advanced: Boolean) {
tooltip.add("Used to display information about blocks,")
tooltip.add("such as their address and component name.")
tooltip.add("Also displays the error that caused a computer")
tooltip.add("to crash if it did not shut down normally.")
}
override def onItemUse(item: ItemStack, player: EntityPlayer, world: World, x: Int, y: Int, z: Int, side: Int, hitX: Float, hitY: Float, hitZ: Float) = {
world.getBlockTileEntity(x, y, z) match {
case analyzable: Analyzable =>
val stats = new NBTTagCompound()
if (!world.isRemote) {
analyzeNode(stats, analyzable.onAnalyze(stats, player, side, hitX, hitY, hitZ), player)
}
true
case host: SidedEnvironment =>
if (!world.isRemote) {
analyzeNode(new NBTTagCompound(), host.sidedNode(ForgeDirection.getOrientation(side)), player)
}
true
case host: Environment =>
if (!world.isRemote) {
analyzeNode(new NBTTagCompound(), host.node, player)
}
true
case _ => super.onItemUse(item, player, world, x, y, z, side, hitX, hitY, hitZ)
}
}
private def analyzeNode(stats: NBTTagCompound, node: Node, player: EntityPlayer) = if (node != null) {
node match {
case connector: Connector if connector.localBufferSize > 0 => stats.setString(Config.namespace + "text.Analyzer.StoredEnergy", "%.2f/%.2f".format(connector.localBuffer, connector.localBufferSize))
case _ =>
}
node match {
case component: Component => stats.setString(Config.namespace + "text.Analyzer.ComponentName", component.name)
case _ =>
}
val address = node.address()
stats.setString(Config.namespace + "text.Analyzer.Address", address)
PacketSender.sendAnalyze(stats, address, player.asInstanceOf[Player])
}
override def registerIcons(iconRegister: IconRegister) {
super.registerIcons(iconRegister)
icon = iconRegister.registerIcon(Config.resourceDomain + ":analyzer")
}
}