X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2Fmisc%2FMetaGrammar.java;h=1a79a1d32a009d36e959a95c84134920c0c16374;hp=13da0cae7e6ac183576f1e23fbcc833f3ea955cb;hb=7187a6a8d74d0a614c2343b319aee3f9c039aaff;hpb=7e98c8cefa1a3d5501c7ab513ba37d4aefa291e6 diff --git a/src/edu/berkeley/sbp/misc/MetaGrammar.java b/src/edu/berkeley/sbp/misc/MetaGrammar.java index 13da0ca..1a79a1d 100644 --- a/src/edu/berkeley/sbp/misc/MetaGrammar.java +++ b/src/edu/berkeley/sbp/misc/MetaGrammar.java @@ -54,7 +54,6 @@ public class MetaGrammar extends ReflectiveWalker { public PreSequence _amp_(PreSequence p, Object[] o) { return p.and(new PreSequence(o, null).buildSequence(null, true, false, true)); } public PreSequence _amp__tilde_(PreSequence p, Object[] o) { return p.not(new PreSequence(o, null).buildSequence(null, true, false, true)); } - public Object _star_(Element r) { return Repeat.many0(r); } public Element epsilon(Object o, Object b) { return Union.epsilon; } public Object _leftparen__rightparen_(Object o) { return Union.epsilon; } public Element _rightparen_(Object e) { return SELF; } @@ -99,7 +98,6 @@ public class MetaGrammar extends ReflectiveWalker { false); } - public Object _plus_(final Element r) { return Repeat.many1(r); } public PreSequence rewrite(Object[] o) { return new PreSequence(o, null); } public PreSequence seqx(PreSequence p, String tag) { return _equals__greater_(p, tag); } @@ -111,17 +109,20 @@ public class MetaGrammar extends ReflectiveWalker { public PreSequence ps(Object[] o) { return new PreSequence(o); } public PreSequence _slash_(PreSequence p, Object sep) { return p.sparse(sep); } + public Object _star_(Element r) { return Repeat.many0(r); } + public Object _plus_(final Element r) { return Repeat.many1(r); } public Object _plus__slash_(final Element r, Element s) { return Repeat.many1(r, s); } public Object _star__slash_(final Element r, Element s) { return Repeat.many0(r, s); } - public Object _star__star_(final Element r) { return Repeat.maximal(Repeat.many0(r)); } - public Object _plus__plus_(final Element r) { return Repeat.maximal(Repeat.many1(r)); } - public Element _question_(final Element r) { return Repeat.maybe(r); } + public Object _star__star_(final Element r) { return Repeat.maximal(Repeat.many0(r)); } + public Object _plus__plus_(final Element r) { return Repeat.maximal(Repeat.many1(r)); } + public Element _question_(final Element r) { return Repeat.maybe(r); } + public MetaGrammar gram(Object o, MetaGrammar g, Object o2) { return g; } public MetaGrammar grammar(Object[] o) { return this; } public MetaGrammar grammar(Object o, Union[] u, Object x) { return this; } public char _backslash_n() { return '\n'; } public char _backslash_r() { return '\r'; } - public Object literal(String s) { return new MyDrop(string(s)); } + public Element literal(String s) { Element ret = string(s); dropAll.add(ret); return ret; } public Range _minus_(char a, char b) { return new Range(a, b); } public Range range(char a) { return new Range(a, a); } public Element _leftbracket_ (Range[] rr) { return ranges(true, rr); } @@ -139,10 +140,6 @@ public class MetaGrammar extends ReflectiveWalker { public final String s; public MyLift(String s) { this.s = s; } } - public class MyDrop { - public final Object o; - public MyDrop(Object o) { this.o = o; } - } public class PreSequence { public final HashSet and = new HashSet(); @@ -165,7 +162,7 @@ public class MetaGrammar extends ReflectiveWalker { ret[i*2] = oi; drops[i*2] = this.drops[i]; if (i*2+11; } else o2[j] = (Element)oi;