81 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
| <?php
 | |
| 
 | |
| namespace Doctrine\Common\Annotations;
 | |
| 
 | |
| use ReflectionClass;
 | |
| use ReflectionMethod;
 | |
| use ReflectionProperty;
 | |
| 
 | |
| /**
 | |
|  * Interface for annotation readers.
 | |
|  */
 | |
| interface Reader
 | |
| {
 | |
|     /**
 | |
|      * Gets the annotations applied to a class.
 | |
|      *
 | |
|      * @param ReflectionClass $class The ReflectionClass of the class from which
 | |
|      * the class annotations should be read.
 | |
|      *
 | |
|      * @return array<object> An array of Annotations.
 | |
|      */
 | |
|     public function getClassAnnotations(ReflectionClass $class);
 | |
| 
 | |
|     /**
 | |
|      * Gets a class annotation.
 | |
|      *
 | |
|      * @param ReflectionClass $class          The ReflectionClass of the class from which
 | |
|      *          the class annotations should be read.
 | |
|      * @param class-string<T> $annotationName The name of the annotation.
 | |
|      *
 | |
|      * @return T|null The Annotation or NULL, if the requested annotation does not exist.
 | |
|      *
 | |
|      * @template T
 | |
|      */
 | |
|     public function getClassAnnotation(ReflectionClass $class, $annotationName);
 | |
| 
 | |
|     /**
 | |
|      * Gets the annotations applied to a method.
 | |
|      *
 | |
|      * @param ReflectionMethod $method The ReflectionMethod of the method from which
 | |
|      * the annotations should be read.
 | |
|      *
 | |
|      * @return array<object> An array of Annotations.
 | |
|      */
 | |
|     public function getMethodAnnotations(ReflectionMethod $method);
 | |
| 
 | |
|     /**
 | |
|      * Gets a method annotation.
 | |
|      *
 | |
|      * @param ReflectionMethod $method         The ReflectionMethod to read the annotations from.
 | |
|      * @param class-string<T>  $annotationName The name of the annotation.
 | |
|      *
 | |
|      * @return T|null The Annotation or NULL, if the requested annotation does not exist.
 | |
|      *
 | |
|      * @template T
 | |
|      */
 | |
|     public function getMethodAnnotation(ReflectionMethod $method, $annotationName);
 | |
| 
 | |
|     /**
 | |
|      * Gets the annotations applied to a property.
 | |
|      *
 | |
|      * @param ReflectionProperty $property The ReflectionProperty of the property
 | |
|      * from which the annotations should be read.
 | |
|      *
 | |
|      * @return array<object> An array of Annotations.
 | |
|      */
 | |
|     public function getPropertyAnnotations(ReflectionProperty $property);
 | |
| 
 | |
|     /**
 | |
|      * Gets a property annotation.
 | |
|      *
 | |
|      * @param ReflectionProperty $property       The ReflectionProperty to read the annotations from.
 | |
|      * @param class-string<T>    $annotationName The name of the annotation.
 | |
|      *
 | |
|      * @return T|null The Annotation or NULL, if the requested annotation does not exist.
 | |
|      *
 | |
|      * @template T
 | |
|      */
 | |
|     public function getPropertyAnnotation(ReflectionProperty $property, $annotationName);
 | |
| }
 |