ergebnis / attribute-collector
Provides collectors for collecting attributes located on classes, class constants, properties, methods, method parameters, functions, function parameters, and constants.
Installs: 12
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/ergebnis/attribute-collector
Requires
- php: ~8.0.0 || ~8.1.0 || ~8.2.0 || ~8.3.0 || ~8.4.0 || ~8.5.0
Requires (Dev)
- ergebnis/composer-normalize: ^2.48.2
- ergebnis/data-provider: ^3.6.0
- ergebnis/license: ^2.7.0
- ergebnis/php-cs-fixer-config: ^6.58.1
- ergebnis/phpstan-rules: ^2.12.0
- ergebnis/phpunit-slow-test-detector: ^2.20.0
- ergebnis/rector-rules: ^1.9.0
- fakerphp/faker: ^1.24.1
- infection/infection: ~0.26.16
- phpstan/extension-installer: ^1.4.3
- phpstan/phpstan: ^2.1.33
- phpstan/phpstan-deprecation-rules: ^2.0.3
- phpstan/phpstan-phpunit: ^2.0.11
- phpstan/phpstan-strict-rules: ^2.0.7
- phpunit/phpunit: ^9.6.31
- rector/rector: ^2.3.0
This package is auto-updated.
Last update: 2026-01-02 16:56:32 UTC
README
This project provides a composer package with collectors for collecting attributes located on classes, class constants, properties, methods, method parameters, functions, function parameters, and constants.
Installation
Run
composer require ergebnis/attribute-collector
Usage
Attributes
This package provides an Attribute that composes the location of an attribute and a concrete instance of the attribute collected at that location.
You can obtain an Attribute from an attribute collection by using a collector to collect attributes.
Attribute Collection
This package provides an AttributeCollection that composes a collection of attributes.
You can obtain an AttributeCollection by using a collector to collect attributes.
Filtering an attribute collection by attribute class name
You can filter an attribute collection by attribute class name:
<?php declare(strict_types=1); use Ergebnis\AttributeCollector; $attributeClassName = AttributeCollector\Name\ClassName::fromString(\Deprecated::class); /** @var AttributeCollector\AttributeCollection $attributeCollector */ $filteredAttributeCollection = $attributeCollector->whereAttributeClassNameEquals($attributeClassName);
You can filter an attribute collection by attribute location:
<?php declare(strict_types=1); use Ergebnis\AttributeCollector; $attributeLocation = AttributeCollector\Location\ClassMethodLocation::create( AttributeCollector\Name\ClassName::fromString(Foo::class), AttributeCollector\Name\MethodName::fromString('bar') ); /** @var AttributeCollector\AttributeCollection $attributeCollector */ $filteredAttributeCollection = $attributeCollector->whereAttributeLocationEquals($attributeLocation);
Locations
This package provides the following locations that describe where attributes could be or are located:
Location\ClassLocationLocation\ClassConstantLocationLocation\ClassPropertyLocationLocation\ClassMethodLocationLocation\ClassMethodParameterLocationLocation\ConstantLocationLocation\FunctionLocationLocation\FunctionParameterLocation
Collectors
This package provides the following collectors for collecting attributes:
Ergebnis\AttributeCollector\Collector\TraversingAttributeFromClassNameCollectorErgebnis\AttributeCollector\Collector\TraversingAttributeFromLocationCollector
Collector\TraversingAttributeFromClassNameCollector
Use Collector\TraversingAttributeFromClassNameCollector to collect attributes by iterating over and traversing into locations from class names.
Collecting attributes by finding class names
In most of the cases, you might want to collect attributes from classes in your project without having to specify these classes explicitly.
For example, you could use symfony/finder and ergebnis/classy to obtain a list of classy constructs names and then collect attributes from these locations:
<?php declare(strict_types=1); use Ergebnis\AttributeCollector; use Ergebnis\Classy; use Symfony\Component\Finder; $finder = Finder\Finder::create() ->files() ->in(__DIR__ . '/src'); $classyConstructCollector = new Classy\Collector\DefaultConstructFromFinderCollector(new Classy\Collector\PhpTokenTokenizeConstructFromSourceCollector())); $classyConstructs = $classyConstructCollector->collectFromFinder($finder); $classNames = array_map(static function (Classy\Construct $construct): AttributeCollector\Name\ClassName { return AttributeCollector\Name\ClassName::fromString($construct->name()->toString()); }, $classyConstructs); $attributeCollector = new AttributeCollector\Collector\TraversingAttributeFromClassNameCollector(); $attributeCollection = $attributeCollector->collectFromClassName(...$classNames); foreach ($attributeCollection->toArray() as $attribute) { $instance = $attribute->instance(); // inspect or process concrete attribute instance here }
Collecting attributes by specifying class names
In other cases, you might want to collect attributes from specific class names that you already know.
<?php declare(strict_types=1); use Ergebnis\AttributeCollector; $classNames = [ AttributeCollector\Name\ClassName::fromString(Foo::class), AttributeCollector\Name\ClassName::fromString(Bar::class), AttributeCollector\Name\ClassName::fromString(Baz::class), ]; $attributeCollector = new AttributeCollector\Collector\TraversingAttributeFromClassNameCollector(); $attributeCollection = $attributeCollector->collectFromClassName(...$classNames); foreach ($attributeCollection->toArray() as $attribute) { $instance = $attribute->instance(); // inspect or process concrete attribute instance here }
Collector\TraversingAttributeFromLocationCollector
Use Collector\TraversingAttributeFromLocationCollector to collect attributes by iterating over and traversing into known locations.
<?php declare(strict_types=1); use Ergebnis\AttributeCollector; $locations = [ AttributeCollector\Location\ClassLocation::create(AttributeCollector\Name\ClassName::fromString(Foo::class)), AttributeCollector\Location\ClassPropertyLocation::create( AttributeCollector\Name\ClassName::fromString(Foo::class), AttributeCollector\Name\PropertyName::fromString('bar') ), AttributeCollector\Location\ClassMethodLocation::create( AttributeCollector\Name\ClassName::fromString(Foo::class), AttributeCollector\Name\MethodName::fromString('baz') ), AttributeCollector\Location\ClassMethodParameterLocation::create( AttributeCollector\Name\ClassName::fromString(Foo::class), AttributeCollector\Name\MethodName::fromString('baz'), AttributeCollector\Name\ParameterName::fromString('qux') ), AttributeCollector\Location\FunctionLocation::create(AttributeCollector\Name\FunctionName::fromString('baz')), AttributeCollector\Location\ConstantLocation::create(AttributeCollector\Name\ConstantName::fromString('BAZ')), ]; $attributeCollector = new AttributeCollector\Collector\TraversingAttributeFromLocationCollector(); $attributeCollection = $attributeCollector->collectFromLocation(...$locations); foreach ($attributeCollection->toArray() as $attribute) { $instance = $attribute->instance(); // inspect or process concrete attribute instance here }
Changelog
The maintainers of this project record notable changes to this project in a changelog.
Contributing
The maintainers of this project suggest following the contribution guide.
Code of Conduct
The maintainers of this project ask contributors to follow the code of conduct.
General Support Policy
The maintainers of this project provide limited support.
PHP Version Support Policy
This project supports PHP versions with active and security support.
The maintainers of this project add support for a PHP version following its initial release and drop support for a PHP version when it has reached the end of security support.
Security Policy
This project has a security policy.
License
This project uses the MIT license.
Social
Follow @localheinz and @ergebnis on Twitter.