123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- <?php
-
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
- namespace Symfony\Component\OptionsResolver;
-
- use Symfony\Component\OptionsResolver\Exception\AccessException;
-
- final class OptionConfigurator
- {
- private $name;
- private $resolver;
-
- public function __construct(string $name, OptionsResolver $resolver)
- {
- $this->name = $name;
- $this->resolver = $resolver;
- $this->resolver->setDefined($name);
- }
-
- /**
- * Adds allowed types for this option.
- *
- * @return $this
- *
- * @throws AccessException If called from a lazy option or normalizer
- */
- public function allowedTypes(string ...$types): self
- {
- $this->resolver->setAllowedTypes($this->name, $types);
-
- return $this;
- }
-
- /**
- * Sets allowed values for this option.
- *
- * @param mixed ...$values One or more acceptable values/closures
- *
- * @return $this
- *
- * @throws AccessException If called from a lazy option or normalizer
- */
- public function allowedValues(...$values): self
- {
- $this->resolver->setAllowedValues($this->name, $values);
-
- return $this;
- }
-
- /**
- * Sets the default value for this option.
- *
- * @param mixed $value The default value of the option
- *
- * @return $this
- *
- * @throws AccessException If called from a lazy option or normalizer
- */
- public function default($value): self
- {
- $this->resolver->setDefault($this->name, $value);
-
- return $this;
- }
-
- /**
- * Defines an option configurator with the given name.
- */
- public function define(string $option): self
- {
- return $this->resolver->define($option);
- }
-
- /**
- * Marks this option as deprecated.
- *
- * @param string $package The name of the composer package that is triggering the deprecation
- * @param string $version The version of the package that introduced the deprecation
- * @param string|\Closure $message The deprecation message to use
- *
- * @return $this
- */
- public function deprecated(string $package, string $version, $message = 'The option "%name%" is deprecated.'): self
- {
- $this->resolver->setDeprecated($this->name, $package, $version, $message);
-
- return $this;
- }
-
- /**
- * Sets the normalizer for this option.
- *
- * @return $this
- *
- * @throws AccessException If called from a lazy option or normalizer
- */
- public function normalize(\Closure $normalizer): self
- {
- $this->resolver->setNormalizer($this->name, $normalizer);
-
- return $this;
- }
-
- /**
- * Marks this option as required.
- *
- * @return $this
- *
- * @throws AccessException If called from a lazy option or normalizer
- */
- public function required(): self
- {
- $this->resolver->setRequired($this->name);
-
- return $this;
- }
-
- /**
- * Sets an info message for an option.
- *
- * @return $this
- *
- * @throws AccessException If called from a lazy option or normalizer
- */
- public function info(string $info): self
- {
- $this->resolver->setInfo($this->name, $info);
-
- return $this;
- }
- }
|