X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2Fmeta%2FGrammarAST.java;h=19f12a32981f5882b51f208b0219372c46d8b53e;hp=997d0b6230b1f06fc05ec4fd5742c86aaa3aef10;hb=584cef55d8811e3215858fde22e708d2a3d1cf70;hpb=eeb3a8b49bdbf753b5a70734fbae7f2c1ac06702 diff --git a/src/edu/berkeley/sbp/meta/GrammarAST.java b/src/edu/berkeley/sbp/meta/GrammarAST.java index 997d0b6..19f12a3 100644 --- a/src/edu/berkeley/sbp/meta/GrammarAST.java +++ b/src/edu/berkeley/sbp/meta/GrammarAST.java @@ -79,26 +79,24 @@ public class GrammarAST { if (head.equals("Word")) return stringifyChildren(t); if (head.equals("Elements")) return seq2((ElementNode[])Reflection.rebuild(walkChildren(t), ElementNode[].class)); if (head.equals("NonTerminalReference")) return new ReferenceNode(stringifyChildren(t.child(0))); - //if (head.equals(")")) return new ReferenceNode(stringifyChildren(t.child(0))); - if (head.equals("{")) return new XTree((Seq)walk(t.child(0))); - if (head.equals("::")) return tag((String)walk(t.child(0)), (Seq)walk(t.child(1))); - if (head.equals("++")) return plusmax((ElementNode)walk(t.child(0))); - if (head.equals("...")) return star(new TildeNode(new AtomNode())); - if (head.equals("+")) return plus((ElementNode)walk(t.child(0))); - if (head.equals("++/")) return plusmaxfollow((ElementNode)walk(t.child(0)), (ElementNode)walk(t.child(1))); - if (head.equals("+/")) return plusfollow((ElementNode)walk(t.child(0)), (ElementNode)walk(t.child(1))); - if (head.equals("**")) return starmax((ElementNode)walk(t.child(0))); - if (head.equals("*")) return star((ElementNode)walk(t.child(0))); - if (head.equals("**/")) return starmaxfollow((ElementNode)walk(t.child(0)), (ElementNode)walk(t.child(1))); - if (head.equals("*/")) return starfollow((ElementNode)walk(t.child(0)), (ElementNode)walk(t.child(1))); - if (head.equals("?")) return question((ElementNode)walk(t.child(0))); - if (head.equals("!")) return new DropNode((ElementNode)walk(t.child(0))); - if (head.equals("^")) return new LiteralNode((String)walk(t.child(0)), true); - if (head.equals("`")) { - ElementNode ret = (ElementNode)walk(t.child(0)); - ret.lifted = true; - return ret; - } + if (head.equals(")")) return new ReferenceNode(stringifyChildren(t.child(0)), true); + if (head.equals("{")) return new BracedNode(walkSeq(t.child(0))); + if (head.equals("::")) return walkSeq(t.child(1)).tag(walkString(t.child(0))); + if (head.equals("...")) return new DropNode(new RepeatNode(new TildeNode(new AtomNode()), null, true, true, false)); + + if (head.equals("++")) return new RepeatNode(walkElement(t.child(0)), null, false, true, true); + if (head.equals("+")) return new RepeatNode(walkElement(t.child(0)), null, false, true, false); + if (head.equals("++/")) return new RepeatNode(walkElement(t.child(0)), walkElement(t.child(1)), false, true, true); + if (head.equals("+/")) return new RepeatNode(walkElement(t.child(0)), walkElement(t.child(1)), false, true, false); + if (head.equals("**")) return new RepeatNode(walkElement(t.child(0)), null, true, true, true); + if (head.equals("*")) return new RepeatNode(walkElement(t.child(0)), null, true, true, false); + if (head.equals("**/")) return new RepeatNode(walkElement(t.child(0)), walkElement(t.child(1)), true, true, true); + if (head.equals("*/")) return new RepeatNode(walkElement(t.child(0)), walkElement(t.child(1)), true, true, false); + if (head.equals("?")) return new RepeatNode(walkElement(t.child(0)), null, true, false, false); + + if (head.equals("!")) return new DropNode(walkElement(t.child(0))); + if (head.equals("^")) return new LiteralNode(walkString(t.child(0)), true); + if (head.equals("`")) return walkElement(t.child(0)).lifted(); if (head.equals("Quoted")) return stringifyChildren(t); if (head.equals("Literal")) return new LiteralNode(walkString(t.child(0))); if (head.equals("->")) return walkSeq(t.child(0)).follow(walkElement(t.child(1))); @@ -198,7 +196,7 @@ public class GrammarAST { public Union build(String rootNonterminal) { Context cx = new Context(this); Union u = null; - for(GrammarBuilder.NonTerminalNode nt : values()) + for(GrammarAST.NonTerminalNode nt : values()) if (nt.name.equals(rootNonterminal)) return (Union)cx.get(nt.name); return null; @@ -347,20 +345,20 @@ public class GrammarAST { els[i] = elements[i].build(cx, cnt, dropall); } if (tag==null && multiNonDrop) - throw new RuntimeException("multiple non-dropped elements in sequence: " + Sequence.create(els, "")); - boolean lift = false; - if (elements.length > 0 && elements[0].lifted) - lift = true; + throw new RuntimeException("multiple non-dropped elements in sequence: " + Sequence.create("", els)); + boolean[] lifts = new boolean[elements.length]; + for(int i=0; i