_View = $view; } /** * Loads/constructs a helper. Will return the instance in the registry if it already exists. * * @param string $helper Helper name to load * @param array $settings Settings for the helper. * @param boolean $enable Whether or not this helper should be enabled by default * @return Helper A helper object, Either the existing loaded helper or a new one. * @throws MissingHelperFileException, MissingHelperClassException when the helper could not be found */ public function load($helper, $settings = array(), $enable = true) { list($plugin, $name) = pluginSplit($helper, true); if (isset($this->{$name})) { return $this->{$name}; } $helperClass = $name . 'Helper'; if (!class_exists($helperClass)) { if (!App::import('Helper', $helper)) { throw new MissingHelperFileException(Inflector::underscore($name) . '.php'); } if (!class_exists($helperClass)) { throw new MissingHelperClassException($helperClass); } } $this->{$name} = new $helperClass($this->_View, $settings); if (!in_array($name, $this->_attached)) { $this->_attached[] = $name; } if ($enable === false) { $this->_disabled[] = $name; } return $this->{$name}; } /** * Name of the helper to remove from the collection * * @param string $name Name of helper to delete. * @return void */ public function unload($name) { list($plugin, $name) = pluginSplit($name); unset($this->{$name}); $this->_attached = array_values(array_diff($this->_attached, (array)$name)); } } /** * Exceptions used by the HelperCollection. */ class MissingHelperFileException extends RuntimeException { } class MissingHelperClassException extends RuntimeException { }