X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2FParser.java;h=18bec5a0aebfa2c5179116f1c92617f1162dd04b;hp=db08afcd22c0afadd2671761384d5a29efcce848;hb=21da21b94e794fa4d7c7207327764895d92ea528;hpb=a22c5074e705e3ffcf03e9f9d174aed8ef79fc91 diff --git a/src/edu/berkeley/sbp/Parser.java b/src/edu/berkeley/sbp/Parser.java index db08afc..18bec5a 100644 --- a/src/edu/berkeley/sbp/Parser.java +++ b/src/edu/berkeley/sbp/Parser.java @@ -12,7 +12,7 @@ public abstract class Parser { /** create a parser to parse the grammar with start symbol u */ protected Parser(Union u) { this.pt = new Table(u, top()); } - //protected Parser(Table pt) { this.pt = pt; } + protected Parser(Table pt) { this.pt = pt; } /** implement this method to create the output forest corresponding to a lone shifted input token */ public abstract Forest shiftedToken(T t, Token.Location loc); @@ -20,17 +20,6 @@ public abstract class Parser { /** this method must return an empty topology of the input token type */ public abstract Topology top(); - /** parse input for a exactly one unique result, throwing Ambiguous if not unique or ParseFailed if none */ - public Tree parse1(Token.Stream input) throws IOException, ParseFailed, Ambiguous { - Forest ret = parse(input); - try { return ret.expand1(); } - catch (Ambiguous a) { - System.out.println("while expanding:"); - System.out.println(ret); - throw a; - } - } - /** parse input, using the table pt to drive the parser */ public Forest parse(Token.Stream input) throws IOException, ParseFailed { GSS gss = new GSS(); @@ -48,10 +37,6 @@ public abstract class Parser { current = next; } } - - - // Exceptions ////////////////////////////////////////////////////////////////////////////// - // Table ////////////////////////////////////////////////////////////////////////////// @@ -60,8 +45,6 @@ public abstract class Parser { public final Walk.Cache cache = this; - public HashMapBag byPosition = new HashMapBag(); - private void walk(Element e, HashSet hs) { if (e==null) return; if (hs.contains(e)) return; @@ -95,7 +78,7 @@ public abstract class Parser { HashSet all_elements = new HashSet(); walk(start0, all_elements); for(Element e : all_elements) - cache.ys.put(e, new Walk.YieldSet(e, cache).walk()); + cache.ys.addAll(e, new Walk.YieldSet(e, cache).walk()); HashSet hp = new HashSet(); reachable(start0, hp); this.start = new State(hp, all_states, all_elements); @@ -108,7 +91,7 @@ public abstract class Parser { if (start0.contains(p.owner()) && p.next()==null) state.accept = true; - if (p.isRightNullable(cache)) { + if (isRightNullable(p)) { Walk.Follow wf = new Walk.Follow(top.empty(), p.owner(), all_elements, cache); Reduction red = new Reduction(p); @@ -138,6 +121,12 @@ public abstract class Parser { } } + private boolean isRightNullable(Position p) { + if (p.isLast()) return true; + if (!p.element().possiblyEpsilon(this)) return false; + return isRightNullable(p.next()); + } + /** a single state in the LR table and the transitions possible from it */ public class State implements Comparable, IntegerMappable, Iterable { @@ -235,7 +224,6 @@ public abstract class Parser { // register ourselves in the all_states hash so that no // two states are ever created with an identical position set all_states.put(hs, this); - for(Position p : hs) byPosition.add(p,this); // Step 1a: examine all Position's in this state and compute the mappings from // sets of follow tokens (tokens which could follow this position) to sets @@ -268,27 +256,14 @@ public abstract class Parser { // "yields" [in one or more step] is used instead of "produces" [in exactly one step] // to avoid having to iteratively construct our set of States as shown in most // expositions of the algorithm (ie "keep doing XYZ until things stop changing"). - /* - for(Element e : all_elements) { - if (e instanceof Atom) continue; - HashSet h = new Walk.Closure(null, g.cache).closure(e, hs); - State s = all_states.get(h) == null ? new State(h, all_states, all_elements) : all_states.get(h); - if (gotoSetNonTerminals.get(e) != null) - throw new Error("this should not happen"); - gotoSetNonTerminals.put(e, s); - } - */ HashMapBag move = new HashMapBag(); for(Position p : hs) { Element e = p.element(); if (e==null) continue; - HashSet ys = cache.ys.get(e); - if (ys != null) { - for(Element y : ys) { - HashSet hp = new HashSet(); - reachable(p.next(), hp); - move.addAll(y, hp); - } + for(Element y : cache.ys.getAll(e)) { + HashSet hp = new HashSet(); + reachable(p.next(), hp); + move.addAll(y, hp); } } for(Element y : move) {