From 5681a099c04138c8cbd30fa3a17b933ab60ae906 Mon Sep 17 00:00:00 2001 From: Unknown Date: Sat, 6 Apr 2019 12:34:29 +0200 Subject: [PATCH] Added explicit exception handler to CC LUA methods --- .../block/TileEntityAbstractInterfaced.java | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/main/java/cr0s/warpdrive/block/TileEntityAbstractInterfaced.java b/src/main/java/cr0s/warpdrive/block/TileEntityAbstractInterfaced.java index d0d50226..2adbab5c 100644 --- a/src/main/java/cr0s/warpdrive/block/TileEntityAbstractInterfaced.java +++ b/src/main/java/cr0s/warpdrive/block/TileEntityAbstractInterfaced.java @@ -425,9 +425,16 @@ public abstract class TileEntityAbstractInterfaced extends TileEntityAbstractBas final int method, @Nonnull final Object[] arguments) { final String methodName = CC_getMethodNameAndLogCall(computerAccess, method, arguments); - // we separate the proxy from the logs so childs can override the proxy without having to handle the logs themselves - return CC_callMethod(methodName, arguments); - + // we separate the proxy from the logs so children can override the proxy without having to handle the logs themselves + try { + return CC_callMethod(methodName, arguments); + } catch (final Exception exception) { + if (WarpDriveConfig.LOGGING_LUA) { + exception.printStackTrace(); + } + throw new RuntimeException(String.format("LUA handling exception in %s\nEnable LUA logs for details.", + methodName)); + } } @Optional.Method(modid = "computercraft")