Examples: "foo"[2], [1, 2, 3][2]
4.0 KiB
Version 0.9.3-dev
-
[PHP 5.5] Add support for constant array / string dereferencing. Examples:
"foo"[2]
,[1, 2, 3][2]
-
[PHP 5.5] Add support for
yield
expressions. This adds a newYield
expression type, with subnodeskey
andvalue
. -
[PHP 5.5] Add support for
finally
. This adds a newfinallyStmts
subnode to theTryCatch
node. If there is no finally clause it will benull
. -
[BC] [PHP 5.5] Add support for
list()
destructuring offoreach
values. Example:foreach ($coords as list($x, $y)) { ... }
This changes the node structure for the previously existing
list(...) = $foo
assignments. Those no longer have a dedicatedAssignList
node; instead they are parsed as a normalAssign
node with aList
asvar
. Similarly the use inforeach
will generate aList
forvalueVar
. -
Fix parsing of
$foo =& new Bar
. It is now properly parsed asAssignRef
(instead ofAssign
).
Version 0.9.2 (07.07.2012)
-
Add
Class->getMethods()
function, which returns all methods contained in thestmts
array of the class node. This does not take inherited methods into account. -
Add
isPublic()
,isProtected()
,isPrivate()
.isAbstract()
,isFinal()
andisStatic()
accessors to theClassMethod
,Property
andClass
nodes. (Property
andClass
obviously only have the accessors relevant to them.) -
Fix parsing of new expressions in parentheses, e.g.
return(new Foo);
. -
[BC] Due to the below changes nodes now optionally accept an
$attributes
array as the last parameter, instead of the previously used$line
and$docComment
parameters. -
Add mechanism for adding attributes to nodes in the lexer.
The following attributes are now added by default:
startLine
: The line the node started in.endLine
: The line the node ended in.comments
: An array of comments. The comments are instances ofPHPParser_Comment
(orPHPParser_Comment_Doc
for doc comments).
The methods
getLine()
andsetLine()
still exist and function as before, but internally operator on thestartLine
attribute.getDocComment()
also continues to exist. It returns the last comment in thecomments
attribute if it is a doc comment, otherwisenull
. AsgetDocComment()
now returns a comment object (which can be modified using->setText()
) thesetDocComment()
method was removed. Comment objects implement a__toString()
method, sogetDocComment()
should continue to work properly with old code. -
[BC] Use inject-once approach for lexer:
Now the lexer is injected only once when creating the parser. Instead of
$parser = new PHPParser_Parser; $parser->parse(new PHPParser_Lexer($code)); $parser->parse(new PHPParser_Lexer($code2));
you write:
$parser = new PHPParser_Parser(new PHPParser_Lexer); $parser->parse($code); $parser->parse($code2);
-
Fix
NameResolver
visitor to also resolve class names incatch
blocks.
Version 0.9.1 (24.04.2012)
-
Add ability to add attributes to nodes:
It is now possible to add attributes to a node using
$node->setAttribute('name', 'value')
and to retrieve them using$node->getAttribute('name' [, 'default'])
. Additionally the existance of an attribute can be checked with$node->hasAttribute('name')
and all attributes can be returned using$node->getAttributes()
. -
Add code generation features: Builders and templates.
For more infos, see the code generation documentation.
-
[BC] Don't traverse nodes merged by another visitor:
If a NodeVisitor returns an array of nodes to merge, these will no longer be traversed by all other visitors. This behavior only caused problems.
-
Fix line numbers for some list structures.
-
Fix XML unserialization of empty nodes.
-
Fix parsing of integers that overflow into floats.
-
Fix emulation of NOWDOC and binary floats.
Version 0.9.0 (05.01.2012)
First version.