source: pro-violet-viettel/sourcecode/application/libraries/Doctrine/Common/Annotations/Annotation.php @ 345

Last change on this file since 345 was 345, checked in by quyenla, 11 years ago

collaborator page

File size: 2.3 KB
Line 
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
20namespace 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 */
30class 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}
Note: See TracBrowser for help on using the repository browser.