registerAllNamespaces(Zend_Gdata::$namespaces); parent::__construct($element); } public function getDOM($doc = null, $majorVersion = 1, $minorVersion = null) { $element = parent::getDOM($doc, $majorVersion, $minorVersion); if ($this->_totalResults != null) { $element->appendChild($this->_totalResults->getDOM($element->ownerDocument)); } if ($this->_startIndex != null) { $element->appendChild($this->_startIndex->getDOM($element->ownerDocument)); } if ($this->_itemsPerPage != null) { $element->appendChild($this->_itemsPerPage->getDOM($element->ownerDocument)); } // ETags are special. We only support them in protocol >= 2.X. // This will be duplicated by the HTTP ETag header. if ($majorVersion >= 2) { if ($this->_etag != null) { $element->setAttributeNS($this->lookupNamespace('gd'), 'gd:etag', $this->_etag); } } return $element; } /** * Creates individual Entry objects of the appropriate type and * stores them in the $_entry array based upon DOM data. * * @param DOMNode $child The DOMNode to process */ protected function takeChildFromDOM($child) { $absoluteNodeName = $child->namespaceURI . ':' . $child->localName; switch ($absoluteNodeName) { case $this->lookupNamespace('openSearch') . ':' . 'totalResults': $totalResults = new Zend_Gdata_Extension_OpenSearchTotalResults(); $totalResults->transferFromDOM($child); $this->_totalResults = $totalResults; break; case $this->lookupNamespace('openSearch') . ':' . 'startIndex': $startIndex = new Zend_Gdata_Extension_OpenSearchStartIndex(); $startIndex->transferFromDOM($child); $this->_startIndex = $startIndex; break; case $this->lookupNamespace('openSearch') . ':' . 'itemsPerPage': $itemsPerPage = new Zend_Gdata_Extension_OpenSearchItemsPerPage(); $itemsPerPage->transferFromDOM($child); $this->_itemsPerPage = $itemsPerPage; break; default: parent::takeChildFromDOM($child); break; } } /** * Given a DOMNode representing an attribute, tries to map the data into * instance members. If no mapping is defined, the name and value are * stored in an array. * * @param DOMNode $attribute The DOMNode attribute needed to be handled */ protected function takeAttributeFromDOM($attribute) { switch ($attribute->localName) { case 'etag': // ETags are special, since they can be conveyed by either the // HTTP ETag header or as an XML attribute. $etag = $attribute->nodeValue; if ($this->_etag === null) { $this->_etag = $etag; } elseif ($this->_etag != $etag) { #require_once('Zend/Gdata/App/IOException.php'); throw new Zend_Gdata_App_IOException("ETag mismatch"); } break; default: parent::takeAttributeFromDOM($attribute); break; } } /** * Set the value of the totalResults property. * * @param Zend_Gdata_Extension_OpenSearchTotalResults|null $value The * value of the totalResults property. Use null to unset. * @return Zend_Gdata_Feed Provides a fluent interface. */ function setTotalResults($value) { $this->_totalResults = $value; return $this; } /** * Get the value of the totalResults property. * * @return Zend_Gdata_Extension_OpenSearchTotalResults|null The value of * the totalResults property, or null if unset. */ function getTotalResults() { return $this->_totalResults; } /** * Set the start index property for feed paging. * * @param Zend_Gdata_Extension_OpenSearchStartIndex|null $value The value * for the startIndex property. Use null to unset. * @return Zend_Gdata_Feed Provides a fluent interface. */ function setStartIndex($value) { $this->_startIndex = $value; return $this; } /** * Get the value of the startIndex property. * * @return Zend_Gdata_Extension_OpenSearchStartIndex|null The value of the * startIndex property, or null if unset. */ function getStartIndex() { return $this->_startIndex; } /** * Set the itemsPerPage property. * * @param Zend_Gdata_Extension_OpenSearchItemsPerPage|null $value The * value for the itemsPerPage property. Use nul to unset. * @return Zend_Gdata_Feed Provides a fluent interface. */ function setItemsPerPage($value) { $this->_itemsPerPage = $value; return $this; } /** * Get the value of the itemsPerPage property. * * @return Zend_Gdata_Extension_OpenSearchItemsPerPage|null The value of * the itemsPerPage property, or null if unset. */ function getItemsPerPage() { return $this->_itemsPerPage; } }