This file documents all notable changes to Peggy.
Released: TBD
- New CLI @hildjj
- Backward compatible with the previous
- New -t/--test and -T/--testfile flags to directly test the generated grammar
- Check allowedStartRules for validity @hildjj
Released: 2021-06-02
-
Infrastructural rebake @StoneCypher
- Builds with
typescript
, removesbabel
- Bundles with
rollup
, removesbrowserify
- Tests with
jest
, removesmocha
- Minifies with
terser
, removesuglify
- Adds
rimraf
for portable pre-build cleanup - Extends CI testing to
windows
,macintosh
- Increases node testing range to include
node 16
- Builds with
-
Option to select optimization mode removed as it had no significant effect on the majority of generated parsers and as such represented only academic interest. You should use minifiers to get smaller parsers. Option
optimize
is deleted from thegenerate()
options, flag--optimize
is deleted from the CLI (you still can supply it, but the CLI will issue a warning that the option is removed). @Mingun -
location()
s now will have additionalsource
property which value is taken from theoptions.grammarSource
property. That property can contain arbitrary data, for example, path to the currently parsed file. @Mingun -
Made usage of
GrammarError
andpeg$SyntaxError
more consistent. Use theformat
method to get pretty string outputs. Updated thepeggy
binary to make pretty errors. Slight breaking change: the format of a few error messages have changed; use thetoString()
method onGrammarError
to get something close to the old text. @hildjj -
The code generator was slightly reworked to simplify reusing the bytecode generator (
generate.generateBytecode
pass). Propertyconsts
on thegrammar
AST node, has been creating by the pass in the past, was decoupled into 4 other properties with the structured information:literals
classes
expectations
functions
-
Added missing type definitions to the
peg.d.ts
file. Added definitions for thecompiler
andvisitor
modules, AST, andplugins
option in thegenerate()
function. @MingunNow bytecode generation pass is independent from the JavaScript backend. @Mingun
-
Some opcodes from
compiler/opcode.js
were deprecated. Although you shouldn't use them directly because they are not considered as a public API, some plugins use them. For that reason backward compatibility is preserved:- Opcode
MATCH_REGEXP
is deprecated and replaced byMATCH_CHAR_CLASS
with the same value. - Added new opcode
PUSH_EMPTY_STRING
that puts a new empty string on the stack. - Opcode
PUSH
is deprecated because it was used only for pushing empty string constants and they now pushed withPUSH_EMPTY_STRING
.
Instead of relying on the library opcodes it is better to have a copy of them, especially if your plugin replaces both the
generateBytecode
and thegenerateJs
passes. @Mingun - Opcode
-
Default visitor functions, returned by the
visitor.build()
, that just forward call tonode.expression
, now return the result of underlyingvisit
call. @MingunAffected functions:
rule
named
action
labeled
text
simple_and
simple_not
optional
zero_or_more
one_or_more
group
-
Parsers now can use two new functions to get location information:
offset()
andrange()
. Use them if you don't need the whole location information, because it is expensive to compute. These two new functions are always very efficient (back-ported pegjs/pegjs#528). @felix9 and @Mingun -
Add a new option
config.reservedWords: string[]
, avalible for plugins in theiruse()
method. Using this option, a plugin can change the list of words that cannot be used.By default this new option contains an array with reserved JavaScript words @Mingun
-
Several optimizations in the generator. Generated parsers should now be faster and smaller @Mingun
- #112:
"group"
node in the AST now havelocation
information (back-ported) - #143:
peg.d.ts
had some errors in the type descriptions, which were fixed
Released: 2021-04-22
- Added global initializer blocks, which contain code that is only run once
when the grammar is loaded, rather than once every time the parser runs.
Global initializers are surrounded by
{{
and}}
, and must come before the per-parser initializer, which is surrounded by{
and}
. @jaubourg - Back-ported value plucking with
@
from pegjs head. If your rule has a simple action that returns one or more of the values matched by the rule, you can instead mark those expressions with@
and not need an action. This works inside of parens as well. @hildjj
- #10: Better docs for parser options
- #40: Turn on eslint prefer-const
- #58: Release script didn't push tag correctly
- #61: Replace download link with new one in doc (partial fix)
- #71: Readme doesn't include "es" format
- #72: Generated code has wrong version number
Released: 2021-04-16
First release
See previous project for PEG.js changes