diff options
| author | Benjamin J. Culkin <bjculkin@mix.wvu.edu> | 2017-08-16 14:01:34 -0300 |
|---|---|---|
| committer | Benjamin J. Culkin <bjculkin@mix.wvu.edu> | 2017-08-16 14:01:34 -0300 |
| commit | b1c95d0a74708ee229b0f18634e19659e87953ad (patch) | |
| tree | af59395e6401841f0aa5d42930db38098ac0cb03 /dice-lang/src | |
| parent | c74cb8eaf454d9243b75e3770001d8d128356b28 (diff) | |
Allow SCL to run seperately
Diffstat (limited to 'dice-lang/src')
| -rw-r--r-- | dice-lang/src/bjc/dicelang/scl/StreamControlConsole.java | 45 | ||||
| -rw-r--r-- | dice-lang/src/bjc/dicelang/scl/StreamEngine.java | 7 |
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; |
