Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion dependencies.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ dependencies {

api("com.github.GTNewHorizons:AE2FluidCraft-Rework:1.5.39-gtnh:dev")
compileOnly("com.github.GTNewHorizons:Angelica:1.0.0-beta68a:api") {transitive = false}
api("com.github.GTNewHorizons:Applied-Energistics-2-Unofficial:rv3-betea-777-GTNH:dev")
api("com.github.GTNewHorizons:Applied-Energistics-2-Unofficial:rv3-beta-777-GTNH:dev")
compileOnly("com.github.GTNewHorizons:Avaritiaddons:1.9.3-GTNH:dev") {transitive = false}
compileOnly("com.github.GTNewHorizons:BloodMagic:1.8.8:dev") {transitive = false}
compileOnly("com.github.GTNewHorizons:BuildCraft:7.1.48:dev") {transitive = false}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

import com.gtnewhorizon.gtnhlib.capability.Capabilities;
import gregtech.api.interfaces.tileentity.IBasicEnergyContainer;
import li.cil.oc.api.driver.NamedBlock;
import li.cil.oc.api.machine.Arguments;
import li.cil.oc.api.machine.Callback;
import li.cil.oc.api.machine.Context;
Expand All @@ -23,7 +24,18 @@ public ManagedEnvironment createEnvironment(
return new Environment(Capabilities.getCapability(world.getTileEntity(x, y, z), IBasicEnergyContainer.class, side));
}

public static final class Environment extends ManagedTileEntityEnvironment<IBasicEnergyContainer> {
public static final class Environment extends ManagedTileEntityEnvironment<IBasicEnergyContainer> implements NamedBlock {

@Override
public String preferredName() {
return "gt_energyContainer";
}

@Override
public int priority() {
return -1;
}

public Environment(final IBasicEnergyContainer tileEntity) {
super(tileEntity, "gt_energyContainer");
}
Expand Down
43 changes: 43 additions & 0 deletions src/main/scala/li/cil/oc/integration/gregtech/DriverLSC.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
package li.cil.oc.integration.gregtech

import gregtech.api.interfaces.tileentity.IGregTechTileEntity
import kekztech.common.tileentities.MTELapotronicSuperCapacitor
import li.cil.oc.api.driver.{NamedBlock, SidedBlock}
import li.cil.oc.api.machine.{Arguments, Callback, Context}
import li.cil.oc.api.network.ManagedEnvironment
import li.cil.oc.integration.ManagedTileEntityEnvironment
import li.cil.oc.util.ResultWrapper.result
import net.minecraft.world.World
import net.minecraftforge.common.util.ForgeDirection

object DriverLSC extends SidedBlock {
override def worksWith(world: World, x: Int, y: Int, z: Int, side: ForgeDirection): Boolean = {
world.getTileEntity(x, y, z) match {
case tile: IGregTechTileEntity => tile.getMetaTileEntity.isInstanceOf[MTELapotronicSuperCapacitor]
case _ => false
}
}

override def createEnvironment(world: World, x: Int, y: Int, z: Int, side: ForgeDirection): ManagedEnvironment = {
val tile = world.getTileEntity(x, y, z).asInstanceOf[IGregTechTileEntity]
new Environment(tile.getMetaTileEntity.asInstanceOf[MTELapotronicSuperCapacitor])
}

final class Environment(tile: MTELapotronicSuperCapacitor) extends ManagedTileEntityEnvironment[MTELapotronicSuperCapacitor](tile, "LSC") with NamedBlock {
override def preferredName(): String = "LSC"

override def priority(): Int = 0

@Callback(doc = "function():number -- Returns the amount of electricity contained in this Block, in EU units! NOTE: Value is clamped to Long.MaxValue to prevent overflow.")
def getStoredEU(context: Context, args: Arguments): Array[AnyRef] = result(tileEntity.getEUVar)

@Callback(doc = "function():string -- Returns the amount of electricity contained in this Block, in EU units! (As a string for HUGE amounts.)")
def getStoredEUString(context: Context, args: Arguments) = Array[AnyRef](tileEntity.getStored.toString)

@Callback(doc = "function():number -- Returns the amount of electricity containable in this Block, in EU units! NOTE: Value is clamped to Long.MaxValue to prevent overflow.")
def getEUCapacity(context: Context, args: Arguments): Array[AnyRef] = result(tileEntity.maxEUStore)

@Callback(doc = "function():number -- Returns the amount of electricity containable in this Block, in EU units! (As a string for HUGE amounts.)")
def getEUCapacityString(context: Context, args: Arguments) = Array[AnyRef](tileEntity.getEnergyCapacity.toString)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ object ModGregtech extends ModProxy {
MinecraftForge.EVENT_BUS.register(EventHandlerGregTech)

Driver.add(new DriverEnergyContainer)
Driver.add(DriverLSC)
Driver.add(new ConverterDataStick)

RecipeHandler.init()
Expand Down
Loading