_cellCache[$pCoord] = $cell; // Set current entry to the new/updated entry $this->_currentObjectID = $pCoord; return $cell; } /** * Get cell at a specific coordinate * * @param string $pCoord Coordinate of the cell * @throws PHPExcel_Exception * @return PHPExcel_Cell Cell that was found, or null if not found */ public function getCacheData($pCoord) { // Check if the entry that has been requested actually exists if (!isset($this->_cellCache[$pCoord])) { $this->_currentObjectID = null; // Return null if requested entry doesn't exist in cache return null; } // Set current entry to the requested entry $this->_currentObjectID = $pCoord; // Return requested entry return $this->_cellCache[$pCoord]; } /** * Clone the cell collection * * @param PHPExcel_Worksheet $parent The new worksheet */ public function copyCellCollection(PHPExcel_Worksheet $parent) { parent::copyCellCollection($parent); $newCollection = array(); foreach ($this->_cellCache as $k => &$cell) { $newCollection[$k] = clone $cell; $newCollection[$k]->attach($this); } $this->_cellCache = $newCollection; } /** * Clear the cell collection and disconnect from our parent * */ public function unsetWorksheetCells() { // Because cells are all stored as intact objects in memory, we need to detach each one from the parent foreach ($this->_cellCache as $k => &$cell) { $cell->detach(); $this->_cellCache[$k] = null; } unset($cell); $this->_cellCache = array(); // detach ourself from the worksheet, so that it can then delete this object successfully $this->_parent = null; } }