X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2Fmeta%2FMetaGrammarBindings.java;h=50fd0b33f7d6f1ba16a091dce0d8a922862cc6ea;hp=3ba3d2af371918c2496bcf0b52598ca8f05b9edd;hb=8129e3bcdf7df528a636daf66e0b35b1dceb153f;hpb=f7d5c2384df4e9e586f3c3465a6e6e0f4212115c diff --git a/src/edu/berkeley/sbp/meta/MetaGrammarBindings.java b/src/edu/berkeley/sbp/meta/MetaGrammarBindings.java index 3ba3d2a..50fd0b3 100644 --- a/src/edu/berkeley/sbp/meta/MetaGrammarBindings.java +++ b/src/edu/berkeley/sbp/meta/MetaGrammarBindings.java @@ -9,20 +9,20 @@ import java.lang.annotation.*; import java.lang.reflect.*; import java.io.*; +/** The java classes typically used to represent a parsed grammar AST */ public class MetaGrammarBindings { - public static @bind class Grammar { - public NonTerminal get(String s) { - for(NonTerminal nt : nonterminals) - if (nt.name.equals(s)) return nt; - return null; - } - public @bind.arg NonTerminal[] nonterminals; + + /** 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); } public String toString() { String ret = "[ "; - for(NonTerminal nt : nonterminals) ret += nt + ", "; + for(NonTerminal nt : values()) ret += nt + ", "; return ret + " ]"; } } + public abstract static class Un extends El { public Seq[][] sequences; public void build(MetaGrammar.Context cx, Union u) { @@ -45,10 +45,11 @@ public class MetaGrammarBindings { } } } + public static class NonTerminal extends Un { public String name = null; - public @bind NonTerminal(@bind.arg("Word") String name, - @bind.arg("RHS") Seq[][] sequences) { + public @bind NonTerminal(@bind.arg String name, + @bind.arg Seq[][] sequences) { this.name = name; this.sequences = sequences; } @@ -66,10 +67,9 @@ public class MetaGrammarBindings { } } - //public static @bind.as void range(char c) { } public static class Range { - public @bind.as("range") Range(char only) { first = only; last = only; } - public @bind.as("-") Range(char first, char last) { this.first = first; this.last = last; } + public @bind Range(char only) { first = only; last = only; } + public @bind Range(char first, char last) { this.first = first; this.last = last; } public char first; public char last; } @@ -172,27 +172,28 @@ public class MetaGrammarBindings { return ret; } } - public static @bind.as("&") Seq and(Seq s, El[] elements) { return s.and(seq(elements)); } - public static @bind.as("&~") Seq andnot(Seq s, El[] elements) { return s.andnot(seq(elements)); } + public static Seq and(Seq s, El[] elements) { return s.and(seq2(elements)); } + public static Seq andnot(Seq s, El[] elements) { return s.andnot(seq2(elements)); } + public static @bind.as("&") Seq and2(Seq s, Seq a) { return s.and(a); } + public static @bind.as("&~") Seq andnot2(Seq s, Seq a) { return s.andnot(a); } public static @bind.as("->") 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("PS") 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; } }