# HG changeset patch # User Mike Pavone # Date 1332220238 25200 # Node ID 454c0346f35754e71ba5d45b2d492c6015d203bf # Parent a57a12bdae96a8dc9294a5805fbfac23db7fdb98 Added method call syntax and comparison operators diff -r a57a12bdae96 -r 454c0346f357 parser.js --- a/parser.js Mon Mar 19 21:29:33 2012 -0700 +++ b/parser.js Mon Mar 19 22:10:38 2012 -0700 @@ -3,21 +3,25 @@ 'start = ws module:(object / lambda) ws { return module; };' + 'ws = [ \\t\\n\\r]*;' + 'hws = [ \\t]*;' + -'expr = funcall / addsub;' + -'addsub = left:muldiv hws op:("+"/"-") hws right:addsub ws { return {type: "op", left: left, op: op, right: right }; } / muldiv;'+ +'expr = e:(funcall / methcall / opexpr) ws { return e; };' + +'opexpr = left:addsub hws op:("<=" / ">=" / "<" / ">" / "=") hws right:opexpr { return {type: "op", left: left, op: op, right: right }; } / addsub;' + +'addsub = left:muldiv hws op:("+"/"-") hws right:addsub { return {type: "op", left: left, op: op, right: right }; } / muldiv;'+ 'muldiv = left:primlitsym hws op:("*"/"/") hws right:muldiv { return {type: "op", left: left, op: op, right: right }; } / primlitsym;'+ -'primlitsym = ws val:(float / int / string / symbol / object / lambda / "(" expr:expr hws ")" { return expr; }) { return val; };' + -'symbol = chars:[a-zA-Z_!?@]+ trailing:(":"? [a-zA-Z_!?@0-9~])* ! ":" { return {type: "symbol", name: chars.join("") + trailing.join("")}; };' + +'primlitsym = hws val:(float / int / string / symbol / object / lambda / "(" expr:expr hws ")" { return expr; }) { return val; };' + +'symbol = chars:[a-zA-Z_!?@]+ trailing:(":"? [a-zA-Z_!?@0-9])* ! ":" { return {type: "symbol", name: chars.join("") + trailing.join("")}; };' + 'float = digits:[0-9]+ "." decimals:[0-9]+ { return {type: "floatlit", value: parseFloat(digits.join("") + "." + decimals.join("")) }; };' + 'int = digits:[0-9]+ { return {type: "intlit", value: parseInt(digits.join(""), 10)}; };' + 'string = "\\"" text:[^\\"]* "\\"" { return {type: "strlit", value: text.join("")}; };' + -'object = "#{" messages:assignment* "}" { return {type: "object", messages: messages}; };' + -'assignment = ws sym:symbol hws "<-" expr:expr { return {type: "assignment", symbol: sym, expression: expr}; }' + -'lambda = args:((& ":") argname+ )? "{" exprs:(assignment / expr)* ws "}" { return {type: "lambda", args: args[1], expressions: exprs}; };' + -'argname = init:":"? chars:[a-zA-Z_!?@]+ trailing:[a-zA-Z_!?@0-9%]* hws { return {type: "symbol", name: init + chars.join("") + trailing.join("")}; };' + -'funcall = ws parts: funcallpart+ { var fun = ""; var args = []; for (var i in parts) { fun += parts[i].name; args = args.concat(parts[i].args); } return {type: "funcall", name: fun, args: args}; };' + -'funcallpart = fun:funpart args:addsub* hws { return { name: fun, args: args}; };' + -'funpart = chars:[a-zA-Z_!?@]+ middle:[a-zA-Z_!?@0-9#]* ":" & [ \\t\\n\\r] { return chars.join("") + middle.join("") + ":"; };'; +'object = "#{" ws messages:assignment* "}" { return {type: "object", messages: messages}; };' + +'assignment = hws sym:symbol hws "<-" expr:expr ws { return {type: "assignment", symbol: sym, expression: expr}; }' + +'lambda = args:((& ":") argname+ )? "{" ws exprs:(assignment / expr)* "}" { return {type: "lambda", args: args[1], expressions: exprs}; };' + +'argname = init:":"? chars:[a-zA-Z_!?@]+ trailing:[a-zA-Z_!?@0-9]* hws { return {type: "symbol", name: init + chars.join("") + trailing.join("")}; };' + +'funcall = hws parts: funcallpart+ { var fun = ""; var args = []; for (var i in parts) { fun += parts[i].name; args = args.concat(parts[i].args); } return {type: "funcall", name: fun, args: args}; };' + +'funcallpart = fun:funpart args:opexpr* hws { return { name: fun, args: args}; };' + +'funpart = chars:[a-zA-Z_!?@]+ middle:[a-zA-Z_!?@0-9]* ":" & [ \\t\\n\\r] { return chars.join("") + middle.join("") + ":"; };' + +'methcall = receiver:opexpr hws info:methcallrest { info.receiver = receiver; return info; };' + +'methcallrest = funcall / unarymeth;' + +'unarymeth = name:symbol { return {type: "funcall", name:name, args: []}; };'; var parser = PEG.buildParser(grammar); //var parser = PEG.buildParser('start = expr; expr = int; int = digits:[0-9]+ { return parseInt(digits.join(""), 10); }');