checkpoint
authoradam <adam@megacz.com>
Wed, 14 Dec 2005 07:42:50 +0000 (02:42 -0500)
committeradam <adam@megacz.com>
Wed, 14 Dec 2005 07:42:50 +0000 (02:42 -0500)
darcs-hash:20051214074250-5007d-c4721867d5f8a2e0f24c5999d3a737c194143e9b.gz

src/edu/berkeley/sbp/misc/MetaGrammar.java
tests/meta.g

index 1cc57be..9fc3382 100644 (file)
@@ -87,9 +87,7 @@ public class MetaGrammar extends ReflectiveWalker {
 
     public PreSequence rewrite(Object[] o)                                            { return new PreSequence(o, null); }
     public PreSequence _equals__greater_(Object[] o, String s)                        { return new PreSequence(o, s); }
 
     public PreSequence rewrite(Object[] o)                                            { return new PreSequence(o, null); }
     public PreSequence _equals__greater_(Object[] o, String s)                        { return new PreSequence(o, s); }
-    public Object[] seq(Object[] o, Object sep) {
-        return sep==null ? o : _slash_(o, sep);
-    }
+    public PreSequence seq(Object[] o, Object sep, String tag) { return new PreSequence(sep==null ? o : _slash_(o, sep), tag); }
     public Object[] seq(Object[] o) { return o; }
     public Object[] _slash_(Object[] o, Object sep) {
         if (o.length <= 1) return o;
     public Object[] seq(Object[] o) { return o; }
     public Object[] _slash_(Object[] o, Object sep) {
         if (o.length <= 1) return o;
index 4fed049..359319d 100644 (file)
@@ -11,10 +11,11 @@ conjuncts   ::=  rewrite
               |  rewrite ^"&"  e*/ws   /ws
               |  rewrite ^"&~" e*/ws   /ws
 
               |  rewrite ^"&"  e*/ws   /ws
               |  rewrite ^"&~" e*/ws   /ws
 
-sequence    ::= e*/ws (ws "/" e)? => "seq"
+sequence    ::= e*/ws
+                (ws "/" e)?
+                (ws "=>" ws (word|quoted))?              => "seq"
 
 
-rewrite  ::=  sequence                     /ws => "rewrite"
-           |  sequence ^"=>" (word|quoted) /ws
+rewrite  ::=  sequence
 
 ec       ::= [~\-\]\\\~]
            | escaped
 
 ec       ::= [~\-\]\\\~]
            | escaped
@@ -45,8 +46,7 @@ w       !::= " "
            | "//" ([~\n]*) "\n"
            | "\n"
            | "\r"
            | "//" ([~\n]*) "\n"
            | "\n"
            | "\r"
-an       ::= [a-zA-Z0-9_]
-word     ::= an++
+word     ::= [a-zA-Z0-9_]++
 quoted   ::= "\"" (([~\"\\] | escaped)+) "\""
            | "\"\"" => ""
 escaped  ::= "\\n" => "\n"
 quoted   ::= "\"" (([~\"\\] | escaped)+) "\""
            | "\"\"" => ""
 escaped  ::= "\\n" => "\n"