David Majda
c3c1c79665
Added OneOrMore AST node.
...
This speeds up the benchmark suite execution by 1.08% on V8.
Detailed results (benchmark suite totals):
---------------------------------
Test # Before After
---------------------------------
1 28.38 kB/s 28.72 kB/s
2 28.52 kB/s 28.84 kB/s
3 28.41 kB/s 28.83 kB/s
4 28.47 kB/s 28.81 kB/s
5 28.64 kB/s 28.76 kB/s
---------------------------------
Average 28.48 kB/s 28.79 kB/s
---------------------------------
Mozilla/5.0 (X11; U; Linux i686; en-US) AppleWebKit/533.2 (KHTML, like Gecko) Chrome/5.0.342.9 Safari/533.2
2010-04-20 21:09:23 +02:00
David Majda
8f59e21c8d
Renamed an iterator variable: "key" -> "rule".
2010-04-19 20:45:27 +02:00
David Majda
3f5cb8850c
Fixed PEG.buildParser's documentation and added a test.
2010-04-19 20:43:03 +02:00
David Majda
48da65d08e
PEG.buildParser now accepts grammars only in string format.
2010-04-19 20:39:59 +02:00
David Majda
a86e06a216
Add "Generated by ..." message to the generated parsers.
2010-04-19 19:54:28 +02:00
David Majda
09291d6f0f
Use "charAt(...)" instead of "[...]" for accessing string characters (compatibility with IE < 8).
2010-04-16 11:06:29 +02:00
David Majda
4b51e6a6d3
Quote null characters in regexps, IE does not like them.
2010-04-16 08:53:02 +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
6abda95a99
Made regexps generated for empty character classes ("[]" and "[^]") work in IE.
2010-04-14 21:08:35 +02:00
David Majda
e79e869993
Compensate for IE's lack of Array.prototype.indexOf function.
2010-04-14 21:00:09 +02:00
David Majda
e63f64a3d5
Make the generated parsers standalone (no runtime is required).
...
This and also speeds up the benchmark suite execution by 7.83 % on V8.
Detailed results (benchmark suite totals):
---------------------------------
Test # Before After
---------------------------------
1 26.17 kB/s 28.16 kB/s
2 26.05 kB/s 28.16 kB/s
3 25.99 kB/s 28.10 kB/s
4 26.13 kB/s 28.11 kB/s
5 26.14 kB/s 28.07 kB/s
---------------------------------
Average 26.10 kB/s 28.14 kB/s
---------------------------------
Mozilla/5.0 (X11; U; Linux i686; en-US) AppleWebKit/533.2 (KHTML, like Gecko) Chrome/5.0.342.7 Safari/533.2
2010-04-12 19:06:04 +02:00
David Majda
3f85a9ca84
Regenerated the metaparser with one-level rule cache.
2010-04-11 17:02:53 +02:00
David Majda
24d38f74b9
Replaced two-level rule cache with a one-level one.
...
This leads to simpler code and also speeds up the benchmark suite execution by
5,89 % on V8.
Detailed results (benchmark suite totals):
---------------------------------
Test # Before After
---------------------------------
1 24,70 kB/s 26,14 kB/s
2 24,49 kB/s 26,05 kB/s
3 24,67 kB/s 25,99 kB/s
4 24,65 kB/s 26,13 kB/s
5 24,71 kB/s 26,14 kB/s
---------------------------------
Average 24,64 kB/s 26.10 kB/s
---------------------------------
Mozilla/5.0 (X11; U; Linux i686; en-US) AppleWebKit/533.2 (KHTML, like Gecko) Chrome/5.0.342.7 Safari/533.2
2010-04-11 16:46:45 +02:00
David Majda
74830d4f8f
Sort expected strings in the error messages.
2010-04-11 15:34:30 +02:00
David Majda
37521cffa5
Error messages now do not contain duplicities.
2010-04-11 15:30:02 +02:00
David Majda
714512f232
Implemented generic AST node extension mechanism.
2010-04-11 14:48:52 +02:00
David Majda
1aa3d8e07e
Implemented a nop (no operation) function and used it on few places.
2010-04-11 14:16:38 +02:00
David Majda
16f238a64d
Fixed comment heading.
2010-04-11 12:41:25 +02:00
David Majda
3291c70d97
Added \uFEFF (BOM) to the definition of whitespace in the metagrammar.
...
The Rhino bug that prevented inclusion of \uFEFF among the whitespace characters
is no longer relevant here because we compile character classes into regexps
now, which avoids the infinite recursion.
2010-04-11 11:45:05 +02:00
David Majda
383c5acaa6
Replaced \xA0 by \u00A0 in the whitespace definition in the metagrammar.
...
This is purely stylistic change.
2010-04-11 11:18:42 +02:00
David Majda
20e230ca0e
Killed *MatchFailure classes => simpler code.
2010-03-21 15:48:28 +01:00
David Majda
4f4bb34ded
Implemented negative character classes (e.g. [^a-z]).
2010-03-20 12:08:45 +01:00
David Majda
22d2ac8ac2
Rewrote implementation of classes to be regexp-based.
2010-03-20 11:24:04 +01:00
David Majda
56ffa94cc7
PEG.buildParser reports left recursion (both direct and indirect).
2010-03-19 17:10:54 +01:00
David Majda
3a65316416
PEG.buildParser reports missing referenced rules.
2010-03-19 11:15:53 +01:00
David Majda
6bbd88088b
Implemented and used PEG.ArrayUtils.each.
2010-03-19 10:38:46 +01:00
David Majda
eae48caf91
Regenerated the grammar parser.
2010-03-19 10:38:32 +01:00
David Majda
6f510a0336
The cache does not remember match length but next position after the match.
...
This leads to simpler and faster code because it avoids one addition and
subtraction.
2010-03-19 10:12:35 +01:00
David Majda
796c98bf8e
Changed order of parameters in the SyntaxError constructor to make creating error with unknown location easier. Also fixes bug with reporting of invalid ranges such as [b-a] in the metagrammar.
2010-03-13 15:56:53 +01:00
David Majda
00a258d246
Renamed "humanName" to "displayName".
2010-03-13 15:36:04 +01:00
David Majda
a43d1b33e3
Bootstrapped the grammar parser, yay! I should have done this long ago.
2010-03-13 15:18:57 +01:00
David Majda
636ceb2719
Metagrammar recognizes JavaScript-like comments.
2010-03-13 09:49:06 +01:00
David Majda
7bf51eddf0
Removed trailing commas in object initializers (Google Closure does not like them).
2010-03-08 14:44:46 +01:00
David Majda
452243d450
Improved error reporting for predicates a bit.
2010-03-08 12:15:52 +01:00
David Majda
69906e9730
Do not recognize \uFEFF as whitespace in the metagrammar since it does not work with Rhino.
2010-03-08 11:37:03 +01:00
David Majda
bddb65ab9b
Improved & simplified error handling code.
2010-03-08 09:58:23 +01:00
David Majda
b86a219c86
Ensure that the same grammar and start rule always generate exactly the same parser.
2010-03-07 21:14:07 +01:00
David Majda
c3dd696a3e
Initial commit.
2010-03-07 20:41:02 +01:00