Skip to content
This repository has been archived by the owner on Jan 31, 2020. It is now read-only.

Commit

Permalink
Resolved merge conflict
Browse files Browse the repository at this point in the history
  • Loading branch information
Show file tree
Hide file tree
Showing 5 changed files with 152 additions and 204 deletions.
96 changes: 46 additions & 50 deletions src/Cloud.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,6 @@

use Traversable;
use Zend\Stdlib\ArrayUtils;
use Zend\Tag\Exception\InvalidArgumentException,
Zend\Loader\Broker;

/**
* @category Zend
Expand All @@ -51,16 +49,16 @@ class Cloud
/**
* List of all tags
*
* @var \Zend\Tag\ItemList
* @var ItemList
*/
protected $_tags = null;

/**
* Plugin broker for decorators
* Plugin manager for decorators
*
* @var \Zend\Loader\Broker
* @var Cloud\DecoratorPluginManager
*/
protected $_decoratorBroker = null;
protected $_decorators = null;

/**
* Option keys to skip when calling setOptions()
Expand Down Expand Up @@ -90,8 +88,8 @@ public function __construct($options = null)
/**
* Set options from array
*
* @param array $options Configuration for \Zend\Tag\Cloud
* @return \Zend\Tag\Cloud
* @param array $options Configuration for Cloud
* @return Cloud
*/
public function setOptions(array $options)
{
Expand Down Expand Up @@ -124,53 +122,51 @@ public function setOptions(array $options)
* decorators.
*
* @param array $tags
* @throws \Zend\Tag\Exception\InvalidArgumentException
* @return \Zend\Tag\Cloud
* @throws Exception\InvalidArgumentException
* @return Cloud
*/
public function setTags(array $tags)
{
// Validate and cleanup the tags
$itemList = $this->getItemList();

foreach ($tags as $tag) {
if ($tag instanceof TaggableInterface) {
$itemList[] = $tag;
} else if (is_array($tag)) {
$itemList[] = new Item($tag);
} else {
throw new InvalidArgumentException('Tag must be an instance of Zend\Tag\TaggableInterface or an array');
}
$this->appendTag($tag);
}

return $this;
}

/**
* Append a single tag to the cloud
*
* @param \Zend\Tag\TaggableInterface|array $tag
* @throws \Zend\Tag\Exception\InvalidArgumentException
* @return \Zend\Tag\Cloud
* @param TaggableInterface|array $tag
* @throws Exception\InvalidArgumentException
* @return Cloud
*/
public function appendTag($tag)
{
$tags = $this->getItemList();

if ($tag instanceof TaggableInterface) {
$tags[] = $tag;
} else if (is_array($tag)) {
$tags[] = new Item($tag);
} else {
throw new InvalidArgumentException('Tag must be an instance of Zend\Tag\TaggableInterface or an array');
return $this;
}

if (!is_array($tag)) {
throw new Exception\InvalidArgumentException(sprintf(
'Tag must be an instance of %s\TaggableInterface or an array; received "%s"',
__NAMESPACE__,
(is_object($tag) ? get_class($tag) : gettype($tag))
));
}

$tags[] = new Item($tag);

return $this;
}

/**
* Set the item list
*
* @param \Zend\Tag\ItemList $itemList
* @return \Zend\Tag\Cloud
* @param ItemList $itemList
* @return Cloud
*/
public function setItemList(ItemList $itemList)
{
Expand All @@ -183,7 +179,7 @@ public function setItemList(ItemList $itemList)
*
* If item list is undefined, creates one.
*
* @return \Zend\Tag\ItemList
* @return ItemList
*/
public function getItemList()
{
Expand All @@ -197,8 +193,8 @@ public function getItemList()
* Set the decorator for the cloud
*
* @param mixed $decorator
* @throws \Zend\Tag\Exception\InvalidArgumentException
* @return \Zend\Tag\Cloud
* @throws Exception\InvalidArgumentException
* @return Cloud
*/
public function setCloudDecorator($decorator)
{
Expand All @@ -215,11 +211,11 @@ public function setCloudDecorator($decorator)
}

if (is_string($decorator)) {
$decorator = $this->getDecoratorBroker()->load($decorator, $options);
$decorator = $this->getDecoratorPluginManager()->get($decorator, $options);
}

if (!($decorator instanceof Cloud\Decorator\Cloud)) {
throw new InvalidArgumentException('DecoratorInterface is no instance of Zend\Tag\Cloud\Decorator\Cloud');
throw new Exception\InvalidArgumentException('DecoratorInterface is no instance of Cloud\Decorator\Cloud');
}

$this->_cloudDecorator = $decorator;
Expand All @@ -244,8 +240,8 @@ public function getCloudDecorator()
* Set the decorator for the tags
*
* @param mixed $decorator
* @throws \Zend\Tag\Exception\InvalidArgumentException
* @return \Zend\Tag\Cloud
* @throws Exception\InvalidArgumentException
* @return Cloud
*/
public function setTagDecorator($decorator)
{
Expand All @@ -262,11 +258,11 @@ public function setTagDecorator($decorator)
}

if (is_string($decorator)) {
$decorator = $this->getDecoratorBroker()->load($decorator, $options);
$decorator = $this->getDecoratorPluginManager()->get($decorator, $options);
}

if (!($decorator instanceof Cloud\Decorator\Tag)) {
throw new InvalidArgumentException('DecoratorInterface is no instance of Zend\Tag\Cloud\Decorator\Tag');
throw new Exception\InvalidArgumentException('DecoratorInterface is no instance of Cloud\Decorator\Tag');
}

$this->_tagDecorator = $decorator;
Expand All @@ -288,29 +284,29 @@ public function getTagDecorator()
}

/**
* Set plugin broker for use with decorators
* Set plugin manager for use with decorators
*
* @param \Zend\Loader\Broker $broker
* @return \Zend\Tag\Cloud
* @param Cloud\DecoratorPluginManager $decorators
* @return Cloud
*/
public function setDecoratorBroker(Broker $broker)
public function setDecoratorPluginManager(Cloud\DecoratorPluginManager $decorators)
{
$this->_decoratorBroker = $broker;
$this->_decorators = $decorators;
return $this;
}

/**
* Get the plugin broker for decorators
* Get the plugin manager for decorators
*
* @return \Zend\Loader\Broker
* @return Cloud\DecoratorPluginManager
*/
public function getDecoratorBroker()
public function getDecoratorPluginManager()
{
if ($this->_decoratorBroker === null) {
$this->_decoratorBroker = new Cloud\DecoratorBroker();
if ($this->_decorators === null) {
$this->_decorators = new Cloud\DecoratorPluginManager();
}

return $this->_decoratorBroker;
return $this->_decorators;
}

/**
Expand Down
58 changes: 0 additions & 58 deletions src/Cloud/DecoratorBroker.php

This file was deleted.

47 changes: 0 additions & 47 deletions src/Cloud/DecoratorLoader.php

This file was deleted.

77 changes: 77 additions & 0 deletions src/Cloud/DecoratorPluginManager.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
<?php
/**
* Zend Framework
*
* LICENSE
*
* This source file is subject to the new BSD license that is bundled
* with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://framework.zend.com/license/new-bsd
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@zend.com so we can send you a copy immediately.
*
* @category Zend
* @package Zend_Tag
* @subpackage Cloud
* @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

namespace Zend\Tag\Cloud;

use Zend\ServiceManager\AbstractPluginManager;
use Zend\Tag\Exception;

/**
* Plugin manager implementation for decorators.
*
* Enforces that decorators retrieved are instances of
* Decorator\DecoratorInterface. Additionally, it registers a number of default
* decorators available.
*
* @category Zend
* @package Zend_Tag
* @subpackage Cloud
* @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
class DecoratorPluginManager extends AbstractPluginManager
{
/**
* Default set of decorators
*
* @var array
*/
protected $invokableClasses = array(
'htmlcloud' => 'Zend\Tag\Cloud\Decorator\HtmlCloud',
'htmltag' => 'Zend\Tag\Cloud\Decorator\HtmlTag',
'tag' => 'Zend\Tag\Cloud\Decorator\Tag',
);

/**
* Validate the plugin
*
* Checks that the decorator loaded is an instance
* of Decorator\DecoratorInterface.
*
* @param mixed $plugin
* @return void
* @throws Exception\InvalidArgumentException if invalid
*/
public function validatePlugin($plugin)
{
if ($plugin instanceof Decorator\DecoratorInterface) {
// we're okay
return;
}

throw new Exception\InvalidArgumentException(sprintf(
'Plugin of type %s is invalid; must implement %s\Decorator\DecoratorInterface',
(is_object($plugin) ? get_class($plugin) : gettype($plugin)),
__NAMESPACE__
));
}
}

Loading

0 comments on commit bd1a8cd

Please sign in to comment.