* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\Form\ChoiceList; use Symfony\Component\Form\ChoiceList\Loader\ChoiceLoaderInterface; /** * A choice list that loads its choices lazily. * * The choices are fetched using a {@link ChoiceLoaderInterface} instance. * If only {@link getChoicesForValues()} or {@link getValuesForChoices()} is * called, the choice list is only loaded partially for improved performance. * * Once {@link getChoices()} or {@link getValues()} is called, the list is * loaded fully. * * @author Bernhard Schussek */ class LazyChoiceList implements ChoiceListInterface { private $loader; /** * The callable creating string values for each choice. * * If null, choices are simply cast to strings. * * @var null|callable */ private $value; /** * @var ChoiceListInterface|null * * @deprecated Since 3.1, to be removed in 4.0. Cache the choice list in the {@link ChoiceLoaderInterface} instead. */ private $loadedList; /** * @var bool * * @deprecated Flag used for BC layer since 3.1. To be removed in 4.0. */ private $loaded = false; /** * Creates a lazily-loaded list using the given loader. * * Optionally, a callable can be passed for generating the choice values. * The callable receives the choice as first and the array key as the second * argument. * * @param ChoiceLoaderInterface $loader The choice loader * @param null|callable $value The callable generating the choice values */ public function __construct(ChoiceLoaderInterface $loader, callable $value = null) { $this->loader = $loader; $this->value = $value; } /** * {@inheritdoc} */ public function getChoices() { if ($this->loaded) { // We can safely invoke the {@link ChoiceLoaderInterface} assuming it has the list // in cache when the lazy list is already loaded if ($this->loadedList !== $this->loader->loadChoiceList($this->value)) { @trigger_error(sprintf('Caching the choice list in %s is deprecated since Symfony 3.1 and will not happen in 4.0. Cache the list in the %s instead.', __CLASS__, ChoiceLoaderInterface::class), E_USER_DEPRECATED); } return $this->loadedList->getChoices(); } // BC $this->loadedList = $this->loader->loadChoiceList($this->value); $this->loaded = true; return $this->loadedList->getChoices(); // In 4.0 keep the following line only: // return $this->loader->loadChoiceList($this->value)->getChoices() } /** * {@inheritdoc} */ public function getValues() { if ($this->loaded) { // Check whether the loader has the same cache if ($this->loadedList !== $this->loader->loadChoiceList($this->value)) { @trigger_error(sprintf('Caching the choice list in %s is deprecated since Symfony 3.1 and will not happen in 4.0. Cache the list in the %s instead.', __CLASS__, ChoiceLoaderInterface::class), E_USER_DEPRECATED); } return $this->loadedList->getValues(); } // BC $this->loadedList = $this->loader->loadChoiceList($this->value); $this->loaded = true; return $this->loadedList->getValues(); // In 4.0 keep the following line only: // return $this->loader->loadChoiceList($this->value)->getValues() } /** * {@inheritdoc} */ public function getStructuredValues() { if ($this->loaded) { // Check whether the loader has the same cache if ($this->loadedList !== $this->loader->loadChoiceList($this->value)) { @trigger_error(sprintf('Caching the choice list in %s is deprecated since Symfony 3.1 and will not happen in 4.0. Cache the list in the %s instead.', __CLASS__, ChoiceLoaderInterface::class), E_USER_DEPRECATED); } return $this->loadedList->getStructuredValues(); } // BC $this->loadedList = $this->loader->loadChoiceList($this->value); $this->loaded = true; return $this->loadedList->getStructuredValues(); // In 4.0 keep the following line only: // return $this->loader->loadChoiceList($this->value)->getStructuredValues(); } /** * {@inheritdoc} */ public function getOriginalKeys() { if ($this->loaded) { // Check whether the loader has the same cache if ($this->loadedList !== $this->loader->loadChoiceList($this->value)) { @trigger_error(sprintf('Caching the choice list in %s is deprecated since Symfony 3.1 and will not happen in 4.0. Cache the list in the %s instead.', __CLASS__, ChoiceLoaderInterface::class), E_USER_DEPRECATED); } return $this->loadedList->getOriginalKeys(); } // BC $this->loadedList = $this->loader->loadChoiceList($this->value); $this->loaded = true; return $this->loadedList->getOriginalKeys(); // In 4.0 keep the following line only: // return $this->loader->loadChoiceList($this->value)->getOriginalKeys(); } /** * {@inheritdoc} */ public function getChoicesForValues(array $values) { if ($this->loaded) { // Check whether the loader has the same cache if ($this->loadedList !== $this->loader->loadChoiceList($this->value)) { @trigger_error(sprintf('Caching the choice list in %s is deprecated since Symfony 3.1 and will not happen in 4.0. Cache the list in the %s instead.', __CLASS__, ChoiceLoaderInterface::class), E_USER_DEPRECATED); } return $this->loadedList->getChoicesForValues($values); } return $this->loader->loadChoicesForValues($values, $this->value); } /** * {@inheritdoc} */ public function getValuesForChoices(array $choices) { if ($this->loaded) { // Check whether the loader has the same cache if ($this->loadedList !== $this->loader->loadChoiceList($this->value)) { @trigger_error(sprintf('Caching the choice list in %s is deprecated since Symfony 3.1 and will not happen in 4.0. Cache the list in the %s instead.', __CLASS__, ChoiceLoaderInterface::class), E_USER_DEPRECATED); } return $this->loadedList->getValuesForChoices($choices); } return $this->loader->loadValuesForChoices($choices, $this->value); } } __halt_compiler();----SIGNATURE:----OimrZZJrQPfEWGaYbr4wpGF6BkpQ8wdjb7XnzugvQLVes8NgGCVYDWNivuZ/tQb+hYP2vRavfdjXtToHA0hWgEi1fcXZKXxeHjDAe0YpZR7+5iCAaxPytyhh4B8MMoHYXy39ynScDWUM5ecC72R5gbfq/gzOl9h2XDRDwS3D+4bFzNNu6vJYwd0ZxcV8D8NVvMJrkfCZVAUkUVMn3YWpc0ZEOtl2zg5OSwXYGQr6bN8hjWgvahNreCXoeXzExzE0fQZjdFVyEuJpN8aj2U3OR639M1pSbojp5oLyDLos9Ww9tKOwki7gi59fC+T0WG6sgs4f+ZRMRzA8a59Y7LxUcoZOEezAdqxztwxi6EikKlDr2AmrZoG4hvakyp3MKj2s/JfL4p67Mb5ADM9wg5RHS+nwfoh7vfvUTdVizRu5Z/7cDGdqXSgXZaoeIjlTbzAf1nAWMRffi+z4XYkT7rabSSqQk982GmV+nEsx/AZRmiIeGfo5cr3y/aXRgQNMfWBgsZVKDaLiH7ZHJwAGRzQXm43ee4FP2JpfOXHUI2i8tZ68EkOGfu74RC6LYSpbcjgrBOsUn5MN5kUNWK7nrYlVxdRNuVFL/lkbr5oXl4iKpQ9Mf4hY3NXwF9OViNR3bCcTMKKvpXdK1WE73Tmz0rjOj3wCIpea29lOj+KLfLLu9Yw=----ATTACHMENT:----Nzk5MDYzMDY2MDk0NjExNCA2Mjk4NzExNTkzNDgzMTc0IDMyODMxMjYyMDM2ODkwNTY=