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