%PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
Server IP : 49.231.201.246 / Your IP : 216.73.216.149 Web Server : Apache/2.4.18 (Ubuntu) System : Linux 246 4.4.0-210-generic #242-Ubuntu SMP Fri Apr 16 09:57:56 UTC 2021 x86_64 User : root ( 0) PHP Version : 7.0.33-0ubuntu0.16.04.16 Disable Function : exec,passthru,shell_exec,system,proc_open,popen,pcntl_exec MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /proc/11584/cwd/html/egp/vendor/zendframework/zend-feed/src/Writer/Renderer/ |
Upload File : |
<?php /** * Zend Framework (http://framework.zend.com/) * * @link http://github.com/zendframework/zf2 for the canonical source repository * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com) * @license http://framework.zend.com/license/new-bsd New BSD License */ namespace Zend\Feed\Writer\Renderer; use DOMDocument; use DOMElement; use Zend\Feed\Writer; /** */ class AbstractRenderer { /** * Extensions * @var array */ protected $extensions = array(); /** * @var Writer\AbstractFeed */ protected $container = null; /** * @var DOMDocument */ protected $dom = null; /** * @var bool */ protected $ignoreExceptions = false; /** * @var array */ protected $exceptions = array(); /** * Encoding of all text values * * @var string */ protected $encoding = 'UTF-8'; /** * Holds the value "atom" or "rss" depending on the feed type set when * when last exported. * * @var string */ protected $type = null; /** * @var DOMElement */ protected $rootElement = null; /** * Constructor * * @param Writer\AbstractFeed $container */ public function __construct($container) { $this->container = $container; $this->setType($container->getType()); $this->_loadExtensions(); } /** * Save XML to string * * @return string */ public function saveXml() { return $this->getDomDocument()->saveXml(); } /** * Get DOM document * * @return DOMDocument */ public function getDomDocument() { return $this->dom; } /** * Get document element from DOM * * @return DOMElement */ public function getElement() { return $this->getDomDocument()->documentElement; } /** * Get data container of items being rendered * * @return Writer\AbstractFeed */ public function getDataContainer() { return $this->container; } /** * Set feed encoding * * @param string $enc * @return AbstractRenderer */ public function setEncoding($enc) { $this->encoding = $enc; return $this; } /** * Get feed encoding * * @return string */ public function getEncoding() { return $this->encoding; } /** * Indicate whether or not to ignore exceptions * * @param bool $bool * @return AbstractRenderer * @throws Writer\Exception\InvalidArgumentException */ public function ignoreExceptions($bool = true) { if (!is_bool($bool)) { throw new Writer\Exception\InvalidArgumentException('Invalid parameter: $bool. Should be TRUE or FALSE (defaults to TRUE if null)'); } $this->ignoreExceptions = $bool; return $this; } /** * Get exception list * * @return array */ public function getExceptions() { return $this->exceptions; } /** * Set the current feed type being exported to "rss" or "atom". This allows * other objects to gracefully choose whether to execute or not, depending * on their appropriateness for the current type, e.g. renderers. * * @param string $type */ public function setType($type) { $this->type = $type; } /** * Retrieve the current or last feed type exported. * * @return string Value will be "rss" or "atom" */ public function getType() { return $this->type; } /** * Sets the absolute root element for the XML feed being generated. This * helps simplify the appending of namespace declarations, but also ensures * namespaces are added to the root element - not scattered across the entire * XML file - may assist namespace unsafe parsers and looks pretty ;). * * @param DOMElement $root */ public function setRootElement(DOMElement $root) { $this->rootElement = $root; } /** * Retrieve the absolute root element for the XML feed being generated. * * @return DOMElement */ public function getRootElement() { return $this->rootElement; } /** * Load extensions from Zend\Feed\Writer\Writer * * @return void */ protected function _loadExtensions() { Writer\Writer::registerCoreExtensions(); $manager = Writer\Writer::getExtensionManager(); $all = Writer\Writer::getExtensions(); if (stripos(get_class($this), 'entry')) { $exts = $all['entryRenderer']; } else { $exts = $all['feedRenderer']; } foreach ($exts as $extension) { $plugin = $manager->get($extension); $plugin->setDataContainer($this->getDataContainer()); $plugin->setEncoding($this->getEncoding()); $this->extensions[$extension] = $plugin; } } }