2010-03-14 18:46:53 +01:00
|
|
|
/*
|
2014-03-12 19:05:26 +01:00
|
|
|
* Simple Arithmetics Grammar
|
|
|
|
* ==========================
|
|
|
|
*
|
|
|
|
* Accepts expressions like "2 * (3 + 4)" and computes their value.
|
2010-03-14 18:46:53 +01:00
|
|
|
*/
|
2010-03-07 20:41:02 +01:00
|
|
|
|
2014-03-12 19:05:26 +01:00
|
|
|
Expression
|
2015-10-09 17:09:33 +02:00
|
|
|
= head:Term tail:(_ ("+" / "-") _ Term)* {
|
|
|
|
var result = head, i;
|
2015-10-09 16:34:19 +02:00
|
|
|
|
2015-10-09 17:09:33 +02:00
|
|
|
for (i = 0; i < tail.length; i++) {
|
|
|
|
if (tail[i][1] === "+") { result += tail[i][3]; }
|
|
|
|
if (tail[i][1] === "-") { result -= tail[i][3]; }
|
2015-10-09 16:34:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
2014-03-12 19:05:26 +01:00
|
|
|
}
|
2010-03-07 20:41:02 +01:00
|
|
|
|
2014-03-12 19:05:26 +01:00
|
|
|
Term
|
2015-10-09 17:09:33 +02:00
|
|
|
= head:Factor tail:(_ ("*" / "/") _ Factor)* {
|
|
|
|
var result = head, i;
|
2015-10-09 16:34:19 +02:00
|
|
|
|
2015-10-09 17:09:33 +02:00
|
|
|
for (i = 0; i < tail.length; i++) {
|
|
|
|
if (tail[i][1] === "*") { result *= tail[i][3]; }
|
|
|
|
if (tail[i][1] === "/") { result /= tail[i][3]; }
|
2015-10-09 16:34:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
2014-03-12 19:05:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Factor
|
|
|
|
= "(" _ expr:Expression _ ")" { return expr; }
|
|
|
|
/ Integer
|
|
|
|
|
|
|
|
Integer "integer"
|
|
|
|
= [0-9]+ { return parseInt(text(), 10); }
|
2015-08-28 14:01:30 +02:00
|
|
|
|
2014-04-21 10:23:42 +02:00
|
|
|
_ "whitespace"
|
|
|
|
= [ \t\n\r]*
|