summaryrefslogtreecommitdiff
path: root/dice-lang/src/bjc
diff options
context:
space:
mode:
Diffstat (limited to 'dice-lang/src/bjc')
-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;