|  | package li.cil.oc.common.tileentity | 
|  |  | 
|  | import li.cil.oc.api.network.{Arguments, Callback, Context, Visibility} | 
|  | import li.cil.oc.{Settings, api} | 
|  | import net.minecraft.block.{Block, BlockFluid} | 
|  | import net.minecraftforge.fluids.FluidRegistry | 
|  |  | 
|  | class Geolyzer extends traits.Environment { | 
|  | val node = api.Network.newNode(this, Visibility.Network). | 
|  | withComponent("geolyzer"). | 
|  | withConnector(). | 
|  | create() | 
|  |  | 
|  | override def canUpdate = false | 
|  |  | 
|  | @Callback(doc = """function(x:number, z:number[, ignoreReplaceable:boolean]):table -- Analyzes the density of the column at the specified relative coordinates.""") | 
|  | def scan(computer: Context, args: Arguments): Array[AnyRef] = { | 
|  | val rx = args.checkInteger(0) | 
|  | val rz = args.checkInteger(1) | 
|  | val includeReplaceable = !(args.count > 2 && args.checkBoolean(2)) | 
|  | if (math.abs(rx) > Settings.get.geolyzerRange || math.abs(rz) > Settings.get.geolyzerRange) { | 
|  | throw new IllegalArgumentException("location out of bounds") | 
|  | } | 
|  | val bx = x + rx | 
|  | val bz = z + rz | 
|  |  | 
|  | if (!node.tryChangeBuffer(-Settings.get.geolyzerScanCost)) | 
|  | return result(Unit, "not enough energy") | 
|  |  | 
|  | val count = 64 | 
|  | val noise = new Array[Byte](count) | 
|  | world.rand.nextBytes(noise) | 
|  | // Map to [-1, 1). The additional /33f is for normalization below. | 
|  | val values = noise.map(_ / 128f / 33f) | 
|  | for (ry <- 0 until count) { | 
|  | val by = y + ry - 32 | 
|  | val blockId = world.getBlockId(bx, by, bz) | 
|  | if (blockId > 0 && !world.isAirBlock(bx, by, bz)) { | 
|  | val block = Block.blocksList(blockId) | 
|  | if (block != null && (includeReplaceable || isFluid(block) || !block.isBlockReplaceable(world, x, y, z))) { | 
|  | values(ry) = values(ry) * (math.abs(ry - 32) + 1) * Settings.get.geolyzerNoise + block.getBlockHardness(world, bx, by, bz) | 
|  | } | 
|  | } | 
|  | else values(ry) = 0 | 
|  | } | 
|  |  | 
|  | result(values) | 
|  | } | 
|  |  | 
|  | private def isFluid(block: Block) = FluidRegistry.lookupFluidForBlock(block) != null || block.isInstanceOf[BlockFluid] | 
|  | } |