3 * Zend Framework (http://framework.zend.com/)
5 * @link http://github.com/zendframework/zf2 for the canonical source repository
6 * @copyright Copyright (c) 2005-2013 Zend Technologies USA Inc. (http://www.zend.com)
7 * @license http://framework.zend.com/license/new-bsd New BSD License
10 namespace Zend\Barcode
;
12 use Zend\ServiceManager\AbstractPluginManager
;
15 * Plugin manager implementation for barcode renderers.
17 * Enforces that barcode parsers retrieved are instances of
18 * Renderer\AbstractRenderer. Additionally, it registers a number of default
21 class RendererPluginManager
extends AbstractPluginManager
24 * @var bool Ensure services are not shared
26 protected $shareByDefault = false;
29 * Default set of barcode renderers
33 protected $invokableClasses = array(
34 'image' => 'Zend\Barcode\Renderer\Image',
35 'pdf' => 'Zend\Barcode\Renderer\Pdf',
36 'svg' => 'Zend\Barcode\Renderer\Svg'
42 * Checks that the barcode parser loaded is an instance
43 * of Renderer\AbstractRenderer.
45 * @param mixed $plugin
47 * @throws Exception\InvalidArgumentException if invalid
49 public function validatePlugin($plugin)
51 if ($plugin instanceof Renderer\AbstractRenderer
) {
56 throw new Exception\
InvalidArgumentException(sprintf(
57 'Plugin of type %s is invalid; must extend %s\Renderer\AbstractRenderer',
58 (is_object($plugin) ?
get_class($plugin) : gettype($plugin)),