Mercurial > hg > isophonics-drupal-site
diff core/lib/Drupal/Core/Plugin/DefaultSingleLazyPluginCollection.php @ 0:4c8ae668cc8c
Initial import (non-working)
author | Chris Cannam |
---|---|
date | Wed, 29 Nov 2017 16:09:58 +0000 |
parents | |
children | af1871eacc83 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/core/lib/Drupal/Core/Plugin/DefaultSingleLazyPluginCollection.php Wed Nov 29 16:09:58 2017 +0000 @@ -0,0 +1,103 @@ +<?php + +namespace Drupal\Core\Plugin; + +use Drupal\Component\Plugin\PluginManagerInterface; +use Drupal\Component\Plugin\LazyPluginCollection; +use Drupal\Component\Plugin\ConfigurablePluginInterface; +use Drupal\Core\DependencyInjection\DependencySerializationTrait; + +/** + * Provides a default plugin collection for a plugin type. + * + * A plugin collection usually stores multiple plugins, and is used to lazily + * instantiate them. When only one plugin is needed, it is still best practice + * to encapsulate all of the instantiation logic in a plugin collection. This + * class can be used directly, or subclassed to add further exception handling + * in self::initializePlugin(). + */ +class DefaultSingleLazyPluginCollection extends LazyPluginCollection { + use DependencySerializationTrait; + + /** + * The manager used to instantiate the plugins. + * + * @var \Drupal\Component\Plugin\PluginManagerInterface + */ + protected $manager; + + /** + * An array of configuration to instantiate the plugin with. + * + * @var array + */ + protected $configuration; + + /** + * The instance ID used for this plugin collection. + * + * @var string + */ + protected $instanceId; + + /** + * Constructs a new DefaultSingleLazyPluginCollection object. + * + * @param \Drupal\Component\Plugin\PluginManagerInterface $manager + * The manager to be used for instantiating plugins. + * @param string $instance_id + * The ID of the plugin instance. + * @param array $configuration + * An array of configuration. + */ + public function __construct(PluginManagerInterface $manager, $instance_id, array $configuration) { + $this->manager = $manager; + $this->addInstanceId($instance_id, $configuration); + } + + /** + * {@inheritdoc} + */ + protected function initializePlugin($instance_id) { + $this->set($instance_id, $this->manager->createInstance($instance_id, $this->configuration)); + } + + /** + * {@inheritdoc} + */ + public function getConfiguration() { + $plugin = $this->get($this->instanceId); + if ($plugin instanceof ConfigurablePluginInterface) { + return $plugin->getConfiguration(); + } + else { + return $this->configuration; + } + } + + /** + * {@inheritdoc} + */ + public function setConfiguration($configuration) { + $this->configuration = $configuration; + $plugin = $this->get($this->instanceId); + if ($plugin instanceof ConfigurablePluginInterface) { + $plugin->setConfiguration($configuration); + } + return $this; + } + + /** + * {@inheritdoc} + */ + public function addInstanceId($id, $configuration = NULL) { + $this->instanceId = $id; + // Reset the list of instance IDs since there can be only one. + $this->instanceIDs = []; + parent::addInstanceId($id, $configuration); + if ($configuration !== NULL) { + $this->setConfiguration($configuration); + } + } + +}