. */ /** * Doctrine_Validator_ErrorStack * * @author Konsta Vesterinen * @author Roman Borschel * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @package Doctrine * @category Object Relational Mapping * @link www.phpdoctrine.com * @since 1.0 * @version $Revision$ */ class Doctrine_Validator_ErrorStack extends Doctrine_Access implements Countable, IteratorAggregate { /** * The errors of the error stack. * * @var array */ protected $errors = array(); protected $classname = ""; /** * Constructor * */ public function __construct($classname = "") { $this->classname = $classname; } /** * Adds an error to the stack. * * @param string $invalidFieldName * @param string $errorType */ public function add($invalidFieldName, $errorCode = 'general') { $this->errors[$invalidFieldName][] = $errorCode; } /** * Removes all existing errors for the specified field from the stack. * * @param string $fieldName */ public function remove($fieldName) { if (isset($this->errors[$fieldName])) { unset($this->errors[$fieldName]); } } /** * Enter description here... * * @param unknown_type $name * @return unknown */ public function get($fieldName) { return isset($this->errors[$fieldName]) ? $this->errors[$fieldName] : null; } /** * Enter description here... * * @param unknown_type $name */ public function set($fieldName, $errorCode) { $this->add($fieldName, $errorCode); } /** * Enter description here... * * @return unknown */ public function contains($fieldName) { return array_key_exists($fieldName, $this->errors); } /** * Removes all errors from the stack. */ public function clear() { $this->errors = array(); } /** * Enter description here... * * @return unknown */ public function getIterator() { return new ArrayIterator($this->errors); } /** * Enter description here... * * @return unknown */ public function count() { return count($this->errors); } /** * Get the classname where the errors occured * */ public function getClassname(){ return $this->classname; } }