Commit graph

75 commits

Author SHA1 Message Date
David Majda f3a83788aa Inline functions extracted just because of JSHint
Rather than extracting functions just because JSHint complained about
defining functions inside a loop, let's inline then and silence the
warning.
2014-04-27 13:31:49 +02:00
David Majda 7e3b4ec4f8 PEG.js grammar: Remove reserved word detection
This is mostly done for consistency with the JavaScript example grammar,
from which the |Identifier| rule is taken from. See the previous commit
for details.
2014-04-13 20:32:39 +02:00
David Majda e78ffbba9c PEG.js grammar: Improve the |Code| rule a bit
Instead of matching segments between blocks character by character,
match them as a whole. Also align the style with other similar rules
(e.g. the comment ones).
2014-04-06 15:02:51 +02:00
David Majda 64eb5faf54 PEG.js grammar: Fix line continuation handling in character classes
Before this commit, line continuations in character classes contributed
an empty string to the list of characters and character ranges matched
by a class. While this didn't lead to a buggy behavior with the current
code generator, the AST was wrong and the problem could have caused bugs
later.

This commit fixes the problem.
2014-04-06 14:53:57 +02:00
David Majda 421b8d6e51 Clean up parser specs 2014-04-04 20:40:09 +02:00
David Majda 6f2510e49e PEG.js grammar: Make rules with operators more generic 2014-04-04 11:25:21 +02:00
David Majda 45c29a886f PEG.js grammar: Extract the |SemanticPredicateExpression| rule
Semantic predicates are kind of |PrimaryExpression|, not kind of
|PrefixedExpression|. Therefore I extracted a rule for them and
referenced it from the |PrimaryExpression|.
2014-04-04 11:25:21 +02:00
David Majda da18f6a729 PEG.js grammar: Extract the |RuleReferenceExpression| rule
This makes the |Primary| rule a bit more tidy.
2014-04-04 11:25:21 +02:00
David Majda 8e6f98e45c PEG.js grammar: Extract the |ActionExpression| rule
Having it separated from the |SequenceExpression| rule is cleaner and
more logical.
2014-04-04 11:25:21 +02:00
David Majda 5c6f4dd38b PEG.js grammar: Append |Expression| to expression rule names
Makes the rule names a bit longer but also clearer.
2014-04-04 11:25:21 +02:00
David Majda 27c2d26203 PEG.js grammar: More JavaScript-like initializer/rule separation
Initializer and rules are now separated in a similar way as JavaScript
statements -- either by a semicolon or a line terminator, possibly with
whitespace and comments mixed in.

One consequence is that the grammars like this are now illegal:

  foo = "a" bar = "b"

A semicolon needs to be inserted between the rules:

  foo = "a";bar = "b"

I consider this a good change as the now-illegal syntax was somewhat
confusing.
2014-04-04 11:25:21 +02:00
David Majda 4ce7593f5f PEG.js grammar: Extract the |AnyMatcher| rule
This makes the |Primary| rule a bit more tidy. Also, matching the |.|
character really belongs to the lexical part of the grammar, next to
literals and character classes.
2014-04-04 11:25:21 +02:00
David Majda c0df01b092 PEG.js grammar: Improve code block handling
* Rename the |Action| rule to |CodeBlock| (it better describes what
    the rule matches).

  * Implement the rule in a simpler way and move it after more basic
    lexical elements.
2014-04-04 11:25:21 +02:00
David Majda 13f72bb19d PEG.js grammar: More JavaScript-like rules for identifiers
This change has two side effects:

  * Label names can no longer be JavaScript reserved words.

  * |$| is allowed again in label names. However, because of the
    preference rules, names starting with it will be usually parsed as a
    text operator followed by another identifier (denoting a rule
    reference or label name).
2014-04-04 11:25:21 +02:00
David Majda 0d6b91cb20 PEG.js grammar: More JavaScript-like rules for strings/literals/classes 2014-04-04 11:25:20 +02:00
David Majda bcb5271649 PEG.js grammar: More JavaScript-like rules for skipped elements 2014-04-04 11:25:20 +02:00
David Majda a5a0609505 PEG.js grammar: Inline trivial character rules 2014-04-04 11:25:20 +02:00
David Majda ae89f5e469 PEG.js grammar: Change whitespace handling
Before this commit, whitespace was handled at the lexical level by
making tokens consume any whitespace coming after them. This was
accomplished by appending |__| to every token rule.

This commit changes whitespace handling to be more explicit. Tokens no
longer consume whitespace coming after them and syntactic rules have to
cope with it. While this slightly complicates the syntactic grammar, I
think it's a cleaner way. Moreover, it is what JavaScript example
grammar does.

One small side-effect of thich change is that the grammar is now
stand-alone (it doesn't require utils.js anymore).
2014-04-04 11:25:20 +02:00
David Majda 4725632641 PEG.js grammar: Capitalize rule names
When rule names are capitalized, it's easier to visually distinguish
them from non-capitalized label names. Moreover, I use capitalized rule
names in all my grammars these days.
2014-04-04 11:25:20 +02:00
David Majda fb72c430e6 PEG.js grammar: Fix line continuation handling
Before this commit, a line continuation (backslash followed by a line
terminator character) contributed a character to a string or a character
class it was used in. In JavaScript and many other languages, line
continuation doesn't contribute anything.

This commit aligns PEG.js line continuation behavior with JavaScript.
2014-04-04 11:25:20 +02:00
David Majda 3dbec0b30d PEG.js grammar: Fix how |rawText| is created
Before this commit, the value of the |rawText| property of "class" AST
nodes was created in a hackish way from processed input and it didn't
always exactly represent the actual input text.

This commit changes the code so that the value of the |rawText| property
is created using the |text| function. This is a clean way which also
resolves the exact representation problem.
2014-04-04 11:25:20 +02:00
David Majda df154daafb PEG.js grammar: Disallow empty sequences
Empty sequences are useless and they only confused users. Let's disallow
them.
2014-04-04 11:25:20 +02:00
David Majda 95fd64ec15 .jshintrc: Add the "forin" option & fix fallout
Also added few missing |hasOwnProperty| calls that JSHint didn't detect
because it only looks whether there is an |if| statement wrapping the
loop body.
2013-12-14 21:50:43 +01:00
David Majda fbcefdf523 Fix |oneRuleGrammar| invocation
At one call site, the |oneRuleGrammar| was called with 3 parameters but
it only accepts 2. This commit removes the additional parameter.
2013-12-07 09:36:33 +01:00
David Majda 5942988f66 Remove the |startRule| property from the AST
It's redundant.
2013-01-06 10:21:48 +01:00
David Majda d61fd1792d Fix JSHint errors
Fixes the following JSHint errors (which I think are JSHint bugs):

  spec/parser.spec.js: line 142, col 20, Bad for in variable 'key'.
  spec/generated-parser.spec.js: line 119, col 20, Bad for in variable 'key'.
2013-01-05 20:28:24 +01:00
David Majda 5e146fce38 Text nodes: Implement text nodes
Implement a new syntax to extract matched strings from expressions. For
example, instead of:

  identifier = first:[a-zA-Z_] rest:[a-zA-Z0-9_]* { return first + rest.join(""); }

you can now just write:

  identifier = $([a-zA-Z_] [a-zA-Z0-9_]*)

This is useful mostly for "lexical" rules at the bottom of many
grammars.

Note that structured match results are still built for the expressions
prefixed by "$", they are just ignored. I plan to optimize this later
(sometime after the code generator rewrite).
2012-12-02 17:05:13 +01:00
David Majda af20f024c7 Text nodes: Disallow the "$" character in identifiers
The "$" character will mark text nodes in the future.
2012-12-02 16:49:56 +01:00
David Majda cdf23e0a49 Change ordering of "literal", "class" and "any" code
Changes all code that does something with "literal", "class" or "any"
AST nodes so that the code deals with these in the follwing order:

  1. literal
  2. class
  3. any

Previously the code used this ordering:

  1. literal
  2. any
  3. class

The new ordering is more logical because the nodes are handled from the
most specific to the most generic.
2012-06-25 21:46:47 +02:00
David Majda eb4badab24 Refactor named rules AST representation
PEG.js grammar rules are represented by |rule| nodes in the AST. Until
now, all such nodes had a |displayName| property which was either |null|
or stored rule's human-readable name. This commit gets rid of the
|displayName| property and starts representing rules with a
human-readable name using a new |named| node (a child of the |rule|
node).

This change simplifies code generation code a bit as tests for
|displayName| can be removed (see changes in generate-code.js). It also
separates different concerns from each other nicely.
2012-06-25 21:36:41 +02:00
David Majda a59516f89b Small reordering of properties when creating |class| nodes
General rule: Least important things/flags go last.
2012-05-07 10:14:09 +02:00
David Majda 55a255a882 Add forgotten tests for |nonBraceCharacter| & |nonBraceCharacters| rules 2012-05-07 09:56:39 +02:00
David Majda 7900b66c70 Fix |braced| rule in the PEG.js grammar
This fix does not change the behavior, it just makes the
|nonBraceCharacters| rule un-dead (as originally intended).
2012-05-07 09:53:21 +02:00
David Majda 94205ab639 Jasmine: Convert tests of parser's "grammar" rule 2012-05-06 19:05:36 +02:00
David Majda f746189f2b Jasmine: Convert tests of parser's "initializer" rule 2012-05-06 19:05:36 +02:00
David Majda a49674b05f Jasmine: Change |oneRuleGrammar| parameter handling
This change makes code using |oneRuleGrammar| less verbose + prepares
for passing of the initializer (will be used by code added in the next
few commits).
2012-05-06 19:05:36 +02:00
David Majda 171d62fce4 Jasmine: Convert tests of parser's "rule" rule 2012-05-06 19:05:36 +02:00
David Majda e17d4de7ae Jasmine: Convert tests of parser's "expression" rule 2012-05-06 19:05:36 +02:00
David Majda cc22086a09 Jasmine: Convert tests of parser's "choice" rule 2012-05-06 19:05:36 +02:00
David Majda 434abdb272 Jasmine: Convert tests of parser's "sequence" rule 2012-05-06 19:05:36 +02:00
David Majda ec8889f85d Jasmine: Convert tests of parser's "labeled" rule 2012-05-06 19:05:36 +02:00
David Majda bf6d412a4f Jasmine: Convert tests of parser's "prefixed" rule 2012-05-06 19:05:36 +02:00
David Majda 3e083cc51b Jasmine: Convert tests of parser's "suffixed" rule 2012-05-06 19:05:36 +02:00
David Majda 45f825c24f Jasmine: Convert tests of parser's "primary" rule 2012-05-06 19:05:35 +02:00
David Majda 57bbcd71e5 Jasmine: Convert tests of parser's "action" rule 2012-05-06 19:05:35 +02:00
David Majda 35771e15bc Jasmine: Convert tests of parser's "braced" rule 2012-05-06 19:05:35 +02:00
David Majda b1cb214e8b Jasmine: Convert non-tests of parser's character class rules 2012-05-06 19:05:35 +02:00
David Majda 4f5b78b372 Jasmine: Convert tests of parser's "identifier" rule 2012-05-06 19:05:35 +02:00
David Majda a3d93f000f Jasmine: Convert tests of parser's "literal" rule 2012-05-06 19:05:35 +02:00
David Majda 573db92583 Jasmine: Convert tests of parser's "string" rule 2012-05-06 19:05:35 +02:00