Pyparsing 3.1.0a1 #468
ptmcg
announced in
Announcements
Replies: 0 comments
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
-
NOTE: In the future release 3.2.0, use of many of the pre-PEP8 methods (such as
ParserElement.parseString
) will start to raiseDeprecationWarnings
. 3.2.0 should get released some time later in 2023. I currently plan to completely drop the pre-PEP8 methods in pyparsing 4.0, though we won't see that release until at least late 2023 if not 2024. So there is plenty of time to convert existing parsers to the new function names before the old functions are completely removed. (Big help from Devin J. Pohly in structuring the code to enable this peaceful transition.)Version 3.2.0 will also discontinue support for Python versions 3.6 and 3.7.
API ENHANCEMENT:
Optional(expr)
may now be written asexpr | ""
This will make this code:
writable as:
Some related changes implemented as part of this work:
Literal("")
now internally generates anEmpty()
(and no longer raises an exception)Empty
is now a subclass ofLiteral
Suggested by Antony Lee (issue Support
... | ""
as alias forOpt(...)
Β #412), PR (Use Literal.__new__ to select optimized subclassesΒ #413) by Devin J. Pohly.Added new class property
identifier
to all Unicode set classes inpyparsing.unicode
, using the class's values forcls.identchars
andcls.identbodychars
. Now Unicode-aware parsers that formerly wrote:can now write:
Reworked
delimited_list
function into the newDelimitedList
class.DelimitedList
has the same constructor interface asdelimited_list
, and in this release,delimited_list
changes from a function to a synonym forDelimitedList
.delimited_list
and the olderdelimitedList
method will be deprecated in a future release, in favor ofDelimitedList
.Added new class method
ParserElement.using_each
, to simplify code that creates a sequence ofLiterals
,Keywords
, or otherParserElement
subclasses.For instance, to define suppressable punctuation, you would previously write:
You can now write:
using_each
will also accept optional keyword args, which it will pass through to the class initializer. Here is an expression for single-letter variable names that might be used in an algebraic expression:Added new builtin
python_quoted_string
, which will match any form of single-line or multiline quoted strings defined in Python. (Inspired by discussion with Andreas SchΓΆrgenhumer in Issuepyparsing.python_style_comment.suppress()
does not work with multi-line stringsΒ #421.)Extended
expr[]
notation for repetition ofexpr
to accept a slice, where the slice's stop value indicates astop_on
expression:Prints:
ParserElement.validate()
is deprecated. It predates the support for left-recursive parsers, and was prone to false positives (warning that a grammar was invalid when it was in fact valid). It will be removed in a future pyparsing release. In its place, developers should use debugging and analytical tools, such asParserElement.set_debug()
andParserElement.create_diagram()
. (Raised in Issue Semantics ofvalidate()
is unclearΒ #444, thanks Andrea Micheli!)Added bool
embed
argument toParserElement.create_diagram()
. When passed as True, the resulting diagram will omit the<DOCTYPE>
,<HEAD>
, and<BODY>
tags so that it can be embedded in other HTML source. (Useful when embedding a call tocreate_diagram()
in a PyScript HTML page.)Added
recurse
argument toParserElement.set_debug
to set the debug flag on an expression and all of its sub-expressions. Requested by multimeric in Issue Recursively enable debugΒ #399.Added 'Β·' (Unicode MIDDLE DOT) to the set of
pp.unicode.Latin1.identbodychars
.Fixed bug in
Word
whenmax=2
. Also added performance enhancement when specifyingexact
argument. Reported in issue Word with max= parses incorrectlyΒ #409 by panda-34, nice catch!Word
arguments are now validated ifmin
andmax
are both given, thatmin
<=max
; raisesValueError
if values are invalid.Fixed bug in
srange
, when parsing escaped '/' and '' inside a range set.Fixed exception messages for some
ParserElements
with custom names, which instead showed their contained expression names.Fixed bug in pyparsing.common.url, when input URL is not alone on an input line. Fixes Issue ZeroOrMore can only handle one URLΒ #459, reported by David Kennedy.
Multiple added and corrected type annotations. With much help from Stephen Rosen, thanks!
Some documentation and error message clarifications on pyparsing's keyword logic, cited by Basil Peace.
General docstring cleanup for Sphinx doc generation, PRs submitted by Devin J. Pohly. A dirty job, but someone has to do it - much appreciated!
invRegex.py example renamed to inv_regex.py and updated to PEP-8 variable and method naming. PR submitted by Ross J. Duff, thanks!
Removed examples sparser.py and pymicko.py, since each included its own GPL license in the header. Since this conflicts with pyparsing's MIT license, they were removed from the distribution to avoid confusion among those making use of them in their own projects.
This discussion was created from the release Pyparsing 3.1.0a1.
Beta Was this translation helpful? Give feedback.
All reactions