the whole shebang
This commit is contained in:
		
							
								
								
									
										79
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,79 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| /** | ||||
|  * Annotations class | ||||
|  * | ||||
|  * @author  Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author  Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author  Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author  Roman Borschel <roman@code-factory.org> | ||||
|  */ | ||||
| class Annotation | ||||
| { | ||||
|     /** | ||||
|      * Value property. Common among all derived classes. | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     public $value; | ||||
|  | ||||
|     /** | ||||
|      * Constructor | ||||
|      * | ||||
|      * @param array $data Key-value for properties to be defined in this class | ||||
|      */ | ||||
|     public final function __construct(array $data) | ||||
|     { | ||||
|         foreach ($data as $key => $value) { | ||||
|             $this->$key = $value; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Error handler for unknown property accessor in Annotation class. | ||||
|      * | ||||
|      * @param string $name Unknown property name | ||||
|      * | ||||
|      * @throws \BadMethodCallException | ||||
|      */ | ||||
|     public function __get($name) | ||||
|     { | ||||
|         throw new \BadMethodCallException( | ||||
|             sprintf("Unknown property '%s' on annotation '%s'.", $name, get_class($this)) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Error handler for unknown property mutator in Annotation class. | ||||
|      * | ||||
|      * @param string $name Unkown property name | ||||
|      * @param mixed $value Property value | ||||
|      * | ||||
|      * @throws \BadMethodCallException | ||||
|      */ | ||||
|     public function __set($name, $value) | ||||
|     { | ||||
|         throw new \BadMethodCallException( | ||||
|             sprintf("Unknown property '%s' on annotation '%s'.", $name, get_class($this)) | ||||
|         ); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										47
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Attribute.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Attribute.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations\Annotation; | ||||
|  | ||||
| /** | ||||
|  * Annotation that can be used to signal to the parser | ||||
|  * to check the attribute type during the parsing process. | ||||
|  * | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  * | ||||
|  * @Annotation | ||||
|  */ | ||||
| final class Attribute | ||||
| { | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     public $name; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     public $type; | ||||
|  | ||||
|     /** | ||||
|      * @var boolean | ||||
|      */ | ||||
|     public $required = false; | ||||
| } | ||||
							
								
								
									
										37
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Attributes.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Attributes.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations\Annotation; | ||||
|  | ||||
| /** | ||||
|  * Annotation that can be used to signal to the parser | ||||
|  * to check the types of all declared attributes during the parsing process. | ||||
|  * | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  * | ||||
|  * @Annotation | ||||
|  */ | ||||
| final class Attributes | ||||
| { | ||||
|     /** | ||||
|      * @var array<Doctrine\Common\Annotations\Annotation\Attribute> | ||||
|      */ | ||||
|     public $value; | ||||
| } | ||||
							
								
								
									
										85
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Enum.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										85
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Enum.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,85 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations\Annotation; | ||||
|  | ||||
| /** | ||||
|  * Annotation that can be used to signal to the parser | ||||
|  * to check the available values during the parsing process. | ||||
|  * | ||||
|  * @since  2.4 | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  * | ||||
|  * @Annotation | ||||
|  * @Attributes({ | ||||
|  *    @Attribute("value",   required = true,  type = "array"), | ||||
|  *    @Attribute("literal", required = false, type = "array") | ||||
|  * }) | ||||
|  */ | ||||
| final class Enum | ||||
| { | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     public $value; | ||||
|  | ||||
|     /** | ||||
|      * Literal target declaration. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     public $literal; | ||||
|  | ||||
|     /** | ||||
|      * Annotation construct | ||||
|      * | ||||
|      * @param array $values | ||||
|      * | ||||
|      * @throws \InvalidArgumentException | ||||
|      */ | ||||
|     public function __construct(array $values) | ||||
|     { | ||||
|         if ( ! isset($values['literal'])) { | ||||
|             $values['literal'] = array(); | ||||
|         } | ||||
|  | ||||
|         foreach ($values['value'] as $var) { | ||||
|             if( ! is_scalar($var)) { | ||||
|                 throw new \InvalidArgumentException(sprintf( | ||||
|                     '@Enum supports only scalar values "%s" given.', | ||||
|                     is_object($var) ? get_class($var) : gettype($var) | ||||
|                 )); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         foreach ($values['literal'] as $key => $var) { | ||||
|             if( ! in_array($key, $values['value'])) { | ||||
|                 throw new \InvalidArgumentException(sprintf( | ||||
|                     'Undefined enumerator value "%s" for literal "%s".', | ||||
|                     $key , $var | ||||
|                 )); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $this->value    = $values['value']; | ||||
|         $this->literal  = $values['literal']; | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										54
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/IgnoreAnnotation.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/IgnoreAnnotation.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations\Annotation; | ||||
|  | ||||
| /** | ||||
|  * Annotation that can be used to signal to the parser to ignore specific | ||||
|  * annotations during the parsing process. | ||||
|  * | ||||
|  * @Annotation | ||||
|  * @author Johannes M. Schmitt <schmittjoh@gmail.com> | ||||
|  */ | ||||
| final class IgnoreAnnotation | ||||
| { | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     public $names; | ||||
|  | ||||
|     /** | ||||
|      * Constructor | ||||
|      * | ||||
|      * @param array $values | ||||
|      * | ||||
|      * @throws \RuntimeException | ||||
|      */ | ||||
|     public function __construct(array $values) | ||||
|     { | ||||
|         if (is_string($values['value'])) { | ||||
|             $values['value'] = array($values['value']); | ||||
|         } | ||||
|         if (!is_array($values['value'])) { | ||||
|             throw new \RuntimeException(sprintf('@IgnoreAnnotation expects either a string name, or an array of strings, but got %s.', json_encode($values['value']))); | ||||
|         } | ||||
|  | ||||
|         $this->names = $values['value']; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										33
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Required.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Required.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations\Annotation; | ||||
|  | ||||
| /** | ||||
|  * Annotation that can be used to signal to the parser | ||||
|  * to check if that attribute is required during the parsing process. | ||||
|  * | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  * | ||||
|  * @Annotation | ||||
|  */ | ||||
| final class Required | ||||
| { | ||||
| } | ||||
							
								
								
									
										107
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Target.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Annotation/Target.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations\Annotation; | ||||
|  | ||||
| /** | ||||
|  * Annotation that can be used to signal to the parser | ||||
|  * to check the annotation target during the parsing process. | ||||
|  * | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  * | ||||
|  * @Annotation | ||||
|  */ | ||||
| final class Target | ||||
| { | ||||
|     const TARGET_CLASS              = 1; | ||||
|     const TARGET_METHOD             = 2; | ||||
|     const TARGET_PROPERTY           = 4; | ||||
|     const TARGET_ANNOTATION         = 8; | ||||
|     const TARGET_ALL                = 15; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private static $map = array( | ||||
|         'ALL'         => self::TARGET_ALL, | ||||
|         'CLASS'       => self::TARGET_CLASS, | ||||
|         'METHOD'      => self::TARGET_METHOD, | ||||
|         'PROPERTY'    => self::TARGET_PROPERTY, | ||||
|         'ANNOTATION'  => self::TARGET_ANNOTATION, | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     public $value; | ||||
|  | ||||
|     /** | ||||
|      * Targets as bitmask. | ||||
|      * | ||||
|      * @var integer | ||||
|      */ | ||||
|     public $targets; | ||||
|  | ||||
|     /** | ||||
|      * Literal target declaration. | ||||
|      * | ||||
|      * @var integer | ||||
|      */ | ||||
|     public $literal; | ||||
|  | ||||
|     /** | ||||
|      * Annotation construct | ||||
|      * | ||||
|      * @param array $values | ||||
|      * | ||||
|      * @throws \InvalidArgumentException | ||||
|      */ | ||||
|     public function __construct(array $values) | ||||
|     { | ||||
|         if (!isset($values['value'])){ | ||||
|             $values['value'] = null; | ||||
|         } | ||||
|         if (is_string($values['value'])){ | ||||
|             $values['value'] = array($values['value']); | ||||
|         } | ||||
|         if (!is_array($values['value'])){ | ||||
|             throw new \InvalidArgumentException( | ||||
|                 sprintf('@Target expects either a string value, or an array of strings, "%s" given.', | ||||
|                     is_object($values['value']) ? get_class($values['value']) : gettype($values['value']) | ||||
|                 ) | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         $bitmask = 0; | ||||
|         foreach ($values['value'] as $literal) { | ||||
|             if(!isset(self::$map[$literal])){ | ||||
|                 throw new \InvalidArgumentException( | ||||
|                     sprintf('Invalid Target "%s". Available targets: [%s]', | ||||
|                             $literal,  implode(', ', array_keys(self::$map))) | ||||
|                 ); | ||||
|             } | ||||
|             $bitmask += self::$map[$literal]; | ||||
|         } | ||||
|  | ||||
|         $this->targets  = $bitmask; | ||||
|         $this->value    = $values['value']; | ||||
|         $this->literal  = implode(', ', $this->value); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										158
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,158 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| /** | ||||
|  * Description of AnnotationException | ||||
|  * | ||||
|  * @since   2.0 | ||||
|  * @author  Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author  Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author  Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author  Roman Borschel <roman@code-factory.org> | ||||
|  */ | ||||
| class AnnotationException extends \Exception | ||||
| { | ||||
|     /** | ||||
|      * Creates a new AnnotationException describing a Syntax error. | ||||
|      * | ||||
|      * @param string $message Exception message | ||||
|      * @return AnnotationException | ||||
|      */ | ||||
|     public static function syntaxError($message) | ||||
|     { | ||||
|         return new self('[Syntax Error] ' . $message); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Creates a new AnnotationException describing a Semantical error. | ||||
|      * | ||||
|      * @param string $message Exception message | ||||
|      * @return AnnotationException | ||||
|      */ | ||||
|     public static function semanticalError($message) | ||||
|     { | ||||
|         return new self('[Semantical Error] ' . $message); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Creates a new AnnotationException describing a constant semantical error. | ||||
|      * | ||||
|      * @since 2.3 | ||||
|      * @param string $identifier | ||||
|      * @param string $context | ||||
|      * @return AnnotationException | ||||
|      */ | ||||
|     public static function semanticalErrorConstants($identifier, $context = null) | ||||
|     { | ||||
|         return self::semanticalError(sprintf( | ||||
|             "Couldn't find constant %s%s", $identifier, | ||||
|             $context ? ", $context." : "." | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Creates a new AnnotationException describing an error which occurred during | ||||
|      * the creation of the annotation. | ||||
|      * | ||||
|      * @since 2.2 | ||||
|      * @param string $message | ||||
|      * @return AnnotationException | ||||
|      */ | ||||
|     public static function creationError($message) | ||||
|     { | ||||
|         return new self('[Creation Error] ' . $message); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Creates a new AnnotationException describing an type error of an attribute. | ||||
|      * | ||||
|      * @since 2.2 | ||||
|      * @param string $attributeName | ||||
|      * @param string $annotationName | ||||
|      * @param string $context | ||||
|      * @param string $expected | ||||
|      * @param mixed $actual | ||||
|      * @return AnnotationException | ||||
|      */ | ||||
|     public static function typeError($attributeName, $annotationName, $context, $expected, $actual) | ||||
|     { | ||||
|         return new self(sprintf( | ||||
|             '[Type Error] Attribute "%s" of @%s declared on %s expects %s, but got %s.', | ||||
|             $attributeName, | ||||
|             $annotationName, | ||||
|             $context, | ||||
|             $expected, | ||||
|             is_object($actual) ? 'an instance of '.get_class($actual) : gettype($actual) | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Creates a new AnnotationException describing an required error of an attribute. | ||||
|      * | ||||
|      * @since 2.2 | ||||
|      * @param string $attributeName | ||||
|      * @param string $annotationName | ||||
|      * @param string $context | ||||
|      * @param string $expected | ||||
|      * @return AnnotationException | ||||
|      */ | ||||
|     public static function requiredError($attributeName, $annotationName, $context, $expected) | ||||
|     { | ||||
|         return new self(sprintf( | ||||
|             '[Type Error] Attribute "%s" of @%s declared on %s expects %s. This value should not be null.', | ||||
|             $attributeName, | ||||
|             $annotationName, | ||||
|             $context, | ||||
|             $expected | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Creates a new AnnotationException describing a invalid enummerator. | ||||
|      * | ||||
|      * @since 2.4 | ||||
|      * @param string $attributeName | ||||
|      * @param string $annotationName | ||||
|      * @param string $context | ||||
|      * @param array  $available | ||||
|      * @param mixed  $given | ||||
|      * @return AnnotationException | ||||
|      */ | ||||
|     public static function enumeratorError($attributeName, $annotationName, $context, $available, $given) | ||||
|     { | ||||
|         throw new self(sprintf( | ||||
|             '[Enum Error] Attribute "%s" of @%s declared on %s accept only [%s], but got %s.', | ||||
|             $attributeName,  | ||||
|             $annotationName, | ||||
|             $context, | ||||
|             implode(', ', $available), | ||||
|             is_object($given) ? get_class($given) : $given | ||||
|         )); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return AnnotationException | ||||
|      */ | ||||
|     public static function optimizerPlusSaveComments() | ||||
|     { | ||||
|         throw new self("You have to enable opcache.save_comments=1 or zend_optimizerplus.save_comments=1."); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										318
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationReader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										318
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationReader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,318 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| use Doctrine\Common\Annotations\Annotation\IgnoreAnnotation; | ||||
| use Doctrine\Common\Annotations\Annotation\Target; | ||||
| use Closure; | ||||
| use ReflectionClass; | ||||
| use ReflectionMethod; | ||||
| use ReflectionProperty; | ||||
|  | ||||
| /** | ||||
|  * A reader for docblock annotations. | ||||
|  * | ||||
|  * @author  Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author  Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author  Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author  Roman Borschel <roman@code-factory.org> | ||||
|  * @author  Johannes M. Schmitt <schmittjoh@gmail.com> | ||||
|  */ | ||||
| class AnnotationReader implements Reader | ||||
| { | ||||
|     /** | ||||
|      * Global map for imports. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private static $globalImports = array( | ||||
|         'ignoreannotation' => 'Doctrine\Common\Annotations\Annotation\IgnoreAnnotation', | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * A list with annotations that are not causing exceptions when not resolved to an annotation class. | ||||
|      * | ||||
|      * The names are case sensitive. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private static $globalIgnoredNames = array( | ||||
|         'access'=> true, 'author'=> true, 'copyright'=> true, 'deprecated'=> true, | ||||
|         'example'=> true, 'ignore'=> true, 'internal'=> true, 'link'=> true, 'see'=> true, | ||||
|         'since'=> true, 'tutorial'=> true, 'version'=> true, 'package'=> true, | ||||
|         'subpackage'=> true, 'name'=> true, 'global'=> true, 'param'=> true, | ||||
|         'return'=> true, 'staticvar'=> true, 'category'=> true, 'staticVar'=> true, | ||||
|         'static'=> true, 'var'=> true, 'throws'=> true, 'inheritdoc'=> true, | ||||
|         'inheritDoc'=> true, 'license'=> true, 'todo'=> true, 'TODO'=> true, | ||||
|         'deprec'=> true, 'property' => true, 'method' => true, | ||||
|         'abstract'=> true, 'exception'=> true, 'magic' => true, 'api' => true, | ||||
|         'final'=> true, 'filesource'=> true, 'throw' => true, 'uses' => true, | ||||
|         'usedby'=> true, 'private' => true, 'Annotation' => true, 'override' => true, | ||||
|         'codeCoverageIgnore' => true, 'codeCoverageIgnoreStart' => true, 'codeCoverageIgnoreEnd' => true, | ||||
|         'Required' => true, 'Attribute' => true, 'Attributes' => true, | ||||
|         'Target' => true, 'SuppressWarnings' => true, | ||||
|         'ingroup' => true, 'code' => true, 'endcode' => true, | ||||
|         'package_version' => true, 'fixme' => true | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * Add a new annotation to the globally ignored annotation names with regard to exception handling. | ||||
|      * | ||||
|      * @param string $name | ||||
|      */ | ||||
|     static public function addGlobalIgnoredName($name) | ||||
|     { | ||||
|         self::$globalIgnoredNames[$name] = true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Annotations Parser | ||||
|      * | ||||
|      * @var \Doctrine\Common\Annotations\DocParser | ||||
|      */ | ||||
|     private $parser; | ||||
|  | ||||
|     /** | ||||
|      * Annotations Parser used to collect parsing metadata | ||||
|      * | ||||
|      * @var \Doctrine\Common\Annotations\DocParser | ||||
|      */ | ||||
|     private $preParser; | ||||
|  | ||||
|     /** | ||||
|      * PHP Parser used to collect imports. | ||||
|      * | ||||
|      * @var \Doctrine\Common\Annotations\PhpParser | ||||
|      */ | ||||
|     private $phpParser; | ||||
|  | ||||
|     /** | ||||
|      * In-memory cache mechanism to store imported annotations per class. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $imports = array(); | ||||
|  | ||||
|     /** | ||||
|      * In-memory cache mechanism to store ignored annotations per class. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $ignoredAnnotationNames = array(); | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * Initializes a new AnnotationReader. | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|         if (extension_loaded('Zend Optimizer+') && (ini_get('zend_optimizerplus.save_comments') === "0" || ini_get('opcache.save_comments') === "0")) { | ||||
|             throw AnnotationException::optimizerPlusSaveComments(); | ||||
|         } | ||||
|  | ||||
|         if (extension_loaded('opcache') && ini_get('opcache.save_comments') == 0) { | ||||
|             throw AnnotationException::optimizerPlusSaveComments(); | ||||
|         } | ||||
|  | ||||
|         AnnotationRegistry::registerFile(__DIR__ . '/Annotation/IgnoreAnnotation.php'); | ||||
|  | ||||
|         $this->parser = new DocParser; | ||||
|  | ||||
|         $this->preParser = new DocParser; | ||||
|         $this->preParser->setImports(self::$globalImports); | ||||
|         $this->preParser->setIgnoreNotImportedAnnotations(true); | ||||
|  | ||||
|         $this->phpParser = new PhpParser; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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 An array of Annotations. | ||||
|      */ | ||||
|     public function getClassAnnotations(ReflectionClass $class) | ||||
|     { | ||||
|         $this->parser->setTarget(Target::TARGET_CLASS); | ||||
|         $this->parser->setImports($this->getImports($class)); | ||||
|         $this->parser->setIgnoredAnnotationNames($this->getIgnoredAnnotationNames($class)); | ||||
|  | ||||
|         return $this->parser->parse($class->getDocComment(), 'class ' . $class->getName()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a class annotation. | ||||
|      * | ||||
|      * @param ReflectionClass $class The ReflectionClass of the class from which | ||||
|      *                               the class annotations should be read. | ||||
|      * @param string $annotationName The name of the annotation. | ||||
|      * @return mixed The Annotation or NULL, if the requested annotation does not exist. | ||||
|      */ | ||||
|     public function getClassAnnotation(ReflectionClass $class, $annotationName) | ||||
|     { | ||||
|         $annotations = $this->getClassAnnotations($class); | ||||
|  | ||||
|         foreach ($annotations as $annotation) { | ||||
|             if ($annotation instanceof $annotationName) { | ||||
|                 return $annotation; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the annotations applied to a property. | ||||
|      * | ||||
|      * @param ReflectionProperty $property The ReflectionProperty of the property | ||||
|      *                                     from which the annotations should be read. | ||||
|      * @return array An array of Annotations. | ||||
|      */ | ||||
|     public function getPropertyAnnotations(ReflectionProperty $property) | ||||
|     { | ||||
|         $class = $property->getDeclaringClass(); | ||||
|         $context = 'property ' . $class->getName() . "::\$" . $property->getName(); | ||||
|         $this->parser->setTarget(Target::TARGET_PROPERTY); | ||||
|         $this->parser->setImports($this->getImports($class)); | ||||
|         $this->parser->setIgnoredAnnotationNames($this->getIgnoredAnnotationNames($class)); | ||||
|  | ||||
|         return $this->parser->parse($property->getDocComment(), $context); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a property annotation. | ||||
|      * | ||||
|      * @param ReflectionProperty $property | ||||
|      * @param string $annotationName The name of the annotation. | ||||
|      * @return mixed The Annotation or NULL, if the requested annotation does not exist. | ||||
|      */ | ||||
|     public function getPropertyAnnotation(ReflectionProperty $property, $annotationName) | ||||
|     { | ||||
|         $annotations = $this->getPropertyAnnotations($property); | ||||
|  | ||||
|         foreach ($annotations as $annotation) { | ||||
|             if ($annotation instanceof $annotationName) { | ||||
|                 return $annotation; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the annotations applied to a method. | ||||
|      * | ||||
|      * @param \ReflectionMethod $method The ReflectionMethod of the method from which | ||||
|      *                                   the annotations should be read. | ||||
|      * | ||||
|      * @return array An array of Annotations. | ||||
|      */ | ||||
|     public function getMethodAnnotations(ReflectionMethod $method) | ||||
|     { | ||||
|         $class = $method->getDeclaringClass(); | ||||
|         $context = 'method ' . $class->getName() . '::' . $method->getName() . '()'; | ||||
|         $this->parser->setTarget(Target::TARGET_METHOD); | ||||
|         $this->parser->setImports($this->getImports($class)); | ||||
|         $this->parser->setIgnoredAnnotationNames($this->getIgnoredAnnotationNames($class)); | ||||
|  | ||||
|         return $this->parser->parse($method->getDocComment(), $context); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a method annotation. | ||||
|      * | ||||
|      * @param ReflectionMethod $method | ||||
|      * @param string $annotationName The name of the annotation. | ||||
|      * @return mixed The Annotation or NULL, if the requested annotation does not exist. | ||||
|      */ | ||||
|     public function getMethodAnnotation(ReflectionMethod $method, $annotationName) | ||||
|     { | ||||
|         $annotations = $this->getMethodAnnotations($method); | ||||
|  | ||||
|         foreach ($annotations as $annotation) { | ||||
|             if ($annotation instanceof $annotationName) { | ||||
|                 return $annotation; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the ignored annotations for the given class. | ||||
|      * | ||||
|      * @param ReflectionClass $class | ||||
|      * @return array | ||||
|      */ | ||||
|     private function getIgnoredAnnotationNames(ReflectionClass $class) | ||||
|     { | ||||
|         if (isset($this->ignoredAnnotationNames[$name = $class->getName()])) { | ||||
|             return $this->ignoredAnnotationNames[$name]; | ||||
|         } | ||||
|         $this->collectParsingMetadata($class); | ||||
|  | ||||
|         return $this->ignoredAnnotationNames[$name]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Retrieve imports | ||||
|      * | ||||
|      * @param \ReflectionClass $class | ||||
|      * @return array | ||||
|      */ | ||||
|     private function getImports(ReflectionClass $class) | ||||
|     { | ||||
|         if (isset($this->imports[$name = $class->getName()])) { | ||||
|             return $this->imports[$name]; | ||||
|         } | ||||
|         $this->collectParsingMetadata($class); | ||||
|  | ||||
|         return $this->imports[$name]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Collects parsing metadata for a given class | ||||
|      * | ||||
|      * @param ReflectionClass $class | ||||
|      */ | ||||
|     private function collectParsingMetadata(ReflectionClass $class) | ||||
|     { | ||||
|         $ignoredAnnotationNames = self::$globalIgnoredNames; | ||||
|  | ||||
|         $annotations = $this->preParser->parse($class->getDocComment(), 'class '.$class->name); | ||||
|         foreach ($annotations as $annotation) { | ||||
|             if ($annotation instanceof IgnoreAnnotation) { | ||||
|                 foreach ($annotation->names AS $annot) { | ||||
|                     $ignoredAnnotationNames[$annot] = true; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $name = $class->getName(); | ||||
|         $this->imports[$name] = array_merge( | ||||
|             self::$globalImports, | ||||
|             $this->phpParser->parseClass($class), | ||||
|             array('__NAMESPACE__' => $class->getNamespaceName()) | ||||
|         ); | ||||
|         $this->ignoredAnnotationNames[$name] = $ignoredAnnotationNames; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										139
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationRegistry.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										139
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/AnnotationRegistry.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,139 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| /** | ||||
|  * AnnotationRegistry | ||||
|  */ | ||||
| final class AnnotationRegistry | ||||
| { | ||||
|     /** | ||||
|      * A map of namespaces to use for autoloading purposes based on a PSR-0 convention. | ||||
|      * | ||||
|      * Contains the namespace as key and an array of directories as value. If the value is NULL | ||||
|      * the include path is used for checking for the corresponding file. | ||||
|      * | ||||
|      * This autoloading mechanism does not utilize the PHP autoloading but implements autoloading on its own. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     static private $autoloadNamespaces = array(); | ||||
|  | ||||
|     /** | ||||
|      * A map of autoloader callables. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     static private $loaders = array(); | ||||
|  | ||||
|     static public function reset() | ||||
|     { | ||||
|         self::$autoloadNamespaces = array(); | ||||
|         self::$loaders = array(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Register file | ||||
|      * | ||||
|      * @param string $file | ||||
|      */ | ||||
|     static public function registerFile($file) | ||||
|     { | ||||
|         require_once $file; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Add a namespace with one or many directories to look for files or null for the include path. | ||||
|      * | ||||
|      * Loading of this namespaces will be done with a PSR-0 namespace loading algorithm. | ||||
|      * | ||||
|      * @param string $namespace | ||||
|      * @param string|array|null $dirs | ||||
|      */ | ||||
|     static public function registerAutoloadNamespace($namespace, $dirs = null) | ||||
|     { | ||||
|         self::$autoloadNamespaces[$namespace] = $dirs; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Register multiple namespaces | ||||
|      * | ||||
|      * Loading of this namespaces will be done with a PSR-0 namespace loading algorithm. | ||||
|      * | ||||
|      * @param array $namespaces | ||||
|      */ | ||||
|     static public function registerAutoloadNamespaces(array $namespaces) | ||||
|     { | ||||
|         self::$autoloadNamespaces = array_merge(self::$autoloadNamespaces, $namespaces); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Register an autoloading callable for annotations, much like spl_autoload_register(). | ||||
|      * | ||||
|      * NOTE: These class loaders HAVE to be silent when a class was not found! | ||||
|      * IMPORTANT: Loaders have to return true if they loaded a class that could contain the searched annotation class. | ||||
|      * | ||||
|      * @param callable $callable | ||||
|      * | ||||
|      * @throws \InvalidArgumentException | ||||
|      */ | ||||
|     static public function registerLoader($callable) | ||||
|     { | ||||
|         if (!is_callable($callable)) { | ||||
|             throw new \InvalidArgumentException("A callable is expected in AnnotationRegistry::registerLoader()."); | ||||
|         } | ||||
|         self::$loaders[] = $callable; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Autoload an annotation class silently. | ||||
|      * | ||||
|      * @param string $class | ||||
|      * @return boolean | ||||
|      */ | ||||
|     static public function loadAnnotationClass($class) | ||||
|     { | ||||
|         foreach (self::$autoloadNamespaces AS $namespace => $dirs) { | ||||
|             if (strpos($class, $namespace) === 0) { | ||||
|                 $file = str_replace("\\", DIRECTORY_SEPARATOR, $class) . ".php"; | ||||
|                 if ($dirs === null) { | ||||
|                     if ($path = stream_resolve_include_path($file)) { | ||||
|                         require $path; | ||||
|                         return true; | ||||
|                     } | ||||
|                 } else { | ||||
|                     foreach((array)$dirs AS $dir) { | ||||
|                         if (is_file($dir . DIRECTORY_SEPARATOR . $file)) { | ||||
|                             require $dir . DIRECTORY_SEPARATOR . $file; | ||||
|                             return true; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         foreach (self::$loaders AS $loader) { | ||||
|             if (call_user_func($loader, $class) === true) { | ||||
|                 return true; | ||||
|             } | ||||
|         } | ||||
|         return false; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										250
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/CachedReader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										250
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/CachedReader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,250 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| use Doctrine\Common\Cache\Cache; | ||||
|  | ||||
| /** | ||||
|  * A cache aware annotation reader. | ||||
|  * | ||||
|  * @author Johannes M. Schmitt <schmittjoh@gmail.com> | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| final class CachedReader implements Reader | ||||
| { | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     private static $CACHE_SALT = '@[Annot]'; | ||||
|  | ||||
|     /** | ||||
|      * @var Reader | ||||
|      */ | ||||
|     private $delegate; | ||||
|  | ||||
|     /** | ||||
|      * @var Cache | ||||
|      */ | ||||
|     private $cache; | ||||
|  | ||||
|     /** | ||||
|      * @var boolean | ||||
|      */ | ||||
|     private $debug; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $loadedAnnotations; | ||||
|  | ||||
|     /** | ||||
|      * Constructor | ||||
|      * | ||||
|      * @param Reader $reader | ||||
|      * @param Cache $cache | ||||
|      * @param bool $debug | ||||
|      */ | ||||
|     public function __construct(Reader $reader, Cache $cache, $debug = false) | ||||
|     { | ||||
|         $this->delegate = $reader; | ||||
|         $this->cache = $cache; | ||||
|         $this->debug = (Boolean) $debug; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get annotations for class | ||||
|      * | ||||
|      * @param \ReflectionClass $class | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getClassAnnotations(\ReflectionClass $class) | ||||
|     { | ||||
|         $cacheKey = $class->getName(); | ||||
|  | ||||
|         if (isset($this->loadedAnnotations[$cacheKey])) { | ||||
|             return $this->loadedAnnotations[$cacheKey]; | ||||
|         } | ||||
|  | ||||
|         if (false === ($annots = $this->fetchFromCache($cacheKey, $class))) { | ||||
|             $annots = $this->delegate->getClassAnnotations($class); | ||||
|             $this->saveToCache($cacheKey, $annots); | ||||
|         } | ||||
|  | ||||
|         return $this->loadedAnnotations[$cacheKey] = $annots; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get selected annotation for class | ||||
|      * | ||||
|      * @param \ReflectionClass $class | ||||
|      * @param string $annotationName | ||||
|      * @return null | ||||
|      */ | ||||
|     public function getClassAnnotation(\ReflectionClass $class, $annotationName) | ||||
|     { | ||||
|         foreach ($this->getClassAnnotations($class) as $annot) { | ||||
|             if ($annot instanceof $annotationName) { | ||||
|                 return $annot; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get annotations for property | ||||
|      * | ||||
|      * @param \ReflectionProperty $property | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getPropertyAnnotations(\ReflectionProperty $property) | ||||
|     { | ||||
|         $class = $property->getDeclaringClass(); | ||||
|         $cacheKey = $class->getName().'$'.$property->getName(); | ||||
|  | ||||
|         if (isset($this->loadedAnnotations[$cacheKey])) { | ||||
|             return $this->loadedAnnotations[$cacheKey]; | ||||
|         } | ||||
|  | ||||
|         if (false === ($annots = $this->fetchFromCache($cacheKey, $class))) { | ||||
|             $annots = $this->delegate->getPropertyAnnotations($property); | ||||
|             $this->saveToCache($cacheKey, $annots); | ||||
|         } | ||||
|  | ||||
|         return $this->loadedAnnotations[$cacheKey] = $annots; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get selected annotation for property | ||||
|      * | ||||
|      * @param \ReflectionProperty $property | ||||
|      * @param string $annotationName | ||||
|      * @return null | ||||
|      */ | ||||
|     public function getPropertyAnnotation(\ReflectionProperty $property, $annotationName) | ||||
|     { | ||||
|         foreach ($this->getPropertyAnnotations($property) as $annot) { | ||||
|             if ($annot instanceof $annotationName) { | ||||
|                 return $annot; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get method annotations | ||||
|      * | ||||
|      * @param \ReflectionMethod $method | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getMethodAnnotations(\ReflectionMethod $method) | ||||
|     { | ||||
|         $class = $method->getDeclaringClass(); | ||||
|         $cacheKey = $class->getName().'#'.$method->getName(); | ||||
|  | ||||
|         if (isset($this->loadedAnnotations[$cacheKey])) { | ||||
|             return $this->loadedAnnotations[$cacheKey]; | ||||
|         } | ||||
|  | ||||
|         if (false === ($annots = $this->fetchFromCache($cacheKey, $class))) { | ||||
|             $annots = $this->delegate->getMethodAnnotations($method); | ||||
|             $this->saveToCache($cacheKey, $annots); | ||||
|         } | ||||
|  | ||||
|         return $this->loadedAnnotations[$cacheKey] = $annots; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get selected method annotation | ||||
|      * | ||||
|      * @param \ReflectionMethod $method | ||||
|      * @param string $annotationName | ||||
|      * @return null | ||||
|      */ | ||||
|     public function getMethodAnnotation(\ReflectionMethod $method, $annotationName) | ||||
|     { | ||||
|         foreach ($this->getMethodAnnotations($method) as $annot) { | ||||
|             if ($annot instanceof $annotationName) { | ||||
|                 return $annot; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Clear loaded annotations | ||||
|      */ | ||||
|     public function clearLoadedAnnotations() | ||||
|     { | ||||
|         $this->loadedAnnotations = array(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Fetches a value from the cache. | ||||
|      * | ||||
|      * @param string           $rawCacheKey The cache key. | ||||
|      * @param \ReflectionClass $class       The related class. | ||||
|      * @return mixed|boolean The cached value or false when the value is not in cache. | ||||
|      */ | ||||
|     private function fetchFromCache($rawCacheKey, \ReflectionClass $class) | ||||
|     { | ||||
|         $cacheKey = $rawCacheKey . self::$CACHE_SALT; | ||||
|         if (($data = $this->cache->fetch($cacheKey)) !== false) { | ||||
|             if (!$this->debug || $this->isCacheFresh($cacheKey, $class)) { | ||||
|                 return $data; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Saves a value to the cache | ||||
|      * | ||||
|      * @param string $rawCacheKey The cache key. | ||||
|      * @param mixed  $value       The value. | ||||
|      */ | ||||
|     private function saveToCache($rawCacheKey, $value) | ||||
|     { | ||||
|         $cacheKey = $rawCacheKey . self::$CACHE_SALT; | ||||
|         $this->cache->save($cacheKey, $value); | ||||
|         if ($this->debug) { | ||||
|             $this->cache->save('[C]'.$cacheKey, time()); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if cache is fresh | ||||
|      * | ||||
|      * @param string $cacheKey | ||||
|      * @param \ReflectionClass $class | ||||
|      * @return bool | ||||
|      */ | ||||
|     private function isCacheFresh($cacheKey, \ReflectionClass $class) | ||||
|     { | ||||
|         if (false === $filename = $class->getFilename()) { | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         return $this->cache->fetch('[C]'.$cacheKey) >= filemtime($filename); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										132
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocLexer.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										132
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocLexer.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,132 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| use Doctrine\Common\Lexer\AbstractLexer; | ||||
|  | ||||
| /** | ||||
|  * Simple lexer for docblock annotations. | ||||
|  * | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @author Johannes M. Schmitt <schmittjoh@gmail.com> | ||||
|  */ | ||||
| final class DocLexer extends AbstractLexer | ||||
| { | ||||
|     const T_NONE                = 1; | ||||
|     const T_INTEGER             = 2; | ||||
|     const T_STRING              = 3; | ||||
|     const T_FLOAT               = 4; | ||||
|  | ||||
|     // All tokens that are also identifiers should be >= 100 | ||||
|     const T_IDENTIFIER          = 100; | ||||
|     const T_AT                  = 101; | ||||
|     const T_CLOSE_CURLY_BRACES  = 102; | ||||
|     const T_CLOSE_PARENTHESIS   = 103; | ||||
|     const T_COMMA               = 104; | ||||
|     const T_EQUALS              = 105; | ||||
|     const T_FALSE               = 106; | ||||
|     const T_NAMESPACE_SEPARATOR = 107; | ||||
|     const T_OPEN_CURLY_BRACES   = 108; | ||||
|     const T_OPEN_PARENTHESIS    = 109; | ||||
|     const T_TRUE                = 110; | ||||
|     const T_NULL                = 111; | ||||
|     const T_COLON               = 112; | ||||
|  | ||||
|     protected $noCase = array( | ||||
|         '@'  => self::T_AT, | ||||
|         ','  => self::T_COMMA, | ||||
|         '('  => self::T_OPEN_PARENTHESIS, | ||||
|         ')'  => self::T_CLOSE_PARENTHESIS, | ||||
|         '{'  => self::T_OPEN_CURLY_BRACES, | ||||
|         '}'  => self::T_CLOSE_CURLY_BRACES, | ||||
|         '='  => self::T_EQUALS, | ||||
|         ':'  => self::T_COLON, | ||||
|         '\\' => self::T_NAMESPACE_SEPARATOR | ||||
|     ); | ||||
|  | ||||
|     protected $withCase = array( | ||||
|         'true'  => self::T_TRUE, | ||||
|         'false' => self::T_FALSE, | ||||
|         'null'  => self::T_NULL | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function getCatchablePatterns() | ||||
|     { | ||||
|         return array( | ||||
|             '[a-z_\\\][a-z0-9_\:\\\]*[a-z]{1}', | ||||
|             '(?:[+-]?[0-9]+(?:[\.][0-9]+)*)(?:[eE][+-]?[0-9]+)?', | ||||
|             '"(?:[^"]|"")*"', | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function getNonCatchablePatterns() | ||||
|     { | ||||
|         return array('\s+', '\*+', '(.)'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @param string $value | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     protected function getType(&$value) | ||||
|     { | ||||
|         $type = self::T_NONE; | ||||
|  | ||||
|         if ($value[0] === '"') { | ||||
|             $value = str_replace('""', '"', substr($value, 1, strlen($value) - 2)); | ||||
|  | ||||
|             return self::T_STRING; | ||||
|         } | ||||
|  | ||||
|         if (isset($this->noCase[$value])) { | ||||
|             return $this->noCase[$value]; | ||||
|         } | ||||
|  | ||||
|         if ($value[0] === '_' || $value[0] === '\\' || ctype_alpha($value[0])) { | ||||
|             return self::T_IDENTIFIER; | ||||
|         } | ||||
|  | ||||
|         $lowerValue = strtolower($value); | ||||
|  | ||||
|         if (isset($this->withCase[$lowerValue])) { | ||||
|             return $this->withCase[$lowerValue]; | ||||
|         } | ||||
|  | ||||
|         // Checking numeric value | ||||
|         if (is_numeric($value)) { | ||||
|             return (strpos($value, '.') !== false || stripos($value, 'e') !== false) | ||||
|                 ? self::T_FLOAT : self::T_INTEGER; | ||||
|         } | ||||
|  | ||||
|         return $type; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										1049
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocParser.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1049
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/DocParser.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										269
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/FileCacheReader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										269
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/FileCacheReader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,269 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * File cache reader for annotations. | ||||
|  * | ||||
|  * @author Johannes M. Schmitt <schmittjoh@gmail.com> | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class FileCacheReader implements Reader | ||||
| { | ||||
|     /** | ||||
|      * @var Reader | ||||
|      */ | ||||
|     private $reader; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     private $dir; | ||||
|  | ||||
|     /** | ||||
|      * @var bool | ||||
|      */ | ||||
|     private $debug; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $loadedAnnotations = array(); | ||||
|  | ||||
|     private $classNameHashes = array(); | ||||
|  | ||||
|     /** | ||||
|      * Constructor | ||||
|      * | ||||
|      * @param Reader $reader | ||||
|      * @param string $cacheDir | ||||
|      * @param bool $debug | ||||
|      * | ||||
|      * @throws \InvalidArgumentException | ||||
|      */ | ||||
|     public function __construct(Reader $reader, $cacheDir, $debug = false) | ||||
|     { | ||||
|         $this->reader = $reader; | ||||
|         if (!is_dir($cacheDir) && !@mkdir($cacheDir, 0777, true)) { | ||||
|             throw new \InvalidArgumentException(sprintf('The directory "%s" does not exist and could not be created.', $cacheDir)); | ||||
|         } | ||||
|         if (!is_writable($cacheDir)) { | ||||
|             throw new \InvalidArgumentException(sprintf('The directory "%s" is not writable. Both, the webserver and the console user need access. You can manage access rights for multiple users with "chmod +a". If your system does not support this, check out the acl package.', $cacheDir)); | ||||
|         } | ||||
|  | ||||
|         $this->dir   = rtrim($cacheDir, '\\/'); | ||||
|         $this->debug = $debug; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Retrieve annotations for class | ||||
|      * | ||||
|      * @param \ReflectionClass $class | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getClassAnnotations(\ReflectionClass $class) | ||||
|     { | ||||
|         if ( ! isset($this->classNameHashes[$class->name])) { | ||||
|             $this->classNameHashes[$class->name] = sha1($class->name); | ||||
|         } | ||||
|         $key = $this->classNameHashes[$class->name]; | ||||
|  | ||||
|         if (isset($this->loadedAnnotations[$key])) { | ||||
|             return $this->loadedAnnotations[$key]; | ||||
|         } | ||||
|  | ||||
|         $path = $this->dir.'/'.strtr($key, '\\', '-').'.cache.php'; | ||||
|         if (!is_file($path)) { | ||||
|             $annot = $this->reader->getClassAnnotations($class); | ||||
|             $this->saveCacheFile($path, $annot); | ||||
|             return $this->loadedAnnotations[$key] = $annot; | ||||
|         } | ||||
|  | ||||
|         if ($this->debug | ||||
|             && (false !== $filename = $class->getFilename()) | ||||
|             && filemtime($path) < filemtime($filename)) { | ||||
|             @unlink($path); | ||||
|  | ||||
|             $annot = $this->reader->getClassAnnotations($class); | ||||
|             $this->saveCacheFile($path, $annot); | ||||
|             return $this->loadedAnnotations[$key] = $annot; | ||||
|         } | ||||
|  | ||||
|         return $this->loadedAnnotations[$key] = include $path; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get annotations for property | ||||
|      * | ||||
|      * @param \ReflectionProperty $property | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getPropertyAnnotations(\ReflectionProperty $property) | ||||
|     { | ||||
|         $class = $property->getDeclaringClass(); | ||||
|         if ( ! isset($this->classNameHashes[$class->name])) { | ||||
|             $this->classNameHashes[$class->name] = sha1($class->name); | ||||
|         } | ||||
|         $key = $this->classNameHashes[$class->name].'$'.$property->getName(); | ||||
|  | ||||
|         if (isset($this->loadedAnnotations[$key])) { | ||||
|             return $this->loadedAnnotations[$key]; | ||||
|         } | ||||
|  | ||||
|         $path = $this->dir.'/'.strtr($key, '\\', '-').'.cache.php'; | ||||
|         if (!is_file($path)) { | ||||
|             $annot = $this->reader->getPropertyAnnotations($property); | ||||
|             $this->saveCacheFile($path, $annot); | ||||
|             return $this->loadedAnnotations[$key] = $annot; | ||||
|         } | ||||
|  | ||||
|         if ($this->debug | ||||
|             && (false !== $filename = $class->getFilename()) | ||||
|             && filemtime($path) < filemtime($filename)) { | ||||
|             @unlink($path); | ||||
|  | ||||
|             $annot = $this->reader->getPropertyAnnotations($property); | ||||
|             $this->saveCacheFile($path, $annot); | ||||
|             return $this->loadedAnnotations[$key] = $annot; | ||||
|         } | ||||
|  | ||||
|         return $this->loadedAnnotations[$key] = include $path; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Retrieve annotations for method | ||||
|      * | ||||
|      * @param \ReflectionMethod $method | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getMethodAnnotations(\ReflectionMethod $method) | ||||
|     { | ||||
|         $class = $method->getDeclaringClass(); | ||||
|         if ( ! isset($this->classNameHashes[$class->name])) { | ||||
|             $this->classNameHashes[$class->name] = sha1($class->name); | ||||
|         } | ||||
|         $key = $this->classNameHashes[$class->name].'#'.$method->getName(); | ||||
|  | ||||
|         if (isset($this->loadedAnnotations[$key])) { | ||||
|             return $this->loadedAnnotations[$key]; | ||||
|         } | ||||
|  | ||||
|         $path = $this->dir.'/'.strtr($key, '\\', '-').'.cache.php'; | ||||
|         if (!is_file($path)) { | ||||
|             $annot = $this->reader->getMethodAnnotations($method); | ||||
|             $this->saveCacheFile($path, $annot); | ||||
|             return $this->loadedAnnotations[$key] = $annot; | ||||
|         } | ||||
|  | ||||
|         if ($this->debug | ||||
|             && (false !== $filename = $class->getFilename()) | ||||
|             && filemtime($path) < filemtime($filename)) { | ||||
|             @unlink($path); | ||||
|  | ||||
|             $annot = $this->reader->getMethodAnnotations($method); | ||||
|             $this->saveCacheFile($path, $annot); | ||||
|             return $this->loadedAnnotations[$key] = $annot; | ||||
|         } | ||||
|  | ||||
|         return $this->loadedAnnotations[$key] = include $path; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Save cache file | ||||
|      * | ||||
|      * @param string $path | ||||
|      * @param mixed $data | ||||
|      */ | ||||
|     private function saveCacheFile($path, $data) | ||||
|     { | ||||
|         file_put_contents($path, '<?php return unserialize('.var_export(serialize($data), true).');'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a class annotation. | ||||
|      * | ||||
|      * @param \ReflectionClass $class The ReflectionClass of the class from which | ||||
|      *                               the class annotations should be read. | ||||
|      * @param string $annotationName The name of the annotation. | ||||
|      * | ||||
|      * @return mixed The Annotation or NULL, if the requested annotation does not exist. | ||||
|      */ | ||||
|     public function getClassAnnotation(\ReflectionClass $class, $annotationName) | ||||
|     { | ||||
|         $annotations = $this->getClassAnnotations($class); | ||||
|  | ||||
|         foreach ($annotations as $annotation) { | ||||
|             if ($annotation instanceof $annotationName) { | ||||
|                 return $annotation; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a method annotation. | ||||
|      * | ||||
|      * @param \ReflectionMethod $method | ||||
|      * @param string $annotationName The name of the annotation. | ||||
|      * @return mixed The Annotation or NULL, if the requested annotation does not exist. | ||||
|      */ | ||||
|     public function getMethodAnnotation(\ReflectionMethod $method, $annotationName) | ||||
|     { | ||||
|         $annotations = $this->getMethodAnnotations($method); | ||||
|  | ||||
|         foreach ($annotations as $annotation) { | ||||
|             if ($annotation instanceof $annotationName) { | ||||
|                 return $annotation; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a property annotation. | ||||
|      * | ||||
|      * @param \ReflectionProperty $property | ||||
|      * @param string $annotationName The name of the annotation. | ||||
|      * @return mixed The Annotation or NULL, if the requested annotation does not exist. | ||||
|      */ | ||||
|     public function getPropertyAnnotation(\ReflectionProperty $property, $annotationName) | ||||
|     { | ||||
|         $annotations = $this->getPropertyAnnotations($property); | ||||
|  | ||||
|         foreach ($annotations as $annotation) { | ||||
|             if ($annotation instanceof $annotationName) { | ||||
|                 return $annotation; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Clear stores annotations | ||||
|      */ | ||||
|     public function clearLoadedAnnotations() | ||||
|     { | ||||
|         $this->loadedAnnotations = array(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										141
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/IndexedReader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/IndexedReader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,141 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| use Doctrine\Common\Annotations\Reader; | ||||
|  | ||||
| /** | ||||
|  * Allows the reader to be used in-place of Doctrine's reader. | ||||
|  * | ||||
|  * @author Johannes M. Schmitt <schmittjoh@gmail.com> | ||||
|  */ | ||||
| class IndexedReader implements Reader | ||||
| { | ||||
|     /** | ||||
|      * @var Reader | ||||
|      */ | ||||
|     private $delegate; | ||||
|  | ||||
|     /** | ||||
|      * Constructor | ||||
|      * | ||||
|      * @param Reader $reader | ||||
|      */ | ||||
|     public function __construct(Reader $reader) | ||||
|     { | ||||
|         $this->delegate = $reader; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Annotations for class | ||||
|      * | ||||
|      * @param \ReflectionClass $class | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getClassAnnotations(\ReflectionClass $class) | ||||
|     { | ||||
|         $annotations = array(); | ||||
|         foreach ($this->delegate->getClassAnnotations($class) as $annot) { | ||||
|             $annotations[get_class($annot)] = $annot; | ||||
|         } | ||||
|  | ||||
|         return $annotations; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get selected annotation for class | ||||
|      * | ||||
|      * @param \ReflectionClass $class | ||||
|      * @param string $annotation | ||||
|      * @return mixed | ||||
|      */ | ||||
|     public function getClassAnnotation(\ReflectionClass $class, $annotation) | ||||
|     { | ||||
|         return $this->delegate->getClassAnnotation($class, $annotation); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Annotations for method | ||||
|      * | ||||
|      * @param \ReflectionMethod $method | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getMethodAnnotations(\ReflectionMethod $method) | ||||
|     { | ||||
|         $annotations = array(); | ||||
|         foreach ($this->delegate->getMethodAnnotations($method) as $annot) { | ||||
|             $annotations[get_class($annot)] = $annot; | ||||
|         } | ||||
|  | ||||
|         return $annotations; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get selected annotation for method | ||||
|      * | ||||
|      * @param \ReflectionMethod $method | ||||
|      * @param string $annotation | ||||
|      * @return mixed | ||||
|      */ | ||||
|     public function getMethodAnnotation(\ReflectionMethod $method, $annotation) | ||||
|     { | ||||
|         return $this->delegate->getMethodAnnotation($method, $annotation); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get annotations for property | ||||
|      * | ||||
|      * @param \ReflectionProperty $property | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getPropertyAnnotations(\ReflectionProperty $property) | ||||
|     { | ||||
|         $annotations = array(); | ||||
|         foreach ($this->delegate->getPropertyAnnotations($property) as $annot) { | ||||
|             $annotations[get_class($annot)] = $annot; | ||||
|         } | ||||
|  | ||||
|         return $annotations; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get selected annotation for property | ||||
|      * | ||||
|      * @param \ReflectionProperty $property | ||||
|      * @param string $annotation | ||||
|      * @return mixed | ||||
|      */ | ||||
|     public function getPropertyAnnotation(\ReflectionProperty $property, $annotation) | ||||
|     { | ||||
|         return $this->delegate->getPropertyAnnotation($property, $annotation); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Proxy all methods to the delegate. | ||||
|      * | ||||
|      * @param string $method | ||||
|      * @param array $args | ||||
|      * @return mixed | ||||
|      */ | ||||
|     public function __call($method, $args) | ||||
|     { | ||||
|         return call_user_func_array(array($this->delegate, $method), $args); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										89
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/PhpParser.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/PhpParser.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,89 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| use SplFileObject; | ||||
|  | ||||
| /** | ||||
|  * Parses a file for namespaces/use/class declarations. | ||||
|  * | ||||
|  * @author Fabien Potencier <fabien@symfony.com> | ||||
|  * @author Christian Kaps <christian.kaps@mohiva.com> | ||||
|  */ | ||||
| final class PhpParser | ||||
| { | ||||
|     /** | ||||
|      * Parses a class. | ||||
|      * | ||||
|      * @param  \ReflectionClass $class A <code>ReflectionClass</code> object. | ||||
|      * @return array            A list with use statements in the form (Alias => FQN). | ||||
|      */ | ||||
|     public function parseClass(\ReflectionClass $class) | ||||
|     { | ||||
|         if (method_exists($class, 'getUseStatements')) { | ||||
|             return $class->getUseStatements(); | ||||
|         } | ||||
|  | ||||
|         if (false === $filename = $class->getFilename()) { | ||||
|             return array(); | ||||
|         } | ||||
|  | ||||
|         $content = $this->getFileContent($filename, $class->getStartLine()); | ||||
|  | ||||
|         if (null === $content) { | ||||
|             return array(); | ||||
|         } | ||||
|  | ||||
|         $namespace = preg_quote($class->getNamespaceName()); | ||||
|         $content = preg_replace('/^.*?(\bnamespace\s+' . $namespace . '\s*[;{].*)$/s', '\\1', $content); | ||||
|         $tokenizer = new TokenParser('<?php ' . $content); | ||||
|  | ||||
|         $statements = $tokenizer->parseUseStatements($class->getNamespaceName()); | ||||
|  | ||||
|         return $statements; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get 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 The content of the file. | ||||
|      */ | ||||
|     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; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										67
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Reader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/Reader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| /** | ||||
|  * Interface for annotation readers. | ||||
|  * | ||||
|  * @author Johannes M. Schmitt <schmittjoh@gmail.com> | ||||
|  */ | ||||
| interface Reader | ||||
| { | ||||
|     /** | ||||
|      * @param \ReflectionClass $class | ||||
|      * @return mixed | ||||
|      */ | ||||
|     function getClassAnnotations(\ReflectionClass $class); | ||||
|  | ||||
|     /** | ||||
|      * @param \ReflectionClass $class | ||||
|      * @param string $annotationName | ||||
|      * @return mixed | ||||
|      */ | ||||
|     function getClassAnnotation(\ReflectionClass $class, $annotationName); | ||||
|  | ||||
|     /** | ||||
|      * @param \ReflectionMethod $method | ||||
|      * @return mixed | ||||
|      */ | ||||
|     function getMethodAnnotations(\ReflectionMethod $method); | ||||
|  | ||||
|     /** | ||||
|      * @param \ReflectionMethod $method | ||||
|      * @param string $annotationName | ||||
|      * @return mixed | ||||
|      */ | ||||
|     function getMethodAnnotation(\ReflectionMethod $method, $annotationName); | ||||
|  | ||||
|     /** | ||||
|      * @param \ReflectionProperty $property | ||||
|      * @return mixed | ||||
|      */ | ||||
|     function getPropertyAnnotations(\ReflectionProperty $property); | ||||
|  | ||||
|     /** | ||||
|      * @param \ReflectionProperty $property | ||||
|      * @param string $annotationName | ||||
|      * @return mixed | ||||
|      */ | ||||
|     function getPropertyAnnotation(\ReflectionProperty $property, $annotationName); | ||||
| } | ||||
							
								
								
									
										157
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/SimpleAnnotationReader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										157
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/SimpleAnnotationReader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,157 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| use Doctrine\Common\Annotations\Annotation\Target; | ||||
|  | ||||
| /** | ||||
|  * Simple Annotation Reader. | ||||
|  * | ||||
|  * This annotation reader is intended to be used in projects where you have | ||||
|  * full-control over all annotations that are available. | ||||
|  * | ||||
|  * @since  2.2 | ||||
|  * @author Johannes M. Schmitt <schmittjoh@gmail.com> | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  */ | ||||
| class SimpleAnnotationReader implements Reader | ||||
| { | ||||
|     /** | ||||
|      * @var DocParser | ||||
|      */ | ||||
|     private $parser; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * Initializes a new SimpleAnnotationReader. | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|         $this->parser = new DocParser(); | ||||
|         $this->parser->setIgnoreNotImportedAnnotations(true); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Adds a namespace in which we will look for annotations. | ||||
|      * | ||||
|      * @param string $namespace | ||||
|      */ | ||||
|     public function addNamespace($namespace) | ||||
|     { | ||||
|         $this->parser->addNamespace($namespace); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 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 An array of Annotations. | ||||
|      */ | ||||
|     public function getClassAnnotations(\ReflectionClass $class) | ||||
|     { | ||||
|         return $this->parser->parse($class->getDocComment(), 'class '.$class->getName()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the annotations applied to a method. | ||||
|      * | ||||
|      * @param \ReflectionMethod $method The ReflectionMethod of the method from which | ||||
|      *                                   the annotations should be read. | ||||
|      * | ||||
|      * @return array An array of Annotations. | ||||
|      */ | ||||
|     public function getMethodAnnotations(\ReflectionMethod $method) | ||||
|     { | ||||
|         return $this->parser->parse($method->getDocComment(), 'method '.$method->getDeclaringClass()->name.'::'.$method->getName().'()'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the annotations applied to a property. | ||||
|      * | ||||
|      * @param \ReflectionProperty $property The ReflectionProperty of the property | ||||
|      *                                     from which the annotations should be read. | ||||
|      * | ||||
|      * @return array An array of Annotations. | ||||
|      */ | ||||
|     public function getPropertyAnnotations(\ReflectionProperty $property) | ||||
|     { | ||||
|         return $this->parser->parse($property->getDocComment(), 'property '.$property->getDeclaringClass()->name.'::$'.$property->getName()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a class annotation. | ||||
|      * | ||||
|      * @param \ReflectionClass $class The ReflectionClass of the class from which | ||||
|      *                               the class annotations should be read. | ||||
|      * @param string $annotationName The name of the annotation. | ||||
|      * | ||||
|      * @return mixed The Annotation or NULL, if the requested annotation does not exist. | ||||
|      */ | ||||
|     public function getClassAnnotation(\ReflectionClass $class, $annotationName) | ||||
|     { | ||||
|         foreach ($this->getClassAnnotations($class) as $annot) { | ||||
|             if ($annot instanceof $annotationName) { | ||||
|                 return $annot; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a method annotation. | ||||
|      * | ||||
|      * @param \ReflectionMethod $method | ||||
|      * @param string $annotationName The name of the annotation. | ||||
|      * | ||||
|      * @return mixed The Annotation or NULL, if the requested annotation does not exist. | ||||
|      */ | ||||
|     public function getMethodAnnotation(\ReflectionMethod $method, $annotationName) | ||||
|     { | ||||
|         foreach ($this->getMethodAnnotations($method) as $annot) { | ||||
|             if ($annot instanceof $annotationName) { | ||||
|                 return $annot; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a property annotation. | ||||
|      * | ||||
|      * @param \ReflectionProperty $property | ||||
|      * @param string $annotationName The name of the annotation. | ||||
|      * @return mixed The Annotation or NULL, if the requested annotation does not exist. | ||||
|      */ | ||||
|     public function getPropertyAnnotation(\ReflectionProperty $property, $annotationName) | ||||
|     { | ||||
|         foreach ($this->getPropertyAnnotations($property) as $annot) { | ||||
|             if ($annot instanceof $annotationName) { | ||||
|                 return $annot; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										175
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/TokenParser.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										175
									
								
								vendor/doctrine/annotations/lib/Doctrine/Common/Annotations/TokenParser.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,175 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Annotations; | ||||
|  | ||||
| /** | ||||
|  * Parses a file for namespaces/use/class declarations. | ||||
|  * | ||||
|  * @author Fabien Potencier <fabien@symfony.com> | ||||
|  * @author Christian Kaps <christian.kaps@mohiva.com> | ||||
|  */ | ||||
| class TokenParser | ||||
| { | ||||
|     /** | ||||
|      * The token list. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $tokens; | ||||
|  | ||||
|     /** | ||||
|      * The number of tokens. | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     private $numTokens = 0; | ||||
|  | ||||
|     /** | ||||
|      * The current array pointer. | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     private $pointer = 0; | ||||
|  | ||||
|     public function __construct($contents) | ||||
|     { | ||||
|         $this->tokens = token_get_all($contents); | ||||
|         $this->numTokens = count($this->tokens); | ||||
|         $this->pointer = 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the next non whitespace and non comment token. | ||||
|      * | ||||
|      * @param $docCommentIsComment | ||||
|      *     If TRUE then a doc comment is considered a comment and skipped. | ||||
|      *     If FALSE then only whitespace and normal comments are skipped. | ||||
|      * | ||||
|      * @return array The token if exists, null otherwise. | ||||
|      */ | ||||
|     public function next($docCommentIsComment = TRUE) | ||||
|     { | ||||
|         for ($i = $this->pointer; $i < $this->numTokens; $i++) { | ||||
|             $this->pointer++; | ||||
|             if ($this->tokens[$i][0] === T_WHITESPACE || | ||||
|                 $this->tokens[$i][0] === T_COMMENT || | ||||
|                 ($docCommentIsComment && $this->tokens[$i][0] === T_DOC_COMMENT)) { | ||||
|  | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             return $this->tokens[$i]; | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parse a single use statement. | ||||
|      * | ||||
|      * @return array A list with all found class names for a use statement. | ||||
|      */ | ||||
|     public function parseUseStatement() | ||||
|     { | ||||
|         $class = ''; | ||||
|         $alias = ''; | ||||
|         $statements = array(); | ||||
|         $explicitAlias = false; | ||||
|         while (($token = $this->next())) { | ||||
|             $isNameToken = $token[0] === T_STRING || $token[0] === T_NS_SEPARATOR; | ||||
|             if (!$explicitAlias && $isNameToken) { | ||||
|                 $class .= $token[1]; | ||||
|                 $alias = $token[1]; | ||||
|             } else if ($explicitAlias && $isNameToken) { | ||||
|                 $alias .= $token[1]; | ||||
|             } else if ($token[0] === T_AS) { | ||||
|                 $explicitAlias = true; | ||||
|                 $alias = ''; | ||||
|             } else if ($token === ',') { | ||||
|                 $statements[strtolower($alias)] = $class; | ||||
|                 $class = ''; | ||||
|                 $alias = ''; | ||||
|                 $explicitAlias = false; | ||||
|             } else if ($token === ';') { | ||||
|                 $statements[strtolower($alias)] = $class; | ||||
|                 break; | ||||
|             } else { | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $statements; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get all use statements. | ||||
|      * | ||||
|      * @param string $namespaceName The namespace name of the reflected class. | ||||
|      * @return array A list with all found use statements. | ||||
|      */ | ||||
|     public function parseUseStatements($namespaceName) | ||||
|     { | ||||
|         $statements = array(); | ||||
|         while (($token = $this->next())) { | ||||
|             if ($token[0] === T_USE) { | ||||
|                 $statements = array_merge($statements, $this->parseUseStatement()); | ||||
|                 continue; | ||||
|             } | ||||
|             if ($token[0] !== T_NAMESPACE || $this->parseNamespace() != $namespaceName) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             // Get fresh array for new namespace. This is to prevent the parser to collect the use statements | ||||
|             // for a previous namespace with the same name. This is the case if a namespace is defined twice | ||||
|             // or if a namespace with the same name is commented out. | ||||
|             $statements = array(); | ||||
|         } | ||||
|  | ||||
|         return $statements; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get the namespace. | ||||
|      * | ||||
|      * @return string The found namespace. | ||||
|      */ | ||||
|     public function parseNamespace() | ||||
|     { | ||||
|         $name = ''; | ||||
|         while (($token = $this->next()) && ($token[0] === T_STRING || $token[0] === T_NS_SEPARATOR)) { | ||||
|             $name .= $token[1]; | ||||
|         } | ||||
|  | ||||
|         return $name; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get the class name. | ||||
|      * | ||||
|      * @return string The foundclass name. | ||||
|      */ | ||||
|     public function parseClass() | ||||
|     { | ||||
|         // Namespaces and class names are tokenized the same: T_STRINGs | ||||
|         // separated by T_NS_SEPARATOR so we can use one function to provide | ||||
|         // both. | ||||
|         return $this->parseNamespace(); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user