X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2Fmisc%2FMetaGrammar.java;h=4348dec1b91cfec1325ab90ee1766c149e593835;hp=7f4120f604246aa107c92a64815f3555a725ac6d;hb=fc1e5069ec5401c425dd29b77b04285916b62d10;hpb=c7af09d552a9cf2d53a72baa975c9a73384813ea diff --git a/src/edu/berkeley/sbp/misc/MetaGrammar.java b/src/edu/berkeley/sbp/misc/MetaGrammar.java index 7f4120f..4348dec 100644 --- a/src/edu/berkeley/sbp/misc/MetaGrammar.java +++ b/src/edu/berkeley/sbp/misc/MetaGrammar.java @@ -63,8 +63,12 @@ public class MetaGrammar extends StringWalker { // MetaGrammar ////////////////////////////////////////////////////////////////////////////// - public Union nonTerminal(String str) { return nonTerminal(str, null, false, false); } - public Union nonTerminal(String str, PreSequence[][] s, boolean synthetic, boolean dropAll) { + public Union getNonTerminal(String str) { return nonTerminal(str, null, false, false); } + private Union nonTerminal(String str) { return nonTerminal(str, null, false, false); } + public Union anonymousNonTerminal(PreSequence[][] s) { + return nonTerminal("anon"+(anon++), s, false, false); + } + private Union nonTerminal(String str, PreSequence[][] s, boolean synthetic, boolean dropAll) { Union n = str.equals(startSymbol) ? g : nt.get(str); if (n == null) nt.put(str, n = new Union(str, synthetic)); if (dropAll) this.dropAll.add(n); @@ -117,10 +121,10 @@ public class MetaGrammar extends StringWalker { else if ("epsilon".equals(head)) return Union.epsilon; else if ("()".equals(head)) return Union.epsilon; else if (")".equals(head)) return SELF; - else if ("nonTerminal".equals(head)) return nonTerminal(string(tree.child(0)), null, false, false); + else if ("nonTerminal".equals(head)) return getNonTerminal(string(tree.child(0))); else if ("::=".equals(head)) return nonTerminal(string(tree.child(0)), (PreSequence[][])walk(tree, 1), false, false); else if ("!::=".equals(head)) return nonTerminal(string(tree.child(0)), (PreSequence[][])walk(tree, 1), false, true); - else if ("(".equals(head)) return nonTerminal("anon"+(anon++), (PreSequence[][])walk(tree, 0), false, false); + else if ("(".equals(head)) return buildUnion((PreSequence[][])walk(tree, 0)); else if ("literal".equals(head)) { Element ret = string(string(tree.child(0))); dropAll.add(ret); return ret; } else if ("-".equals(head)) return new Range(walk(tree, 0).toString().charAt(0), walk(tree,1).toString().charAt(0)); else if ("range".equals(head)) return new Range(walk(tree, 0).toString().charAt(0), walk(tree,0).toString().charAt(0)); @@ -173,6 +177,10 @@ public class MetaGrammar extends StringWalker { return super.walk(tag, argo); } + public Union buildUnion(PreSequence[][] p) { + return anonymousNonTerminal(p); + } + ////////////////////////////////////////////////////////////////////////////// public class PreSequence { @@ -221,11 +229,12 @@ public class MetaGrammar extends StringWalker { this.drops = drops==null ? new boolean[o.length] : drops; } - public Union buildUnion() { - Union u = new Union("???"); + public Union buildUnion(String s) { + Union u = new Union(s); u.add(buildSequence(u)); return u; } + public Union buildUnion() { return buildUnion("???"); } public boolean unwrap = false; public Sequence buildSequence(Union u) { return buildSequence(u, false, false); } public Sequence buildSequence(Union u, boolean lame, boolean dropAll) {