X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=tests%2Fregression.tc;h=e2ae422917e969aa13f4e13b495f28ffa7f58ebe;hp=2aba4b1e62e6865b2722b7cd527feb2f56829b22;hb=526da96dd06e152d194ec92c9ef9df6085a1251b;hpb=1981ad8a9fea8bf4d0940b649c211741b17dd1ff diff --git a/tests/regression.tc b/tests/regression.tc index 2aba4b1..e2ae422 100644 --- a/tests/regression.tc +++ b/tests/regression.tc @@ -24,8 +24,8 @@ testcase { output "1:{{a b} {c}}"; s ::= ids - ids ::= id (" " ids &~ id [~]*) => "1" - | id ( ids &~ id [~]*) => "2" + ids ::= id (" " ids &~ id ~[]*) => "1" + | id ( ids &~ id ~[]*) => "2" | id id ::= [a-z]++ } @@ -45,11 +45,11 @@ testcase { testcase { input "aaabbbccc"; - output ""; + output "ab"; s ::= ab & dc - ab ::= a b - dc ::= d c + ab ::= a b => ab + dc ::= d c => dc a ::= "a" a | () b ::= "b" b "c" | () c ::= "c" c | () @@ -60,8 +60,8 @@ testcase { input "aaabbbbccc"; s ::= ab & dc - ab !::= a b - dc !::= d c + ab !::= a b => ab + dc !::= d c => dc a ::= "a" a | () b ::= "b" b "c" | () c ::= "c" c | () @@ -90,11 +90,12 @@ testcase { } testcase { - input "xbambambam"; - output "bam:{a bam:{a bam:{a x}}}"; + input "qxbambambam"; + output "bam:{a bam:{a bam:{a x:{x}}}}"; - s ::= a s ^"bam" - s ::= ^"x" + s ::= "q" z + z ::= a z ^"bam" + z ::= ^"x" a ::= () => "a" } @@ -182,11 +183,11 @@ testcase { input "a+(b*c)"; output "+:{{a} *:{{b} {c}}}"; - s ::= R - R ::= id - | R ^"*" R - | R ^"+" R - | "(" R ")" + s ::= r + r ::= id + | r ^"*" r + | r ^"+" r + | "(" r ")" id ::= [a-z]++ } @@ -197,17 +198,16 @@ testcase { output "plus:{stringify:{{a}} times:{minus:{stringify:{{b}} stringify:{{d}}} stringify:{{c}}}}"; output "times:{minus:{plus:{stringify:{{a}} stringify:{{b}}} stringify:{{d}}} stringify:{{c}}}"; output "minus:{plus:{stringify:{{a}} stringify:{{b}}} times:{stringify:{{d}} stringify:{{c}}}}"; - s ::= S w ::= " " - L ::= id - S ::= L "=" Q => "assign" - | Q - Q ::= id - | L "=" Q => "assign" - | Q "-" Q => "minus" - | Q "+" Q => "plus" - | Q "*" Q => "times" - | "(" Q ")" + l ::= id + s ::= l "=" q => "assign" + | q + q ::= id + | l "=" q => "assign" + | q "-" q => "minus" + | q "+" q => "plus" + | q "*" q => "times" + | "(" q ")" id ::= idl++ => "stringify" idl ::= [a-d] } @@ -215,17 +215,16 @@ testcase { testcase { input "a*b*c"; output "times:{stringify:{{a}} times:{stringify:{{b}} stringify:{{c}}}}"; - s ::= S w ::= " " - L ::= id - S ::= L "=" R => "assign" - | R - R ::= L - | L "=" R => "assign" - | R "+" R => "plus" - | (R) "*" R => "times" - | "(" R ")" - | R R => "times" + l ::= id + s ::= l "=" r => "assign" + | r + r ::= l + | l "=" r => "assign" + | r "+" r => "plus" + | (r) "*" r => "times" + | "(" r ")" + | r r => "times" id ::= idl++ => "stringify" idl ::= [a-d] } @@ -233,73 +232,84 @@ testcase { testcase { input "a+b*c"; output "plus:{stringify:{{a}} times:{stringify:{{b}} stringify:{{c}}}}"; - s ::= S w ::= " " - L ::= id - S ::= L "=" R => "assign" - | R - R ::= L - | L "=" R => "assign" - | R "+" R => "plus" - > R "*" R => "times" - | "(" R ")" - | R R => "times" + l ::= id + s ::= l "=" r => "assign" + | r + r ::= l + | l "=" r => "assign" + | r "+" r => "plus" + > r "*" r => "times" + | "(" r ")" + | r r => "times" id ::= idl++ => "stringify" idl ::= [a-d] } testcase { + input "aa bb"; + output "{q:{{a a}} q:{{b b}}}"; + + s ::= q */ ws + ws ::= " "* + q ::= [a-z]++ => "q" +} + +testcase { input " + while x>0 - while y>0 - foo() - bar() + while y>0 + foo() + bar() + while x>0 - while y>0 - foo() - bar() + while y>0 + foo() + bar() + "; - output "smt:{while:{>:{{x} {0}} while:{>:{{y} {0}} sbb:{{f o o} {b a r}}}}}"; - output "smt:{while:{>:{{x} {0}} sbb:{while:{>:{{y} {0}} {f o o}} {b a r}}}}"; + output "smt:{while:{>:{{x} {0}} while:{>:{{y} {0}} sbb:{{f o o} {b a r}}}} while:{>:{{x} {0}} sbb:{while:{>:{{y} {0}} {f o o}} {b a r}}}}"; indent !::= ww outdent !::= " " outdent " " - | " " [~]* "\n" + | " " (~[]*) "\n" + +w !::= " " | "\n" | "\r" +ws !::= w* +ww !::= sp* +sp !::= " " +any !::= ~[]* -any !::= [~]* -s ::= !any "\n\n" !ww Statement !ww "\n\n" !any => smt -ww ::= sp* -sp ::= " " +s ::= ws statement ws statement ws => smt -block ::= "\n" !indent BlockBody - &~ "\n" outdent [~\ ] [~]* +block ::= "\n" indent blockBody + &~ "\n" outdent ~[\ ] ~[]* -BlockBody ::= Statement - > Statement BlockBody => "sbb" +blockBody ::= statement + > statement ws blockBody => "sbb" -Statement ::= Call - | ^"while" Expr block +statement ::= call + | ^"while" expr block /ws -Expr ::= ident - | Call - | Expr ^">" Expr +expr ::= ident + | call + | expr ^">" expr /ws | num -Call ::= Expr "()" +call ::= expr "()" /ws num ::= [0-9]++ ident ::= [a-z]++ &~ keyword keyword ::= "if" | "then" | "else" | "while" -w ::= " " | "\n" | "\r" -ws ::= w* }