| 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;    }}
 |