judahnator/trait-aware

Makes your classes aware of the traits they use

v2.0.0 2020-10-10 10:46 UTC

This package is auto-updated.

Last update: 2024-12-11 03:18:20 UTC


README

pipeline status coverage report

This package, quite simply, allows you to find all the traits a class uses recursively. It was inspired by a snippet added to this comment on the php.net documentation.

Installation

Use composer.

composer install judahnator/trait-aware

Usage

This library provides a function you may use that is very similar to the class_uses() function, except it is recursive including both parent classes and trait traits.

You may also "use" a trait \judahnator\TraitAware\TraitAware. It provides a public static getTraits() method which will return all the traits that class uses.

Examples

trait foo 
{
}
trait bar
{
    use foo;
}
class baz
{
    use bar, \judahnator\TraitAware\TraitAware;
}
class bing extends baz
{
}

class_uses(baz::class);
// can see bar and the TraitAware traits, but not bar
[
    "bar" => "bar",
    "judahnator\TraitAware\TraitAware" => "judahnator\TraitAware\TraitAware",
];

class_uses(bing::class);
// can not see any traits
[];

judahnator\TraitAware\class_uses_deep(bing::class);
// can see foo, plus all the traits used by the baz class
[
    "foo" => "foo",
    "bar" => "bar",
    "judahnator\TraitAware\TraitAware" => "judahnator\TraitAware\TraitAware",
];

baz::getTraits();
// same as above but just the values
[
    "foo",
    "bar",
    "judahnator\TraitAware\TraitAware",
];