summaryrefslogtreecommitdiff
path: root/dice-lang/src
diff options
context:
space:
mode:
authorBenjamin J. Culkin <bjculkin@mix.wvu.edu>2017-08-16 14:01:34 -0300
committerBenjamin J. Culkin <bjculkin@mix.wvu.edu>2017-08-16 14:01:34 -0300
commitb1c95d0a74708ee229b0f18634e19659e87953ad (patch)
treeaf59395e6401841f0aa5d42930db38098ac0cb03 /dice-lang/src
parentc74cb8eaf454d9243b75e3770001d8d128356b28 (diff)
Allow SCL to run seperately
Diffstat (limited to 'dice-lang/src')
-rw-r--r--dice-lang/src/bjc/dicelang/scl/StreamControlConsole.java45
-rw-r--r--dice-lang/src/bjc/dicelang/scl/StreamEngine.java7
2 files changed, 52 insertions, 0 deletions
diff --git a/dice-lang/src/bjc/dicelang/scl/StreamControlConsole.java b/dice-lang/src/bjc/dicelang/scl/StreamControlConsole.java
new file mode 100644
index 0000000..8c71770
--- /dev/null
+++ b/dice-lang/src/bjc/dicelang/scl/StreamControlConsole.java
@@ -0,0 +1,45 @@
+package bjc.dicelang.scl;
+
+import bjc.utils.funcdata.FunctionalList;
+import bjc.utils.funcdata.IList;
+
+import java.util.Scanner;
+
+public class StreamControlConsole {
+ public static void main(String[] args) {
+ /*
+ * We're not using the DiceLangEngine in the streams yet.
+ */
+ StreamEngine sengine = new StreamEngine(null);
+
+ StreamControlEngine sclengine = new StreamControlEngine(sengine);
+
+ Scanner scn = new Scanner(System.in);
+
+ System.out.print("Enter a SCL command string (blank to exit): ");
+
+ while(scn.hasNextLine()) {
+ String ln = scn.nextLine();
+
+ if(ln.trim().equals("")) break;
+
+ IList<String> res = new FunctionalList<>();
+
+ String[] tokens = ln.split(" ");
+
+ boolean succ = sengine.doStreams(tokens, res);
+
+ if(!succ) continue;
+
+ tokens = res.toArray(new String[res.getSize()]);
+
+ succ = sclengine.runProgram(tokens);
+
+ if(!succ) continue;
+
+ System.out.print("Command string executed succesfully.\n\n");
+
+ System.out.print("Enter a SCL command string (blank to exit): ");
+ }
+ }
+}
diff --git a/dice-lang/src/bjc/dicelang/scl/StreamEngine.java b/dice-lang/src/bjc/dicelang/scl/StreamEngine.java
index f1abbdc..fded5f1 100644
--- a/dice-lang/src/bjc/dicelang/scl/StreamEngine.java
+++ b/dice-lang/src/bjc/dicelang/scl/StreamEngine.java
@@ -4,6 +4,8 @@ import static bjc.dicelang.Errors.ErrorKey.EK_STRM_INVCOM;
import static bjc.dicelang.Errors.ErrorKey.EK_STRM_LAST;
import static bjc.dicelang.Errors.ErrorKey.EK_STRM_NONEX;
+import static java.util.logging.Level.*;
+
import bjc.dicelang.DiceLangEngine;
import bjc.dicelang.Errors;
import bjc.utils.esodata.SingleTape;
@@ -24,6 +26,11 @@ import bjc.utils.funcutils.ListUtils;
*/
public class StreamEngine {
/*
+ * Whether or not we're doing debugging.
+ */
+ public final boolean debug = true;
+
+ /*
* The engine we're attached to.
*/
DiceLangEngine eng;