envorradev / file-class-resolver
Requires
- php: ^8.1
- nikic/php-parser: ^4.15
Requires (Dev)
- phpstan/phpstan: ^1.8
- phpunit/phpunit: ^9.5
- ramsey/composer-repl: ^1.4
This package is auto-updated.
Last update: 2024-10-14 04:13:06 UTC
README
A simple tool to resolve the fully qualified class name and an instance of the class given the path to the file.
Install
$ composer require envorradev/file-class-resolver
Usage
The following examples will use the following sample class:
namespace SomeNamespace\SomeFolder; class SomeClass { public function __construct( public string $aRequiredString, public int $anOptionalInt = 5, ) {} }
$filename = __DIR__.'/SomeFolder/SomeClass.php';
They also assume you have imported the resolver class via:
use Envorra\FileClassResolver\ClassResolver;
Resolve a Fully Qualified Class Name
ClassResolver::resolve($filename);
Returns
'SomeNamespace\SomeFolder\SomeClass'
Make an Instance
Class with No Required Parameters
ClassResolver::make($someOtherClassPath);
Class with Required Parameters
Pass the parameters as an array as the parameter for the make
method:
ClassResolver::make($filename, ['string value', 10]);
Only the required parameters need to be passed:
ClassResolver::make($filename, ['string value']);
You can pass the parameters as named parameters:
ClassResolver::make($filename, ['aRequiredString' => 'string value', 'anOptionalInt' => 7]);
When using named parameters, the order does not matter:
ClassResolver::make($filename, ['anOptionalInt' => 7, 'aRequiredString' => 'string value']);
Get the Resolver Instance
ClassResolver::resolver($filename);
Returns a ClassResolver
Instance.
Available ClassResolver Methods
In the below examples:
$resolver = ClassResolver::resolve($filename);
getClass(): ?string
Gets the fully qualified class name.
Same as ClassResolver::resolve($filename)
and $resolver->getFullyQualifiedClassName()
$resolver->getClass();
Returns
'SomeNamespace\SomeFolder\SomeClass'
getClassInstance(array $parameters = []): ?object
Get an instance of the class.
Same as ClassResolver::make($filename, $parameters)
$resolver->getClassInstance(['string']);
Returns an instance of SomeClass
getClassName(): ?string
Gets onlt the name of the class.
$resolver->getClassName();
Returns
'SomeClass'
getClassNode(): \PhpParser\Node\Stmt\Class_
Gets the \PhpParser\Node\Stmt\Class_
node.
See: nikic/php-parser and Class_
$resolver->getClassNode();
Returns something like:
PhpParser\Node\Stmt\Class_ {#8563 +name: PhpParser\Node\Identifier {#8550 +name: "SomeClass", }, +stmts: [ PhpParser\Node\Stmt\ClassMethod {#8562 +flags: 1, +byRef: false, +name: PhpParser\Node\Identifier {#8551 +name: "__construct", }, +params: [ PhpParser\Node\Param {#8554 +type: PhpParser\Node\Identifier {#8553 +name: "string", }, +byRef: false, +variadic: false, +var: PhpParser\Node\Expr\Variable {#8552 +name: "aRequiredString", }, +default: null, +flags: 1, +attrGroups: [], }, PhpParser\Node\Param {#8557 +type: PhpParser\Node\Identifier {#8556 +name: "int", }, +byRef: false, +variadic: false, +var: PhpParser\Node\Expr\Variable {#8555 +name: "anOptionalInt", }, +default: null, +flags: 1, +attrGroups: [], }, ], +returnType: null, +stmts: [], +attrGroups: [], }, ], +attrGroups: [], +namespacedName: null, +flags: 0, +extends: null, +implements: [], }
getFullyQualifiedClassName(): ?string
Gets the fully qualified class name.
Same as ClassResolver::resolve($filename)
and $resolver->getClass()
$resolver->getFullyQualifiedClassName();
Returns
'SomeNamespace\SomeFolder\SomeClass'
getNamespace(): ?string
Gets only the namespace of the class.
$resolver->getNamespace();
Returns
'SomeNamespace\SomeFolder'
getNamespaceNode(): \PhpParser\Node\Stmt\Namespace_
Gets the \PhpParser\Node\Stmt\Namespace_
node.
See: nikic/php-parser and Namespace_
$resolver->getNamespaceNode();
Returns something like:
PhpParser\Node\Stmt\Namespace_ {#8549 +name: PhpParser\Node\Name {#8548 +parts: [ "SomeNamespace", "SomeFolder", ], }, +stmts: [ PhpParser\Node\Stmt\Class_ {#8563 +name: PhpParser\Node\Identifier {#8550 +name: "SomeClass", }, +stmts: [ PhpParser\Node\Stmt\ClassMethod {#8562 +flags: 1, +byRef: false, +name: PhpParser\Node\Identifier {#8551 +name: "__construct", }, +params: [ PhpParser\Node\Param {#8554 +type: PhpParser\Node\Identifier {#8553 +name: "string", }, +byRef: false, +variadic: false, +var: PhpParser\Node\Expr\Variable {#8552 +name: "aRequiredString", }, +default: null, +flags: 1, +attrGroups: [], }, PhpParser\Node\Param {#8557 +type: PhpParser\Node\Identifier {#8556 +name: "int", }, +byRef: false, +variadic: false, +var: PhpParser\Node\Expr\Variable {#8555 +name: "anOptionalInt", }, +default: null, +flags: 1, +attrGroups: [], }, ], +returnType: null, +stmts: [], +attrGroups: [], }, ], +attrGroups: [], +namespacedName: null, +flags: 0, +extends: null, +implements: [], }, ], }