PHP 8.0: add support for attributes #357
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
PHP 8.0 | BCFile/FunctionDeclarations::get[Method]Parameters(): sync with upstream / bug fix for attributes leaking into type hint
Refs:
PHP 8.0 | Arrays::getDoubleArrowPtr(): handle attributes
As of PHP 8.0, attributes can be attached to functions, closures, arrow functions, classes, interfaces, traits, class constants, properties, methods and method parameters.
Attributes effectively instantiate a new instance of the class being referenced and can pass arguments to the constructor of that class.
As, while uncommon, closures or arrow functions could be used in an array key, there could be an attribute attached to these.
This adjusts the method to skip over attributes to prevent them confusing the double arrow pointer determination.
Includes tests.
Refs:
PHP 8.0 | Namespaces::determineNamespace(): skip over attributes
Efficiency tweak: skip over potentially large attribute declarations when walking up to find a namespace declaration.
Includes test.
Refs:
PHP 8.0 | PassedParameters::getParameters(): handle attributes
As of PHP 8.0, attributes can be attached to functions, closures, arrow functions, classes, interfaces, traits, class constants, properties, methods and method parameters.
Attributes effectively instantiate a new instance of the class being referenced and can pass arguments to the constructor of that class.
This has two implications for the
PassedParameters::getParameters()
method:This commit adds a test confirming that situation [1] is already handled correctly.
Additionally, this commit adds the code to skip over attributes within parameters and adds a test covering that as well.
Refs:
PHP 8.0 | Variables::getMemberProperties(): correctly handle attributes
Sync with upstream PR squizlabs/PHP_CodeSniffer#3203 which ensures that attributes for properties are correctly regarded as "stop points" for gathering property information.
Ref: