Fixed LUA property implementation (removing exceptions)
Tentative fix for #250
This commit is contained in:
parent
e20990dd5d
commit
c74c1d3d46
3 changed files with 79 additions and 58 deletions
|
@ -129,7 +129,7 @@ public class TileEntityAcceleratorControlPoint extends TileEntityAbstractInterfa
|
|||
// OpenComputer callback methods
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] enable(Context context, Arguments arguments) throws Exception {
|
||||
public Object[] enable(Context context, Arguments arguments) {
|
||||
return enable(argumentsOCtoCC(arguments));
|
||||
}
|
||||
|
||||
|
@ -149,13 +149,16 @@ public class TileEntityAcceleratorControlPoint extends TileEntityAbstractInterfa
|
|||
}
|
||||
|
||||
// Common OC/CC methods
|
||||
public Object[] enable(Object[] arguments) throws Exception {
|
||||
public Object[] enable(Object[] arguments) {
|
||||
if (arguments.length == 1) {
|
||||
boolean enable;
|
||||
try {
|
||||
enable = Commons.toBool(arguments[0]);
|
||||
} catch (Exception exception) {
|
||||
throw new Exception("Function expects a boolean value");
|
||||
if (WarpDriveConfig.LOGGING_LUA) {
|
||||
WarpDrive.logger.error(this + " LUA error on enable(): Boolean expected for 1st argument " + arguments[0]);
|
||||
}
|
||||
return new Object[] { isEnabled };
|
||||
}
|
||||
isEnabled = enable;
|
||||
}
|
||||
|
|
|
@ -306,17 +306,47 @@ public class TileEntityEnanReactorCore extends TileEntityAbstractEnergy {
|
|||
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] active(Context context, Arguments arguments) throws Exception {
|
||||
public Object[] active(Context context, Arguments arguments) {
|
||||
return active(argumentsOCtoCC(arguments));
|
||||
}
|
||||
|
||||
private Object[] active(Object[] arguments) throws Exception {
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] release(Context context, Arguments arguments) {
|
||||
return release(argumentsOCtoCC(arguments));
|
||||
}
|
||||
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] releaseRate(Context context, Arguments arguments) {
|
||||
return releaseRate(argumentsOCtoCC(arguments));
|
||||
}
|
||||
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] releaseAbove(Context context, Arguments arguments) {
|
||||
return releaseAbove(argumentsOCtoCC(arguments));
|
||||
}
|
||||
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] instability(Context context, Arguments arguments) {
|
||||
// computer is alive => start updating reactor
|
||||
hold = false;
|
||||
return new Double[] { instabilityValues[0], instabilityValues[1], instabilityValues[2], instabilityValues[3] };
|
||||
}
|
||||
|
||||
// Common OC/CC methods
|
||||
private Object[] active(Object[] arguments) {
|
||||
if (arguments.length == 1) {
|
||||
boolean activate;
|
||||
try {
|
||||
activate = Commons.toBool(arguments[0]);
|
||||
} catch (Exception exception) {
|
||||
throw new Exception("Function expects a boolean value");
|
||||
if (WarpDriveConfig.LOGGING_LUA) {
|
||||
WarpDrive.logger.error(this + " LUA error on active(): Boolean expected for 1st argument " + arguments[0]);
|
||||
}
|
||||
return active(new Object[0]);
|
||||
}
|
||||
if (active && !activate) {
|
||||
sendEvent("reactorDeactivation");
|
||||
|
@ -334,19 +364,16 @@ public class TileEntityEnanReactorCore extends TileEntityAbstractEnergy {
|
|||
}
|
||||
}
|
||||
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] release(Context context, Arguments arguments) throws Exception {
|
||||
return release(argumentsOCtoCC(arguments));
|
||||
}
|
||||
|
||||
private Object[] release(Object[] arguments) throws Exception {
|
||||
boolean doRelease;
|
||||
if (arguments.length > 0) {
|
||||
private Object[] release(Object[] arguments) {
|
||||
if (arguments.length == 1) {
|
||||
boolean doRelease;
|
||||
try {
|
||||
doRelease = Commons.toBool(arguments[0]);
|
||||
} catch (Exception exception) {
|
||||
throw new Exception("Function expects a boolean value");
|
||||
if (WarpDriveConfig.LOGGING_LUA) {
|
||||
WarpDrive.logger.error(this + " LUA error on release(): Boolean expected for 1st argument " + arguments[0]);
|
||||
}
|
||||
return new Object[] { releaseMode != MODE_DONT_RELEASE };
|
||||
}
|
||||
|
||||
releaseMode = doRelease ? MODE_MANUAL_RELEASE : MODE_DONT_RELEASE;
|
||||
|
@ -356,44 +383,39 @@ public class TileEntityEnanReactorCore extends TileEntityAbstractEnergy {
|
|||
return new Object[] { releaseMode != MODE_DONT_RELEASE };
|
||||
}
|
||||
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] releaseRate(Context context, Arguments arguments) throws Exception {
|
||||
return releaseRate(argumentsOCtoCC(arguments));
|
||||
}
|
||||
private Object[] releaseRate(Object[] arguments) {
|
||||
if (arguments.length == 1) {
|
||||
int rate;
|
||||
try {
|
||||
rate = Commons.toInt(arguments[0]);
|
||||
} catch (Exception exception) {
|
||||
if (WarpDriveConfig.LOGGING_LUA) {
|
||||
WarpDrive.logger.error(this + " LUA error on releaseRate(): Integer expected for 1st argument " + arguments[0]);
|
||||
}
|
||||
return new Object[] { MODE_STRING[releaseMode], releaseRate };
|
||||
}
|
||||
|
||||
private Object[] releaseRate(Object[] arguments) throws Exception {
|
||||
int rate;
|
||||
try {
|
||||
rate = Commons.toInt(arguments[0]);
|
||||
} catch (Exception exception) {
|
||||
throw new Exception("Function expects an integer value");
|
||||
if (rate <= 0) {
|
||||
releaseMode = MODE_DONT_RELEASE;
|
||||
releaseRate = 0;
|
||||
} else {
|
||||
// player has to adjust it
|
||||
releaseRate = rate;
|
||||
releaseMode = MODE_RELEASE_AT_RATE;
|
||||
}
|
||||
}
|
||||
|
||||
if (rate <= 0) {
|
||||
releaseMode = MODE_DONT_RELEASE;
|
||||
releaseRate = 0;
|
||||
} else {
|
||||
// player has to adjust it
|
||||
releaseRate = rate;
|
||||
releaseMode = MODE_RELEASE_AT_RATE;
|
||||
}
|
||||
|
||||
return new Object[] { MODE_STRING[releaseMode], releaseRate };
|
||||
}
|
||||
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] releaseAbove(Context context, Arguments arguments) throws Exception {
|
||||
return releaseAbove(argumentsOCtoCC(arguments));
|
||||
}
|
||||
|
||||
private Object[] releaseAbove(Object[] arguments) throws Exception {
|
||||
private Object[] releaseAbove(Object[] arguments) {
|
||||
int above;
|
||||
try {
|
||||
above = Commons.toInt(arguments[0]);
|
||||
} catch (Exception exception) {
|
||||
throw new Exception("Function expects an integer value");
|
||||
if (WarpDriveConfig.LOGGING_LUA) {
|
||||
WarpDrive.logger.error(this + " LUA error on releaseAbove(): Integer expected for 1st argument " + arguments[0]);
|
||||
}
|
||||
return new Object[] { MODE_STRING[releaseMode], releaseAbove };
|
||||
}
|
||||
|
||||
if (above <= 0) {
|
||||
|
@ -407,14 +429,6 @@ public class TileEntityEnanReactorCore extends TileEntityAbstractEnergy {
|
|||
return new Object[] { MODE_STRING[releaseMode], releaseAbove };
|
||||
}
|
||||
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] instability(Context context, Arguments arguments) throws Exception {
|
||||
// computer is alive => start updating reactor
|
||||
hold = false;
|
||||
return new Double[] { instabilityValues[0], instabilityValues[1], instabilityValues[2], instabilityValues[3] };
|
||||
}
|
||||
|
||||
// ComputerCraft IPeripheral methods implementation
|
||||
@Override
|
||||
@Optional.Method(modid = "ComputerCraft")
|
||||
|
@ -422,7 +436,7 @@ public class TileEntityEnanReactorCore extends TileEntityAbstractEnergy {
|
|||
// computer is alive => start updating reactor
|
||||
hold = false;
|
||||
|
||||
String methodName = getMethodName(method);
|
||||
final String methodName = getMethodName(method);
|
||||
|
||||
try {
|
||||
switch (methodName) {
|
||||
|
|
|
@ -153,7 +153,7 @@ public class TileEntityAbstractForceField extends TileEntityAbstractEnergy imple
|
|||
// OpenComputer callback methods
|
||||
@Callback
|
||||
@Optional.Method(modid = "OpenComputers")
|
||||
public Object[] enable(Context context, Arguments arguments) throws Exception {
|
||||
public Object[] enable(Context context, Arguments arguments) {
|
||||
return enable(argumentsOCtoCC(arguments));
|
||||
}
|
||||
|
||||
|
@ -166,13 +166,17 @@ public class TileEntityAbstractForceField extends TileEntityAbstractEnergy imple
|
|||
return new Integer[] { beamFrequency };
|
||||
}
|
||||
|
||||
public Object[] enable(Object[] arguments) throws Exception {
|
||||
// Common OC/CC methods
|
||||
public Object[] enable(Object[] arguments) {
|
||||
if (arguments.length == 1) {
|
||||
boolean enable;
|
||||
try {
|
||||
enable = Commons.toBool(arguments[0]);
|
||||
} catch (Exception exception) {
|
||||
throw new Exception("Function expects a boolean value");
|
||||
if (WarpDriveConfig.LOGGING_LUA) {
|
||||
WarpDrive.logger.error(this + " LUA error on enable(): Boolean expected for 1st argument " + arguments[0]);
|
||||
}
|
||||
return new Object[] { isEnabled };
|
||||
}
|
||||
isEnabled = enable;
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue