3.9 KiB
Upgrading from PHP-Parser 3.x to 4.0
PHP version requirements
PHP-Parser now requires PHP 7.0 or newer to run. It is however still possible to parse PHP 5.2-5.6 source code, while running on a newer version.
HHVM is no longer actively supported.
Changes to the node structure
-
Many subnodes that previously held simple strings now store
Identifier
nodes instead (orVarLikeIdentifier
nodes if they have form$ident
). The constructors of the affected nodes will automatically convert strings toIdentifier
s andIdentifier
s implement__toString()
. As such some code continues to work without changes, but anything usingis_string()
, type-strict comparisons or strict-mode may require adjustment. The following is an exhaustive list of all affected subnodes:Const_::$name
NullableType::$type
(for simple types)Param::$type
(for simple types)Expr\ClassConstFetch::$name
Expr\Closure::$returnType
(for simple types)Expr\MethodCall::$name
Expr\PropertyFetch::$name
Expr\StaticCall::$name
Expr\StaticPropertyFetch::$name
(usesVarLikeIdentifier
)Stmt\Class_::$name
Stmt\ClassMethod::$name
Stmt\ClassMethod::$returnType
(for simple types)Stmt\Function_::$name
Stmt\Function_::$returnType
(for simple types)Stmt\Goto_::$name
Stmt\Interface_::$name
Stmt\Label::$name
Stmt\PropertyProperty::$name
(usesVarLikeIdentifier
)Stmt\TraitUseAdaptation\Alias::$method
Stmt\TraitUseAdaptation\Alias::$newName
Stmt\TraitUseAdaptation\Precedence::$method
Stmt\Trait_::$name
Stmt\UseUse::$alias
-
Expression statements (
expr;
) are now represented using aStmt\Expression
node. Previously these statements were directly represented as their constituent expression. -
The
name
subnode ofParam
has been renamed tovar
and now contains aVariable
rather than a plain string. -
The
name
subnode ofStaticVar
has been renamed tovar
and now contains aVariable
rather than a plain string. -
The
var
subnode ofClosureUse
now contains aVariable
rather than a plain string. -
The
var
subnode ofCatch_
now contains aVariable
rather than a plain string. -
The
alias
subnode ofUseUse
is nownull
if no explicit alias is given. As such,use Foo\Bar
anduse Foo\Bar as Bar
are now represented differently. ThegetAlias()
method can be used to get the effective alias, even if it is not explicitly given.
Miscellaneous
- The indentation handling in the pretty printer has been changed (this is only relevant if you
extend the pretty printer). Previously indentation was automatic, and parts were excluded using
pNoindent()
. Now no-indent is the default and newlines that require indentation should use$this->nl
.
Removed functionality
- Removed
type
subnode onClass_
,ClassMethod
andProperty
nodes. Useflags
instead. - The
ClassConst::isStatic()
method has been removed. Constants cannot have a static modifier. - The
NodeTraverser
no longer acceptsfalse
as a return value from aleaveNode()
method.NodeTraverser::REMOVE_NODE
should be returned instead. - The
Node::setLine()
method has been removed. If you really need to, you can usesetAttribute()
instead. - The misspelled
Class_::VISIBILITY_MODIFER_MASK
constant has been dropped in favor ofClass_::VISIBILITY_MODIFIER_MASK
. - The XML serializer has been removed. As such, the classes
Serializer\XML
, andUnserializer\XML
, as well as the interfacesSerializer
andUnserializer
no longer exist. - The
BuilderAbstract
class has been removed. It's functionality is moved intoBuilderHelpers
. However, this is an internal class and should not be used directly. - The
Autoloader
class has been removed in favor of relying on the Composer autoloader.