From 41c2a41eaf3c2dd158a2a51947180f402918229e Mon Sep 17 00:00:00 2001 From: bjculkin Date: Fri, 24 Mar 2017 09:54:17 -0400 Subject: Implement Pratt parser. --- .../utils/parserutils/pratt/StringTokenStream.java | 44 ++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 BJC-Utils2/src/main/java/bjc/utils/parserutils/pratt/StringTokenStream.java (limited to 'BJC-Utils2/src/main/java/bjc/utils/parserutils/pratt/StringTokenStream.java') 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 { + 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 void next() { + if(iter.hasNext()) { + curr = iter.next(); + } else { + curr = new StringToken("(end)", null); + } + } +} -- cgit v1.2.3