123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368 |
- <?php
- abstract class PHPExcel_CachedObjectStorage_CacheBase
- {
-
- protected $parent;
-
- protected $currentObject = null;
-
- protected $currentObjectID = null;
-
- protected $currentCellIsDirty = true;
-
- protected $cellCache = array();
-
- public function __construct(PHPExcel_Worksheet $parent)
- {
-
-
-
- $this->parent = $parent;
- }
-
- public function getParent()
- {
- return $this->parent;
- }
-
- public function isDataSet($pCoord)
- {
- if ($pCoord === $this->currentObjectID) {
- return true;
- }
-
- return isset($this->cellCache[$pCoord]);
- }
-
- public function moveCell($fromAddress, $toAddress)
- {
- if ($fromAddress === $this->currentObjectID) {
- $this->currentObjectID = $toAddress;
- }
- $this->currentCellIsDirty = true;
- if (isset($this->cellCache[$fromAddress])) {
- $this->cellCache[$toAddress] = &$this->cellCache[$fromAddress];
- unset($this->cellCache[$fromAddress]);
- }
- return true;
- }
-
- public function updateCacheData(PHPExcel_Cell $cell)
- {
- return $this->addCacheData($cell->getCoordinate(), $cell);
- }
-
- public function deleteCacheData($pCoord)
- {
- if ($pCoord === $this->currentObjectID && !is_null($this->currentObject)) {
- $this->currentObject->detach();
- $this->currentObjectID = $this->currentObject = null;
- }
- if (is_object($this->cellCache[$pCoord])) {
- $this->cellCache[$pCoord]->detach();
- unset($this->cellCache[$pCoord]);
- }
- $this->currentCellIsDirty = false;
- }
-
- public function getCellList()
- {
- return array_keys($this->cellCache);
- }
-
- public function getSortedCellList()
- {
- $sortKeys = array();
- foreach ($this->getCellList() as $coord) {
- sscanf($coord, '%[A-Z]%d', $column, $row);
- $sortKeys[sprintf('%09d%3s', $row, $column)] = $coord;
- }
- ksort($sortKeys);
- return array_values($sortKeys);
- }
-
- public function getHighestRowAndColumn()
- {
-
- $col = array('A' => '1A');
- $row = array(1);
- foreach ($this->getCellList() as $coord) {
- sscanf($coord, '%[A-Z]%d', $c, $r);
- $row[$r] = $r;
- $col[$c] = strlen($c).$c;
- }
- if (!empty($row)) {
-
- $highestRow = max($row);
- $highestColumn = substr(max($col), 1);
- }
- return array(
- 'row' => $highestRow,
- 'column' => $highestColumn
- );
- }
-
- public function getCurrentAddress()
- {
- return $this->currentObjectID;
- }
-
- public function getCurrentColumn()
- {
- sscanf($this->currentObjectID, '%[A-Z]%d', $column, $row);
- return $column;
- }
-
- public function getCurrentRow()
- {
- sscanf($this->currentObjectID, '%[A-Z]%d', $column, $row);
- return (integer) $row;
- }
-
- public function getHighestColumn($row = null)
- {
- if ($row == null) {
- $colRow = $this->getHighestRowAndColumn();
- return $colRow['column'];
- }
- $columnList = array(1);
- foreach ($this->getCellList() as $coord) {
- sscanf($coord, '%[A-Z]%d', $c, $r);
- if ($r != $row) {
- continue;
- }
- $columnList[] = PHPExcel_Cell::columnIndexFromString($c);
- }
- return PHPExcel_Cell::stringFromColumnIndex(max($columnList) - 1);
- }
-
- public function getHighestRow($column = null)
- {
- if ($column == null) {
- $colRow = $this->getHighestRowAndColumn();
- return $colRow['row'];
- }
- $rowList = array(0);
- foreach ($this->getCellList() as $coord) {
- sscanf($coord, '%[A-Z]%d', $c, $r);
- if ($c != $column) {
- continue;
- }
- $rowList[] = $r;
- }
- return max($rowList);
- }
-
- protected function getUniqueID()
- {
- if (function_exists('posix_getpid')) {
- $baseUnique = posix_getpid();
- } else {
- $baseUnique = mt_rand();
- }
- return uniqid($baseUnique, true);
- }
-
- public function copyCellCollection(PHPExcel_Worksheet $parent)
- {
- $this->currentCellIsDirty;
- $this->storeData();
- $this->parent = $parent;
- if (($this->currentObject !== null) && (is_object($this->currentObject))) {
- $this->currentObject->attach($this);
- }
- }
-
- public function removeRow($row)
- {
- foreach ($this->getCellList() as $coord) {
- sscanf($coord, '%[A-Z]%d', $c, $r);
- if ($r == $row) {
- $this->deleteCacheData($coord);
- }
- }
- }
-
- public function removeColumn($column)
- {
- foreach ($this->getCellList() as $coord) {
- sscanf($coord, '%[A-Z]%d', $c, $r);
- if ($c == $column) {
- $this->deleteCacheData($coord);
- }
- }
- }
-
- public static function cacheMethodIsAvailable()
- {
- return true;
- }
- }
|