Commit graph

964 commits

Author SHA1 Message Date
David Majda a8d01e1834 Use eslint 3.2.0
Note the update required disabling the "no-control-regex" rule, which
started reporting following errors:

  /Users/dmajda/Programming/PEG.js/pegjs/lib/compiler/js.js
    22:16  error  Unexpected control character in regular expression  no-control-regex
    27:16  error  Unexpected control character in regular expression  no-control-regex
    28:16  error  Unexpected control character in regular expression  no-control-regex
    51:16  error  Unexpected control character in regular expression  no-control-regex
    52:16  error  Unexpected control character in regular expression  no-control-regex

  /Users/dmajda/Programming/PEG.js/pegjs/lib/parser.js
    76:16  error  Unexpected control character in regular expression  no-control-regex
    77:16  error  Unexpected control character in regular expression  no-control-regex
    90:16  error  Unexpected control character in regular expression  no-control-regex
    91:16  error  Unexpected control character in regular expression  no-control-regex
2016-08-02 15:02:49 +02:00
David Majda e6c3e7180f Use browserify 13.1.0 2016-08-01 15:41:32 +02:00
David Majda 2647f5789f generated-parser-behavior.spec.js: Test also with options.trace === true
Based on a pull request by @Mingun:

  https://github.com/pegjs/pegjs/pull/397
2016-08-01 11:50:00 +02:00
David Majda bf9d9561c4 Tighten "try ... catch" clauses in spec helpers
They wrapped too much code.
2016-08-01 11:37:23 +02:00
David Majda 67d85f2de8 Align names of compiler passes that detect infinite loops
Rename compiler passes as follows:

  reportLeftRecursion -> reportInfiniteRecursion
  reportInfiniteLoops -> reportInfiniteRepetition

This reflects the fact that both passes detect different ways of causing
the same problem (possible infinite loop when parsing).
2016-07-29 18:06:16 +02:00
David Majda 9717dc3417 Talk about "undefined rules" instead of "missing rules" internally
The new terminology is more precise and in line with commonly used
programming languages.

The change involves mainly renaming related compiler pass and files
associated with it.
2016-07-29 15:16:56 +02:00
David Majda e9cb23608d Split peg$buildException into two separate functions
This change reflects the fact that PEG.js-generated parsers really
produce two kinds of syntax errors:

  Structured errors

    Caused by match failures, trailing input, or calls of the "expected"
    function in parser code. Their messages have fixed format ("Expected
    ... but ... found.").

  Simple errors

    Caused by calls of the "error" function in parser code. Their
    messages don't have any fixed format.

Each kind of error now has a separate helper function which builds its
instances.
2016-07-29 12:05:54 +02:00
David Majda e03d92488a Set the "found" property of syntax errors produced by "error" to null
The property doesn't correspond to anything in the error's message.
2016-07-29 12:04:12 +02:00
David Majda 6ca546a44e Regenerate lib/parser.js 2016-07-14 16:18:57 +02:00
David Majda 75cd17ed58 bin/pegjs: Implement the --format option 2016-07-14 16:18:57 +02:00
David Majda d83e4d5a48 bin/pegjs: Generate parsers in "node" format
I think the "node" format is what most people want these days.

An option to override will be added in the next commit.
2016-07-14 16:18:57 +02:00
David Majda db9920e3ca peg.generate: Implement { format: "global" } 2016-07-14 16:18:50 +02:00
David Majda 61c11ee1b4 peg.generate: Implement { format: "amd" } 2016-07-14 16:18:43 +02:00
David Majda f633f697c9 peg.generate: Implement { format: "node" } 2016-07-14 16:18:32 +02:00
David Majda 9454c11c59 generate-js.js: Fix "=" alignment 2016-07-14 13:55:13 +02:00
David Majda e546af5543 Regenerate lib/parser.js 2016-07-04 09:04:47 +02:00
David Majda a3397c31f9 Makefile: Fix bin/pegjs invocation
It was broken since a57431955e.
2016-07-04 09:03:09 +02:00
David Majda e8be76ee3a Don't expose the "parser" variable in parser code
The "parser" variable allowed access to the parser object. Among other
things, this made it possible to invoke the parser recursively using
"parser.parse".

One problem with the "parser" variable is that it bakes in the idea that
the parser is an *object*, not a *module*. While this is true now, it
won't necessarily be in the future, when parsers may be exported as ES6
modules. Also, people tend to use parsers as modules even today, e.g.
like this:

  var parse = require("parser").parse;
  var result = parse(...);

Such usage broke the "parser" variable (as it was implemented).

For this reasons I decided to remove the "parser" variable. If someone
needs to do tricks like recursive invocation of the parser, he/she must
pass the parser or the "parse" function itself using options.

Related to #433.
2016-07-04 08:35:39 +02:00
David Majda 6aa956452e Don't use "this" inside peg.generate
This change makes it possible to use "generate" as a module function,
e.g. like this:

  var generate = require("pegjs").generate;
  var parser = generate(...);

Fixes #433.
2016-07-04 08:33:26 +02:00
David Majda 65550965c6 Remove extraneous "with" from an error message 2016-07-04 07:19:57 +02:00
David Majda b3a90de020 Syntax error messages: Use Oxford comma
In general PEG.js uses American English, where Oxford comma is
prevalent.

Part of #371.
2016-07-03 18:42:08 +02:00
David Majda ec8ede5bbe Grammar error messages 3/3: Improve the left recursion message
New wording is more explanatory.

Part of #371.
2016-07-03 18:13:01 +02:00
David Majda f5e43f842c Grammar error messages 2/3: Improve the infinite loop message
New wording is more explanatory.

Part of #371.
2016-07-03 18:12:47 +02:00
David Majda 85fb8aaa0e Grammar error messages 1/3: Improve the missing rule message
New wording is more similar to wording used in various programming
languages and it is in line with the duplicate rule message.

Part of #371.
2016-07-03 18:12:33 +02:00
David Majda eb67cbedb4 Report duplicate labels as errors
Resolves #270.
2016-06-27 13:45:59 +02:00
David Majda 2a889535bd Add location to the "Rule ... is already defined" error message
See this discussion:

  eb5875bc6a (commitcomment-17970220)
2016-06-27 12:27:41 +02:00
David Majda f9bc0fe619 package.json: Sort files alphabetically 2016-06-22 15:29:06 +02:00
David Majda eb5875bc6a Report duplicate rule definitions as errors
Based on a pull request by Futago-za Ryuu (@futagoza):

  https://github.com/pegjs/pegjs/pull/329

Resolves #318.
2016-06-22 15:19:56 +02:00
David Majda 149c829897 lib/compiler/index.js: Order default option values alphabetically 2016-06-22 09:48:09 +02:00
David Majda c0e2bd218c README.md: Describe the --optimize command-line option 2016-06-22 09:47:24 +02:00
David Majda da1395e21e README.md: Describe the --dependency command-line option 2016-06-22 09:47:24 +02:00
David Majda 6bf19ae6f8 README.md: Order command-line options alphabetically 2016-06-22 09:47:24 +02:00
David Majda 01aa32615b README.md: Describe the "trace" peg.generate option 2016-06-22 09:47:14 +02:00
David Majda f41535224d README.md: Order peg.generate options alphabetically 2016-06-22 09:35:50 +02:00
David Majda 3672eff31c bin/pegjs: Order peg.generate options alphabetically 2016-06-22 09:08:43 +02:00
David Majda 0a2217d3da bin/pegjs: Order options in a switch statement alphabetically 2016-06-22 09:06:44 +02:00
David Majda ff330a0d4b bin/pegjs: Order options in help text alphabetically 2016-06-22 09:04:33 +02:00
David Majda a57431955e bin/pegjs: Use the -o/--output option to specify the output file
This is more traditional compiler interface. Its main advantage against
specifying the output file as a second argument (which is what bin/pegjs
used until now) is that input and output files can't be mixed up.

Part of #370.
2016-06-21 16:51:01 +02:00
David Majda 9bf7c0c5ff bin/pegjs: Remove detailed instructions from the help text
They don't belong there.

Part of #370.
2016-06-21 16:50:50 +02:00
David Majda 35b3971366 bin/pegjs: Rename the -o option to -O
This will make room for -o to mean --output instead of --optimize. Also,
-O is more traditional option name for describing optimization config
than -o.

Part of #370.
2016-06-21 16:25:01 +02:00
David Majda 1c14a2c8f2 bin/pegjs: Allow using "-" to mean standard input and output
Part of #370.
2016-06-21 16:11:43 +02:00
David Majda 6eb42ddae7 Update CONTRIBUTING.md
Improve the text stylistically and grammatically. Rewrite intro to nudge
people into the right direction and warn them about the usual fate of
spontaneous PRs.
2016-06-21 14:21:57 +02:00
David Majda b10ddc4877 Move .github/CONTRIBUTING.md to CONTRIBUTING.md
No need to have a .github directory for just one file.
2016-06-21 11:28:56 +02:00
David Majda 3db71ebceb Remove .github/{ISSUE,PULL_REQUEST}_TEMPLATE
The files were not really templates but instructions. These instructions
are already spelled-out in CONTRIBUTING.md and repeating them feels a
bit redundant.

If it turns out people don't read CONTRIBUTING.md when submitting issues
and pull requests, I'll probably restore the templates (likely in some
shorter/simpler form).
2016-06-21 11:23:57 +02:00
David Majda 930877c3ba Move lib/compiler.js to lib/compiler/index.js
This makes "compiler" a regular Node.js module.
2016-06-20 08:06:14 +02:00
David Majda 5a4d04fa90 Construct expectations using functions
Until now, expectations were constructed using object literals. This
commit changes the construction to use factory functions.

This change makes generated parsers slightly smaller because property
names don't have to be repeated many times and factory function calls
are more amenable to minifying.

Some numbers based on the aggregate size of parsers generated from
examples/*.pegjs:

  Optimization   Minified?   Size before   Size after   Saving
  ------------------------------------------------------------
  speed          no               719066       716063    0.42%
  speed          yes              188998       180202    4.65%
  size           no               194810       197813    1.52%
  size           yes              108782        99947    8.12%

(Minification was done using "uglify --mangle --compress" with
uglify-js 2.4.24.)
2016-06-18 06:57:09 +02:00
David Majda e7d03825e0 AST: Remove the "rawText" property from "class" nodes
It isn't used anymore.
2016-06-18 04:52:49 +02:00
David Majda 35c8280743 Expectation refactoring 7/7: Regenerate lib/parser.js 2016-06-17 19:27:48 +02:00
David Majda 8639cf6d61 Expectation refactoring 6/7: Move "buildMessage" to SyntaxError
The "buildMessage" utility function, which was previously internal, is
now exposed as SyntaxError.buildMessage in generated parsers.

The motivation behind this is two-fold:

  1. Building of a syntax error message is a responsibility of the
     SyntaxError class, meaning the code should be placed there.

  2. By exposing the message building code, parser users can use it to
     generate customized error messages without duplicating PEG.js's code.

Note that helper functions inside "buildMessage" ("describeExpected",
"describeFound", etc.) currently aren't exposed. They may become exposed
in the future if there is enough demand.
2016-06-17 19:25:28 +02:00
David Majda 999cc7be74 Expectation refactoring 5/7: Refactor "buildMesage"
Mostly just extract few functions, increasing readability.
2016-06-17 19:24:03 +02:00