Commit graph

31 commits

Author SHA1 Message Date
David Majda 57e806383c Error handling: Use a special value (not |null|) to indicate failure
Using a special value to indicate match failure instead of |null| allows
actions to return |null| as a regular value. This simplifies e.g. the
JSON parser.

Note the special value is internal and intentionally undocumented. This
means that there is currently no official way how to trigger a match
failure from an action. This is a temporary state which will be fixed
soon.

The negative performance impact (see below) is probably caused by
changing lot of comparisons against |null| (which likely check the value
against a fixed constant representing |null| in the interpreter) to
comparisons against the special value (which likely check the value
against another value in the interpreter).

Implements part of #198.

Speed impact
------------
Before:     1146.82 kB/s
After:      1031.25 kB/s
Difference: -10.08%

Size impact
-----------
Before:     950817 b
After:      973269 b
Difference: 2.36%

(Measured by /tools/impact with Node.js v0.6.18 on x86_64 GNU/Linux.)
2013-12-01 16:08:55 +01:00
David Majda f3d392bd1c JavaScript example: Fix handling of elided elements in array literals
JavaScript allows one to skip (elide) elements in array literals. It
also allows a trailing comma, which doesn't imply an element elision.

For example, an array literal:

  [,,,]

contains three elided elements (one before each comma) and a trailing
comma.

Example JavaScript parser handled elided elements incorrectly and just
threw them away. This commit fixes this behvior and inserts |null| in
the AST for each elided element. This is in line with how SpiderMonkey's
JavaScript parser (the |Reflect.parse| API), Esprima and Acorn behave.

Based on a patch by @fpirsch:

  https://github.com/dmajda/pegjs/pull/177
2013-08-31 11:02:00 +02:00
David Majda d71bca46a1 Javascript example: Improve array literal rules
Makes the |ArrayLiteral| and |ElementList| rules more in line with the
ECMAScript grammar.

Based on a patch by @fpirsch:

  https://github.com/dmajda/pegjs/pull/177
2013-08-31 10:56:33 +02:00
David Majda fe18c6ffd3 Fix |null| handling in the JSON parser
We couldn't return |null| in the |value| rule of the JSON example
parser because that would mean parse failure. So until now, we just
returned |"null"| (a string).

This was obviously stupid, so this commit changes the |value| rule to
return a special object instead that is converted to |null| later.

Based on patches by Patrick Logan (GH-91) and Jakub Vrána (GH-191).
2013-08-20 07:54:12 +02:00
fpirsch d7e853b87c Fix automatic semi-colon insertion
Fix automatic semi-colon insertion in var statements without
initialisers.
var i
i = 1;
is valid and not accepted by the parser

but
var i = 2
i = 3;
is valid and accepted by the parser, as it should be.

With this fix, both are accepted.
2013-01-12 18:59:49 +01:00
David Majda c54483bb17 Text nodes: Use text nodes in examples/javascript.pegjs 2012-12-02 17:41:46 +01:00
David Majda faaf9b6be1 Text nodes: Use text nodes in examples/css.pegjs 2012-12-02 17:40:02 +01:00
David Majda d0dfe46550 Text nodes: Use text nodes in examples/json.pegjs 2012-12-02 17:36:26 +01:00
David Majda 9ec6b6aa57 Text nodes: Use text nodes in examples/arithmetics.pegjs 2012-12-02 17:25:52 +01:00
fpirsch fa05142292 Update examples/javascript.pegjs
Changed "arguments" to "args" in several places to avoid shadowing "arguments", which is not allowed by Google Clusure Compiler.
2012-10-26 23:17:54 +03:00
David Majda 70e4166bb2 Fix typo in a comment in JavaScript example grammar 2012-02-12 15:35:26 +01:00
David Majda 8ae3eea7c4 Fix typo in JavaScript example grammar
Fixes GH-62.
2012-02-04 22:25:06 +01:00
Jason Davies d386d3a351 Fix typo in comment. 2011-10-09 16:38:26 +01:00
David Majda 5cf66d824c Fix typo in JavaScript example grammar 2011-08-15 20:14:34 +02:00
David Majda 5f810f803b Make example grammars compatible with Rhino 2010-06-08 17:01:54 +02:00
David Majda ee8c121676 Use labeled expressions and variables instead of $1, $2, etc.
Labeled expressions lead to more maintainable code and also will allow
certain optimizations (we can ignore results of expressions not passed
to the actions).

This does not speed up the benchmark suite execution statistically
significantly on V8.

Detailed results (benchmark suite totals):

---------------------------------
 Test #     Before       After
---------------------------------
      1   28.43 kB/s   28.46 kB/s
      2   28.38 kB/s   28.56 kB/s
      3   28.22 kB/s   28.58 kB/s
      4   28.76 kB/s   28.55 kB/s
      5   28.57 kB/s   28.48 kB/s
---------------------------------
Average   28.47 kB/s   28.53 kB/s
---------------------------------

Mozilla/5.0 (X11; U; Linux i686; en-US) AppleWebKit/533.4 (KHTML, like Gecko) Chrome/5.0.375.55 Safari/533.4
2010-06-07 09:23:04 +02:00
David Majda 409ddf2ae8 Formatted all grammars more consistently and transparently
This is purely cosmetical change, no functionality was affected
(hopefully).
2010-05-31 16:35:03 +02:00
David Majda 698564a3c2 Replace ":" after a rule name with "="
I'll introduce labelled expressions shortly and I want to use ":" as a
label-expression separator. This change avoids conflict between the two
meanings of ":". (What would e.g. "foo: 'bar'" mean?  Rule "foo"
matching string "bar", or string "bar" labelled "foo"?)
2010-05-31 16:31:45 +02:00
David Majda f9ea46ef15 Fix string literal parsing in the JavaScript grammar 2010-05-31 15:26:35 +02:00
David Majda 11c67b0507 Remove trailing whitespace 2010-05-22 13:15:20 +02:00
David Majda de7536fd94 Added notes about ECMA-262, 5th ed. compatibility to the JSON example grammar. 2010-04-19 20:00:22 +02:00
David Majda 7fc491412d Work around the fact that IE does not recognize "\v" in strings. 2010-04-14 21:29:05 +02:00
David Majda 6a194e8f68 Added example JavaScript parser. 2010-04-11 13:18:23 +02:00
David Majda 751a33715d Added example CSS parser. 2010-03-29 12:44:32 +02:00
David Majda a1adbf0607 Added example JSON parser. 2010-03-22 12:18:58 +01:00
David Majda 8f2aa1e834 Fixed a bug in the example grammar where integers beginning with 0 were parsed as octal. 2010-03-18 20:06:55 +01:00
David Majda aff85fd228 Removed subtraction and division from the example grammar because of wrong associativity. 2010-03-18 20:06:05 +01:00
David Majda 9d239db2d6 Simplified the example arithmetics grammar once more + addded comment. 2010-03-14 18:46:53 +01:00
David Majda 1ee0049b08 Changed standard grammar extension from .peg to .pegjs (it is more specific). 2010-03-13 09:52:54 +01:00
David Majda eade133ea6 Simplified the example arithmetics grammar. 2010-03-12 14:27:22 +01:00
David Majda c3dd696a3e Initial commit. 2010-03-07 20:41:02 +01:00