X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2Fmeta%2FMetaGrammarBindings.java;h=2d064223452c9b81e500b1e52ebc62a30490691f;hb=59eead6bf0f2d9a7abeba03f3fdab04625521faf;hp=5168c34746493074c51bf204af98067a19428eea;hpb=b5ae4ceb563fd4d52514ef4f4206c5c2be8140ca;p=sbp.git diff --git a/src/edu/berkeley/sbp/meta/MetaGrammarBindings.java b/src/edu/berkeley/sbp/meta/MetaGrammarBindings.java index 5168c34..2d06422 100644 --- a/src/edu/berkeley/sbp/meta/MetaGrammarBindings.java +++ b/src/edu/berkeley/sbp/meta/MetaGrammarBindings.java @@ -11,6 +11,8 @@ import java.io.*; /** The java classes typically used to represent a parsed grammar AST */ public class MetaGrammarBindings { + + /** A grammar (a set of nonterminals) */ public static class Grammar extends HashMap { public @bind Grammar(NonTerminal[] nonterminals) { for(NonTerminal nt : nonterminals) this.put(nt.name, nt); } @@ -20,6 +22,7 @@ public class MetaGrammarBindings { return ret + " ]"; } } + public abstract static class Un extends El { public Seq[][] sequences; public void build(MetaGrammar.Context cx, Union u) { @@ -42,14 +45,54 @@ public class MetaGrammarBindings { } } } + public static class NonTerminal extends Un { + public boolean rep; public String name = null; - public @bind NonTerminal(@bind.arg String name, - @bind.arg Seq[][] sequences) { + public String sep = null; + public @bind NonTerminal(@bind.arg String name, @bind.arg Seq[][] sequences) { this(name, sequences, false); } + public NonTerminal(String name, Seq[][] sequences, boolean rep) { this(name, sequences, rep, null); } + public NonTerminal(String name, Seq[][] sequences, boolean rep, String sep) { this.name = name; this.sequences = sequences; + this.rep = rep; + this.sep = sep; } public Element build(MetaGrammar.Context cx) { return cx.get(name); } + public void build(MetaGrammar.Context cx, Union u) { + if (!rep) { super.build(cx, u); return; } + HashSet bad2 = new HashSet(); + + Union urep = new Union(); + urep.add(Sequence.empty); + urep.add(Sequence.singleton(new Element[] { cx.get(sep), u }, 1)); + + for(int i=0; i") Seq arrow(Seq s, El e) { return s.follow(e); } public static @bind.as("::") Seq tag(String tagname, Seq s) { return s.tag(tagname); } public static @bind.as("/") Seq slash(Seq s, El e) { return s.separate(e); } - public static @bind.as("ps") Seq seq(El[] elements) { return new Seq(elements); } + public static Seq seq(El[] elements) { return new Seq(elements); } + public static @bind.as("Elements") Seq seq2(El[] elements) { return new Seq(elements); } public static @bind.as Seq psx(Seq s) { return s; } public static @bind.as(":") El colon(String s, El e) { return new Label(s, e); } public static @bind.as(")") void close(String foo) { throw new Error("not supported"); } public static @bind.as("()") El epsilon() { return new Constant(Union.epsilon); } - public static @bind.as("nonTerminal") class NonTerminalReference extends El { + public static @bind class NonTerminalReference extends El { public @bind.arg String nonTerminal; - public Element build(MetaGrammar.Context cx) { - return cx.get(nonTerminal); - } + public Element build(MetaGrammar.Context cx) { return cx.get(nonTerminal); } } - public static class StringLiteral extends Constant { - public @bind.as("literal") StringLiteral(String string) { super(CharRange.string(string)); } + public static class Literal extends Constant { + public @bind Literal(@bind.arg String string) { super(CharRange.string(string)); } public boolean drop() { return true; } } @@ -207,7 +254,17 @@ public class MetaGrammarBindings { public static @bind.as("{") class XTree extends El { public @bind.arg Seq body; public Element build(MetaGrammar.Context cx) { - throw new Error(); + Union u = new Union(); + Sequence s = body.build(cx, u, false); + Union u2 = new Union(); + u2.add(Sequence.singleton(new Element[] { + CharRange.leftBrace, + cx.get("ws"), + u, + cx.get("ws"), + CharRange.rightBrace + }, 2)); + return u2; } } @@ -265,12 +322,12 @@ public class MetaGrammarBindings { //public static @bind.as("(") El subexpression(Seq[][] rhs) { return new NonTerminal(rhs); } - public static @bind.as("Word") String word(String s) { return s; } - public static @bind.as("Quoted") String quoted(String s) { return s; } - public static @bind.as("escaped") String c(char c) { return c+""; } - public static @bind.as("\"\"") String emptystring() { return ""; } - public static @bind.as("\n") String retur() { return "\n"; } - public static @bind.as("\r") String lf() { return "\r"; } + public static @bind.as("Word") String word(String s) { return s; } + public static @bind.as("Quoted") String quoted(String s) { return s; } + public static @bind.as("escaped") String c(char c) { return c+""; } + public static @bind.as("EmptyString") String emptystring() { return ""; } + public static @bind.as("\n") String retur() { return "\n"; } + public static @bind.as("\r") String lf() { return "\r"; } static Atom infer(Element e) { return infer((Topology)Atom.toAtom(e)); } static Atom infer(Topology t) { return new CharRange(new CharTopology(t)); }