public ArchiverManager::getInstance(array $options)
Gets a preconfigured instance of a plugin.
array $options: An array of options that can be used to determine a suitable plugin to instantiate and how to configure it.
object|false A fully configured plugin instance. The interface of the plugin instance will depends on the plugin type. If no instance can be retrieved, FALSE will be returned.
Overrides PluginManagerBase::getInstance
public function getInstance(array $options) { $filepath = $options['filepath']; foreach ($this->getDefinitions() as $plugin_id => $definition) { foreach ($definition['extensions'] as $extension) { // Because extensions may be multi-part, such as .tar.gz, // we cannot use simpler approaches like substr() or pathinfo(). // This method isn't quite as clean but gets the job done. // Also note that the file may not yet exist, so we cannot rely // on fileinfo() or other disk-level utilities. if (strrpos($filepath, '.' . $extension) === strlen($filepath) - strlen('.' . $extension)) { return $this->createInstance($plugin_id, $options); } } } }
© 2001–2016 by the original authors
Licensed under the GNU General Public License, version 2 and later.
Drupal is a registered trademark of Dries Buytaert.
https://api.drupal.org/api/drupal/core!lib!Drupal!Core!Archiver!ArchiverManager.php/function/ArchiverManager::getInstance/8.1.x