summaryrefslogtreecommitdiff
path: root/BJC-Utils2/src/main/java/bjc/utils/parserutils/pratt/StringTokenStream.java
diff options
context:
space:
mode:
authorbjculkin <bjculkin@mix.wvu.edu>2017-03-24 09:54:17 -0400
committerbjculkin <bjculkin@mix.wvu.edu>2017-03-24 09:54:17 -0400
commit41c2a41eaf3c2dd158a2a51947180f402918229e (patch)
tree47cbe22f24c7c0898ae9154734973846224332d8 /BJC-Utils2/src/main/java/bjc/utils/parserutils/pratt/StringTokenStream.java
parentb0d27faf67ec23b3d55786e00d4fd3b0d07567ee (diff)
Implement Pratt parser.
Diffstat (limited to 'BJC-Utils2/src/main/java/bjc/utils/parserutils/pratt/StringTokenStream.java')
-rw-r--r--BJC-Utils2/src/main/java/bjc/utils/parserutils/pratt/StringTokenStream.java44
1 files changed, 44 insertions, 0 deletions
diff --git a/BJC-Utils2/src/main/java/bjc/utils/parserutils/pratt/StringTokenStream.java b/BJC-Utils2/src/main/java/bjc/utils/parserutils/pratt/StringTokenStream.java
new file mode 100644
index 0000000..8caeef9
--- /dev/null
+++ b/BJC-Utils2/src/main/java/bjc/utils/parserutils/pratt/StringTokenStream.java
@@ -0,0 +1,44 @@
+package bjc.utils.parserutils.pratt;
+
+import java.util.Iterator;
+
+/**
+ * Simple implementation of token stream for strings.
+ *
+ * The terminal token here is represented by a token with type '(end)' and null
+ * value.
+ *
+ * @author EVE
+ *
+ */
+public class StringTokenStream implements TokenStream<String, String> {
+ private Iterator<Token<String, String>> iter;
+
+ private Token<String, String> curr;
+
+ /**
+ * Create a new token stream from a iterator.
+ *
+ * @param itr
+ * The iterator to use.
+ *
+ */
+ public StringTokenStream(Iterator<Token<String, String>> itr) {
+ iter = itr;
+
+ }
+
+ @Override
+ public Token<String, String> current() {
+ return curr;
+ }
+
+ @Override
+ public void next() {
+ if(iter.hasNext()) {
+ curr = iter.next();
+ } else {
+ curr = new StringToken("(end)", null);
+ }
+ }
+}