Releases: nikic/PHP-Parser
Releases Β· nikic/PHP-Parser
PHP-Parser 5.0.2
Fixed
- Fix handling of indentation on next line after opening PHP tag in formatting-preserving pretty printer.
Changed
- Avoid cyclic references in
Parser
objects. This means that no longer used parser objects are immediately destroyed now, instead of requiring cycle GC. - Update
PhpVersion::getNewestSupported()
to report PHP 8.3 instead of PHP 8.2.
PHP-Parser 5.0.1
Changed
- Added check to detect use of PHP-Parser with libraries that define
T_*
compatibility tokens with incorrect type (such as string instead of int). This would lead toTypeError
s down the line. Now anError
will be thrown early to indicate the problem.
PHP-Parser 5.0.0
See the upgrading guide for detailed migration instructions. The changelog is relative to PHP-Parser 4.18.0.
Added
- Added
PhpVersion
class, which is accepted in a number of places (e.g. ParserFactory, Parser, Lexer, PrettyPrinter) and gives more precise control over the PHP version being targeted. - Added PHP 8 parser though it only differs from the PHP 7 parser in concatenation precedence.
- Added
Parser::getTokens()
method. - Added a
Modifiers
class, as a replacement forStmt\Class_::MODIFIER_*
. - Added support for returning an array or
REMOVE_NODE
fromNodeVisitor::enterNode()
. - Added many additional type annotations. PhpStan is now used.
- Added a fuzzing target for PHP-Fuzzer, which was how a lot of pretty printer bugs were found.
- Added
isPromoted()
,isPublic()
,isProtected()
,isPrivate()
andisReadonly()
methods onParam
. - Added support for class constants in trait builder.
- Added
PrettyPrinter
interface. - Added support for formatting preservation when toggling static modifiers.
- The
php-parse
binary now accepts-
as the file name, in which case it will read from stdin. - Added support for
NodeVisitor::REPLACE_WITH_NULL
. - Added support for CRLF newlines in the pretty printer, using the new
newline
option. - Visitors can now be passed directly to the
NodeTraverser
constructor. A separate call toaddVisitor()
is no longer required. - Added support for printing additional attributes (like
kind
) inNodeDumper
. - Added
rawValue
attribute toInterpolatedStringPart
and heredoc/nowdocString_
s, which provides the original, unparsed value. It was previously only available for non-interpolated single/double quoted strings. - Added
Stmt\Block
to represent{}
code blocks. Previously, such code blocks were flattened into the parent statements array.Stmt\Block
will not be created for structures that are typically used with code blocks, for exampleif ($x) { $y; }
will be represented as previously, whileif ($x) { { $x; } }
will have an extraStmt\Block
wrapper.
Changed
- PHP 7.4 is now required to run PHP-Parser.
- Property types have been added where possible.
- Formatting of the standard pretty printer has been adjusted to match PSR-12 more closely.
- The internal token representation now uses a
PhpParser\Token
class, which is compatible with PHP 8 token representation (PhpToken
). - Array destructuring is now always represented using
Expr\List_
nodes, even if it uses[]
syntax. - Renamed a number of node classes, and moved things that were not real expressions/statements outside the
Expr
/Stmt
hierarchy. Compatibility shims for the old names have been retained. - The pretty printer no longer unconditionally wraps
yield
in parentheses, unless the target version is set to older than PHP 7.0. - The pretty printer now defaults to PHP 7.4 as the target version.
- Print
else if { }
instead ofelse { if { } }
. - The
leaveNode()
method on visitors is now invoked in reverse order ofenterNode()
. - Moved
NodeTraverser::REMOVE_NODE
etc. toNodeVisitor::REMOVE_NODE
. The old constants are still available for compatibility. - The
Name
subnodeparts
has been replaced byname
, which stores the name as a string rather than an array of parts separated by namespace separators. ThegetParts()
method returns the old representation. - No longer accept strings for types in Node constructors. Instead, either an
Identifier
,Name
orComplexType
must be passed. Comment::getReformattedText()
now normalizes CRLF newlines to LF newlines.- The
Lexer
no longer accepts options.Lexer\Emulative
only accepts aPhpVersion
. ThestartLexing()
,getTokens()
andhandleHaltCompiler()
methods have been removed. Instead, there is a single methodtokenize()
returning the tokens. - Attribute handling has been moved from the lexer to the parser, and is no longer configurable. The comments, startLine, endLine, startTokenPos, endTokenPos, startFilePos, and endFilePos attributes will always be added.
- The pretty printer now indents heredoc/nowdoc strings if the target version is >= 7.3 (flexible heredoc/nowdoc).
- Use visitor to assign comments. This fixes the long-standing issue where comments were assigned to all nodes sharing a starting position. Now only the outer-most node will hold the comments.
- Improve NodeDumper performance for large dumps.
Removed
- The PHP 5 parser has been removed. The PHP 7 parser has been adjusted to deal with PHP 5 code more gracefully.
- Removed deprecated
Error
constructor taking a line number instead of an attributes array. - The deprecated
Comment::getLine()
,Comment::getTokenPos()
andComment::getFilePos()
methods have been removed. UseComment::getStartLine()
,Comment::getStartTokenPos()
andComment::getStartFilePos()
instead. - Removed
Stmt\Throw_
node, useExpr\Throw_
insideStmt\Expression
instead. - Removed
ParserFactory::create()
.
Fixed
- The pretty printer now uses a more accurate treatment of unary operator precedence, and will only wrap them in parentheses if required. This allowed fixing a number of other precedence related bugs.
- The pretty printer now respects the precedence of
clone
,throw
and arrow functions. - Fixed formatting preservation for alternative elseif/else syntax.
- Fixed checks for when it is safe to print strings as heredoc/nowdoc to accommodate flexible doc string semantics.
- Fixed various cases where
\r
at the end of a doc string could be incorrectly merged into a CRLF sequence with a following\n
. __halt_compiler
is no longer recognized as a semi-reserved keyword, in line with PHP behavior.<?=
is no longer recognized as a semi-reserved keyword.- Fix handling of very large overflowing
\u
escape sequences. - Don't trim leading whitespace in formatting preserving printer.
- Treat DEL as a label character in the formatting preserving printer depending on the targeted PHP version.
- Fix error reporting in emulative lexer without explicitly specified error handler.
- Gracefully handle non-contiguous array indices in the
Differ
.
Deprecated
- The
Node::getLine()
method has been deprecated. UseNode::getStartLine()
instead.
PHP-Parser 5.0.0 Release Candidate 1
See UPGRADE-5.0 for detailed migration instructions. The changelog is relative to beta 1.
Fixed
- Fixed parsing of empty files.
Added
- Added support for printing additional attributes (like
kind
) inNodeDumper
. - Added
rawValue
attribute toInterpolatedStringPart
and heredoc/nowdocString_
s, which provides the original, unparsed value. It was previously only available for non-interpolated single/double quoted strings. - Added
Stmt\Block
to represent{}
code blocks. Previously, such code blocks were flattened into the parent statements array.Stmt\Block
will not be created for structures that are typically used with code blocks, for exampleif ($x) { $y; }
will be represented as previously, whileif ($x) { { $y; } }
will have an extraStmt\Block
wrapper.
Changed
- Use visitor to assign comments. This fixes the long-standing issue where comments were assigned to all nodes sharing a starting position. Now only the outer-most node will hold the comments.
- Don't parse unicode escape sequences when targeting PHP < 7.0.
- Improve NodeDumper performance for large dumps.
Removed
- Removed
Stmt\Throw_
node, useExpr\Throw_
insideStmt\Expression
instead. - Removed
ParserFactory::create()
.
PHP-Parser 4.18.0
Added
- Added methods
ParserFactory::createForNewestSupportedVersion()
andParserFactory::createForHostVersion()
for forward-compatibility with PHP-Parser 5.0.
Fixed
- Fixed missing name resolution of class constant types.
- Fixed class members being dropped if an error is encountered while parsing a later class member (when error recovery is enabled).
Changed
- The
grammar/
directory has been excluded from exported git archives.
PHP-Parser 5.0.0 Beta 1
See UPGRADE-5.0 for detailed migration instructions. The changelog is relative to alpha 3.
Added
- Visitors can now be passed directly to the
NodeTraverser
constructor. A separate call toaddVisitor()
is no longer required.
Changed
- The minimum host PHP version is now PHP 7.4. It is still possible to parse code from older versions. Property types have been added where possible.
- The
Lexer
no longer accepts options.Lexer\Emulative
only accepts aPhpVersion
. ThestartLexing()
,getTokens()
andhandleHaltCompiler()
methods have been removed. Instead, there is a single methodtokenize()
returning the tokens. - The
Parser::getLexer()
method has been replaced byParser::getTokens()
. - Attribute handling has been moved from the lexer to the parser, and is no longer configurable. The comments, startLine, endLine, startTokenPos, endTokenPos, startFilePos, and endFilePos attributes will always be added.
- The pretty printer now defaults to PHP 7.4 as the target version.
- The pretty printer now indents heredoc/nowdoc strings if the target version is >= 7.3 (flexible heredoc/nowdoc).
Removed
- The deprecated
Comment::getLine()
,Comment::getTokenPos()
andComment::getFilePos()
methods have been removed. UseComment::getStartLine()
,Comment::getStartTokenPos()
andComment::getStartFilePos()
instead.
Deprecated
- The
Node::getLine()
method has been deprecated. UseNode::getStartLine()
instead.
PHP-Parser 4.17.1
Fixed
- Fixed phpdoc mismatches for
ClassConst::$type
introduced in previous release.
PHP-Parser 4.17.0
Added
- [PHP 8.3] Added support for typed class constants.
- [PHP 8.3] Added supprot for dynamic class constant fetch.
- [PHP 8.3] Added support for readonly anonymous classes.
Fixed
- Fixed missing required parentheses when pretty printing new with an expression class name.
- Fixed missing required parentheses when pretty printing
(CONST)::$x
and similar.
PHP-Parser 4.16.0
Added
- Added
Name::getParts()
method for forward-compatibility with PHP-Parser 5.
Deprecated
- Deprecated direct access to
Name::$parts
, which will be removed in PHP-Parser 5.
PHP-Parser 5.0.0-alpha3
See UPGRADE-5.0 for detailed migration instructions.
Added
- [PHP 8.3] Added support for typed constants.
- [PHP 8.3] Added support for readonly anonymous classes.
- Added support for
NodeVisitor::REPLACE_WITH_NULL
. - Added support for CRLF newlines in the pretty printer, using the new
newline
option.
Changed
- Use PHP 7.1 as the default target version for the pretty printer.
- Print
else if { }
instead ofelse { if { } }
. - The
leaveNode()
method on visitors is now invoked in reverse order ofenterNode()
. - Moved
NodeTraverser::REMOVE_NODE
etc. toNodeVisitor::REMOVE_NODE
. The old constants are still available for compatibility. - The
Name
subnodeparts
has been replaced byname
, which stores the name as a string rather than an array of parts separated by namespace separators. ThegetParts()
method returns the old representation. - No longer accept strings for types in Node constructors. Instead, either an
Identifier
,Name
orComplexType
must be passed. Comment::getReformattedText()
now normalizes CRLF newlines to LF newlines.
Fixed
- Don't trim leading whitespace in formatting preserving printer.
- Treat DEL as a label character in the formatting preserving printer depending on the targeted PHP version.
- Fix error reporting in emulative lexer without explicitly specified error handler.
- Gracefully handle non-contiguous array indices in the
Differ
.