vendor/doctrine-common/lib/Doctrine/Common/Annotations/Annotation.php
changeset 0 7f95f8617b0b
equal deleted inserted replaced
-1:000000000000 0:7f95f8617b0b
       
     1 <?php
       
     2 /*
       
     3  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
       
     4  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
       
     5  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
       
     6  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
       
     7  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
       
     8  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
       
     9  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
       
    10  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
       
    11  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
       
    12  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
       
    13  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
       
    14  *
       
    15  * This software consists of voluntary contributions made by many individuals
       
    16  * and is licensed under the LGPL. For more information, see
       
    17  * <http://www.doctrine-project.org>.
       
    18  */
       
    19 
       
    20 namespace Doctrine\Common\Annotations;
       
    21 
       
    22 /**
       
    23  * Annotations class
       
    24  *
       
    25  * @author  Benjamin Eberlei <kontakt@beberlei.de>
       
    26  * @author  Guilherme Blanco <guilhermeblanco@hotmail.com>
       
    27  * @author  Jonathan Wage <jonwage@gmail.com>
       
    28  * @author  Roman Borschel <roman@code-factory.org>
       
    29  */
       
    30 class Annotation
       
    31 {
       
    32     /**
       
    33      * Value property. Common among all derived classes.
       
    34      *
       
    35      * @var string
       
    36      */
       
    37     public $value;
       
    38 
       
    39     /**
       
    40      * Constructor
       
    41      *
       
    42      * @param array $data Key-value for properties to be defined in this class
       
    43      */
       
    44     public final function __construct(array $data)
       
    45     {
       
    46         foreach ($data as $key => $value) {
       
    47             $this->$key = $value;
       
    48         }
       
    49     }
       
    50 
       
    51     /**
       
    52      * Error handler for unknown property accessor in Annotation class.
       
    53      *
       
    54      * @param string $name Unknown property name
       
    55      */
       
    56     public function __get($name)
       
    57     {
       
    58         throw new \BadMethodCallException(
       
    59             sprintf("Unknown property '%s' on annotation '%s'.", $name, get_class($this))
       
    60         );
       
    61     }
       
    62 
       
    63     /**
       
    64      * Error handler for unknown property mutator in Annotation class.
       
    65      *
       
    66      * @param string $name Unkown property name
       
    67      * @param mixed $value Property value
       
    68      */
       
    69     public function __set($name, $value)
       
    70     {
       
    71         throw new \BadMethodCallException(
       
    72             sprintf("Unknown property '%s' on annotation '%s'.", $name, get_class($this))
       
    73         );
       
    74     }
       
    75 }