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;
 | 
						|
    }
 | 
						|
}
 |