annotate vendor/zendframework/zend-feed/src/Reader/StandaloneExtensionManager.php @ 12:7a779792577d

Update Drupal core to v8.4.5 (via Composer)
author Chris Cannam
date Fri, 23 Feb 2018 15:52:07 +0000
parents 4c8ae668cc8c
children c2387f117808
rev   line source
Chris@0 1 <?php
Chris@0 2 /**
Chris@0 3 * Zend Framework (http://framework.zend.com/)
Chris@0 4 *
Chris@0 5 * @link http://github.com/zendframework/zf2 for the canonical source repository
Chris@0 6 * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
Chris@0 7 * @license http://framework.zend.com/license/new-bsd New BSD License
Chris@0 8 */
Chris@0 9
Chris@0 10 namespace Zend\Feed\Reader;
Chris@0 11
Chris@12 12 use Zend\Feed\Reader\Exception\InvalidArgumentException;
Chris@12 13
Chris@0 14 class StandaloneExtensionManager implements ExtensionManagerInterface
Chris@0 15 {
Chris@0 16 private $extensions = [
Chris@12 17 'Atom\Entry' => Extension\Atom\Entry::class,
Chris@12 18 'Atom\Feed' => Extension\Atom\Feed::class,
Chris@12 19 'Content\Entry' => Extension\Content\Entry::class,
Chris@12 20 'CreativeCommons\Entry' => Extension\CreativeCommons\Entry::class,
Chris@12 21 'CreativeCommons\Feed' => Extension\CreativeCommons\Feed::class,
Chris@12 22 'DublinCore\Entry' => Extension\DublinCore\Entry::class,
Chris@12 23 'DublinCore\Feed' => Extension\DublinCore\Feed::class,
Chris@12 24 'Podcast\Entry' => Extension\Podcast\Entry::class,
Chris@12 25 'Podcast\Feed' => Extension\Podcast\Feed::class,
Chris@12 26 'Slash\Entry' => Extension\Slash\Entry::class,
Chris@12 27 'Syndication\Feed' => Extension\Syndication\Feed::class,
Chris@12 28 'Thread\Entry' => Extension\Thread\Entry::class,
Chris@12 29 'WellFormedWeb\Entry' => Extension\WellFormedWeb\Entry::class,
Chris@0 30 ];
Chris@0 31
Chris@0 32 /**
Chris@0 33 * Do we have the extension?
Chris@0 34 *
Chris@0 35 * @param string $extension
Chris@0 36 * @return bool
Chris@0 37 */
Chris@0 38 public function has($extension)
Chris@0 39 {
Chris@0 40 return array_key_exists($extension, $this->extensions);
Chris@0 41 }
Chris@0 42
Chris@0 43 /**
Chris@0 44 * Retrieve the extension
Chris@0 45 *
Chris@0 46 * @param string $extension
Chris@0 47 * @return Extension\AbstractEntry|Extension\AbstractFeed
Chris@0 48 */
Chris@0 49 public function get($extension)
Chris@0 50 {
Chris@0 51 $class = $this->extensions[$extension];
Chris@0 52 return new $class();
Chris@0 53 }
Chris@12 54
Chris@12 55 /**
Chris@12 56 * Add an extension.
Chris@12 57 *
Chris@12 58 * @param string $name
Chris@12 59 * @param string $class
Chris@12 60 */
Chris@12 61 public function add($name, $class)
Chris@12 62 {
Chris@12 63 if (is_string($class)
Chris@12 64 && (
Chris@12 65 is_a($class, Extension\AbstractEntry::class, true)
Chris@12 66 || is_a($class, Extension\AbstractFeed::class, true)
Chris@12 67 )
Chris@12 68 ) {
Chris@12 69 $this->extensions[$name] = $class;
Chris@12 70 return;
Chris@12 71 }
Chris@12 72
Chris@12 73 throw new InvalidArgumentException(sprintf(
Chris@12 74 'Plugin of type %s is invalid; must implement %2$s\Extension\AbstractFeed '
Chris@12 75 . 'or %2$s\Extension\AbstractEntry',
Chris@12 76 $class,
Chris@12 77 __NAMESPACE__
Chris@12 78 ));
Chris@12 79 }
Chris@12 80
Chris@12 81 /**
Chris@12 82 * Remove an extension.
Chris@12 83 *
Chris@12 84 * @param string $name
Chris@12 85 */
Chris@12 86 public function remove($name)
Chris@12 87 {
Chris@12 88 unset($this->extensions[$name]);
Chris@12 89 }
Chris@0 90 }