From c82452e59b1547392c3e89d08d9173cc6dc79e23 Mon Sep 17 00:00:00 2001 From: bjculkin Date: Wed, 5 Apr 2017 15:35:13 -0400 Subject: Reorganize --- .../java/bjc/pratt/tokens/StringTokenStream.java | 56 ++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 JPratt/src/main/java/bjc/pratt/tokens/StringTokenStream.java (limited to 'JPratt/src/main/java/bjc/pratt/tokens/StringTokenStream.java') diff --git a/JPratt/src/main/java/bjc/pratt/tokens/StringTokenStream.java b/JPratt/src/main/java/bjc/pratt/tokens/StringTokenStream.java new file mode 100644 index 0000000..7f8215a --- /dev/null +++ b/JPratt/src/main/java/bjc/pratt/tokens/StringTokenStream.java @@ -0,0 +1,56 @@ +package bjc.pratt.tokens; + +import bjc.pratt.Token; +import bjc.pratt.TokenStream; + +import java.util.Iterator; + +import static bjc.pratt.tokens.StringToken.litToken; + +/** + * Simple implementation of token stream for strings. + * + * The terminal token here is represented by a token with type and value + * '(end)'. + * + * @author EVE + * + */ +public class StringTokenStream extends TokenStream { + private Iterator> iter; + + private Token curr; + + /** + * Create a new token stream from a iterator. + * + * @param itr + * The iterator to use. + * + */ + public StringTokenStream(Iterator> itr) { + iter = itr; + + } + + @Override + public Token current() { + return curr; + } + + @Override + public Token next() { + if (iter.hasNext()) { + curr = iter.next(); + } else { + curr = litToken("(end)"); + } + + return curr; + } + + @Override + public boolean hasNext() { + return iter.hasNext(); + } +} -- cgit v1.2.3