93 lines
2.4 KiB
PHP
93 lines
2.4 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Doctrine\Common\Annotations;
|
||
|
|
||
|
use ReflectionClass;
|
||
|
use ReflectionFunction;
|
||
|
use SplFileObject;
|
||
|
|
||
|
use function is_file;
|
||
|
use function method_exists;
|
||
|
use function preg_quote;
|
||
|
use function preg_replace;
|
||
|
|
||
|
/**
|
||
|
* Parses a file for namespaces/use/class declarations.
|
||
|
*/
|
||
|
final class PhpParser
|
||
|
{
|
||
|
/**
|
||
|
* Parses a class.
|
||
|
*
|
||
|
* @deprecated use parseUseStatements instead
|
||
|
*
|
||
|
* @param ReflectionClass $class A <code>ReflectionClass</code> object.
|
||
|
*
|
||
|
* @return array<string, class-string> A list with use statements in the form (Alias => FQN).
|
||
|
*/
|
||
|
public function parseClass(ReflectionClass $class)
|
||
|
{
|
||
|
return $this->parseUseStatements($class);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Parse a class or function for use statements.
|
||
|
*
|
||
|
* @param ReflectionClass|ReflectionFunction $reflection
|
||
|
*
|
||
|
* @psalm-return array<string, string> a list with use statements in the form (Alias => FQN).
|
||
|
*/
|
||
|
public function parseUseStatements($reflection): array
|
||
|
{
|
||
|
if (method_exists($reflection, 'getUseStatements')) {
|
||
|
return $reflection->getUseStatements();
|
||
|
}
|
||
|
|
||
|
$filename = $reflection->getFileName();
|
||
|
|
||
|
if ($filename === false) {
|
||
|
return [];
|
||
|
}
|
||
|
|
||
|
$content = $this->getFileContent($filename, $reflection->getStartLine());
|
||
|
|
||
|
if ($content === null) {
|
||
|
return [];
|
||
|
}
|
||
|
|
||
|
$namespace = preg_quote($reflection->getNamespaceName());
|
||
|
$content = preg_replace('/^.*?(\bnamespace\s+' . $namespace . '\s*[;{].*)$/s', '\\1', $content);
|
||
|
$tokenizer = new TokenParser('<?php ' . $content);
|
||
|
|
||
|
return $tokenizer->parseUseStatements($reflection->getNamespaceName());
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Gets the content of the file right up to the given line number.
|
||
|
*
|
||
|
* @param string $filename The name of the file to load.
|
||
|
* @param int $lineNumber The number of lines to read from file.
|
||
|
*
|
||
|
* @return string|null The content of the file or null if the file does not exist.
|
||
|
*/
|
||
|
private function getFileContent($filename, $lineNumber)
|
||
|
{
|
||
|
if (! is_file($filename)) {
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
$content = '';
|
||
|
$lineCnt = 0;
|
||
|
$file = new SplFileObject($filename);
|
||
|
while (! $file->eof()) {
|
||
|
if ($lineCnt++ === $lineNumber) {
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
$content .= $file->fgets();
|
||
|
}
|
||
|
|
||
|
return $content;
|
||
|
}
|
||
|
}
|