annotate vendor/symfony/serializer/Annotation/Groups.php @ 8:50b0d041100e

Further files for download
author Chris Cannam
date Mon, 05 Feb 2018 10:56:40 +0000
parents 4c8ae668cc8c
children 1fec387a4317
rev   line source
Chris@0 1 <?php
Chris@0 2
Chris@0 3 /*
Chris@0 4 * This file is part of the Symfony package.
Chris@0 5 *
Chris@0 6 * (c) Fabien Potencier <fabien@symfony.com>
Chris@0 7 *
Chris@0 8 * For the full copyright and license information, please view the LICENSE
Chris@0 9 * file that was distributed with this source code.
Chris@0 10 */
Chris@0 11
Chris@0 12 namespace Symfony\Component\Serializer\Annotation;
Chris@0 13
Chris@0 14 use Symfony\Component\Serializer\Exception\InvalidArgumentException;
Chris@0 15
Chris@0 16 /**
Chris@0 17 * Annotation class for @Groups().
Chris@0 18 *
Chris@0 19 * @Annotation
Chris@0 20 * @Target({"PROPERTY", "METHOD"})
Chris@0 21 *
Chris@0 22 * @author Kévin Dunglas <dunglas@gmail.com>
Chris@0 23 */
Chris@0 24 class Groups
Chris@0 25 {
Chris@0 26 /**
Chris@0 27 * @var array
Chris@0 28 */
Chris@0 29 private $groups;
Chris@0 30
Chris@0 31 /**
Chris@0 32 * @param array $data
Chris@0 33 *
Chris@0 34 * @throws InvalidArgumentException
Chris@0 35 */
Chris@0 36 public function __construct(array $data)
Chris@0 37 {
Chris@0 38 if (!isset($data['value']) || !$data['value']) {
Chris@0 39 throw new InvalidArgumentException(sprintf('Parameter of annotation "%s" cannot be empty.', get_class($this)));
Chris@0 40 }
Chris@0 41
Chris@0 42 if (!is_array($data['value'])) {
Chris@0 43 throw new InvalidArgumentException(sprintf('Parameter of annotation "%s" must be an array of strings.', get_class($this)));
Chris@0 44 }
Chris@0 45
Chris@0 46 foreach ($data['value'] as $group) {
Chris@0 47 if (!is_string($group)) {
Chris@0 48 throw new InvalidArgumentException(sprintf('Parameter of annotation "%s" must be an array of strings.', get_class($this)));
Chris@0 49 }
Chris@0 50 }
Chris@0 51
Chris@0 52 $this->groups = $data['value'];
Chris@0 53 }
Chris@0 54
Chris@0 55 /**
Chris@0 56 * Gets groups.
Chris@0 57 *
Chris@0 58 * @return array
Chris@0 59 */
Chris@0 60 public function getGroups()
Chris@0 61 {
Chris@0 62 return $this->groups;
Chris@0 63 }
Chris@0 64 }