Не совсем уверен в лучшем названии, но я объясню, что я спрашиваю, как могу. Предположим, у меня есть следующий файл:
MyCustomClass.php
<?php
namespace MyNamespace;
use FooNamespace\FooClass;
use BarNamespace\BarClass as Bar;
use BazNamespace\BazClass as BazSpecial;
class MyCustomClass {
protected $someDependencies = [];
public function __construct(FooClass $foo, Bar $bar) {
$someDependencies[] = $foo;
$someDependencies[] = $bar;
}
}
Теперь, если бы мне пришлось использовать отражение, я мог бы получить полные имена классов из подсказок типов в конструкции.
Тем не менее, я бы получил FooNamespace\FooClass
а также BarNamespace\BarClass
, Не, FooNamespace\FooClass
а также BarNamespace\Bar
, Я также не получил бы ссылку на BazNamespace\BazClass
,
По сути, мой вопрос: как я могу получить полностью квалифицированные имена от MyCustomClass.php
пока только зная FooClass
, Bar
, а также, BazSpecial
?
Я не хочу использовать анализатор файлов, так как это будет есть производительность. Я хочу быть в состоянии сделать что-то вроде:
$class = new ReflectionClass('MyCustomClass');
...
$class->getUsedClass('FooClass'); // FooNamespace\FooClass
$class->getUsedClass('Bar'); // BarNamespace\BarClass
$class->getUsedClass('BazSpecial'); // BazNamespace\BazClass
Как бы я поступил так?
Поскольку никто не ответил, я полагаю, что не существует простого способа добиться этого. Поэтому я создал свой собственный класс под названием ExtendedReflectionClass
который достигает того, что мне нужно.
Я создал суть файла класса и readme, который находится внизу, так что прокрутите !.
Пример использования:
require 'ExtendedReflectionClass.php';
require 'MyCustomClass.php';
$class = new ExtendedReflectionClass('MyNamespace\Test\MyCustomClass');
$class->getUseStatements();
// [
// [
// 'class' => 'FooNamespace\FooClass',
// 'as' => 'FooClass'
// ],
// [
// 'class' => 'BarNamespace\BarClass',
// 'as' => 'Bar'
// ],
// [
// 'class' => 'BazNamespace\BazClass',
// 'as' => 'BazSpecial'
// ]
// ]
$class->hasUseStatement('FooClass'); // true
$class->hasUseStatement('BarNamespace\BarClass'); // true
$class->hasUseStatement('BazSpecial'); // true
$class->hasUseStatement('SomeNamespace\SomeClass'); // false
Я использую TokenFinderTool для этого.
По сути, он использует токены для извлечения операторов использования.
Насколько я знаю, у объектов \ Reflection в php такого метода пока нет.
Приведенный ниже код извлекает операторы использования импорта из файла с помощью инструмента TokenFinder.
$tokens = token_get_all(file_get_contents("/path/to/MyCompany/MyClass.php"));
a(TokenFinderTool::getUseDependencies($tokens));
Будет выводить:
array (size=9)
0 => string 'Bat\CaseTool' (length=12)
1 => string 'Bat\FileSystemTool' (length=18)
2 => string 'Bat\StringTool' (length=14)
3 => string 'Bat\ValidationTool' (length=18)
4 => string 'CopyDir\AuthorCopyDirUtil' (length=25)
5 => string 'PhpBeast\AuthorTestAggregator' (length=29)
6 => string 'PhpBeast\PrettyTestInterpreter' (length=30)
7 => string 'PhpBeast\Tool\ComparisonErrorTableTool' (length=38)
8 => string 'Tiphaine\TiphaineTool' (length=21)
Примечание: если у вас есть только имя класса, вы можете использовать этот фрагмент:
$o = new \ReflectionClass($className);
$tokens = token_get_all(file_get_contents($$o->getFileName()));
$useStatements = TokenFinderTool::getUseDependencies($tokens);