array( ), self::cache_in_memory_gzip => array( ), self::cache_in_memory_serialized => array( ), self::cache_igbinary => array( ), self::cache_to_phpTemp => array( 'memoryCacheSize' => '1MB' ), self::cache_to_discISAM => array( 'dir' => null ), self::cache_to_apc => array( 'cacheTime' => 600 ), self::cache_to_memcache => array( 'memcacheServer' => 'localhost', 'memcachePort' => 11211, 'cacheTime' => 600 ), self::cache_to_wincache => array( 'cacheTime' => 600 ), self::cache_to_sqlite => array( ), self::cache_to_sqlite3 => array( ), ); /** * Arguments for the active cache storage method * * @var array of mixed array */ private static $storageMethodParameters = array(); /** * Return the current cache storage method * * @return string|null **/ public static function getCacheStorageMethod() { return self::$cacheStorageMethod; } /** * Return the current cache storage class * * @return PHPExcel_CachedObjectStorage_ICache|null **/ public static function getCacheStorageClass() { return self::$cacheStorageClass; } /** * Return the list of all possible cache storage methods * * @return string[] **/ public static function getAllCacheStorageMethods() { return self::$storageMethods; } /** * Return the list of all available cache storage methods * * @return string[] **/ public static function getCacheStorageMethods() { $activeMethods = array(); foreach (self::$storageMethods as $storageMethod) { $cacheStorageClass = 'PHPExcel_CachedObjectStorage_' . $storageMethod; if (call_user_func(array($cacheStorageClass, 'cacheMethodIsAvailable'))) { $activeMethods[] = $storageMethod; } } return $activeMethods; } /** * Identify the cache storage method to use * * @param string $method Name of the method to use for cell cacheing * @param array of mixed $arguments Additional arguments to pass to the cell caching class * when instantiating * @return boolean **/ public static function initialize($method = self::cache_in_memory, $arguments = array()) { if (!in_array($method, self::$storageMethods)) { return false; } $cacheStorageClass = 'PHPExcel_CachedObjectStorage_'.$method; if (!call_user_func(array( $cacheStorageClass, 'cacheMethodIsAvailable'))) { return false; } self::$storageMethodParameters[$method] = self::$storageMethodDefaultParameters[$method]; foreach ($arguments as $k => $v) { if (array_key_exists($k, self::$storageMethodParameters[$method])) { self::$storageMethodParameters[$method][$k] = $v; } } if (self::$cacheStorageMethod === null) { self::$cacheStorageClass = 'PHPExcel_CachedObjectStorage_' . $method; self::$cacheStorageMethod = $method; } return true; } /** * Initialise the cache storage * * @param PHPExcel_Worksheet $parent Enable cell caching for this worksheet * @return PHPExcel_CachedObjectStorage_ICache **/ public static function getInstance(PHPExcel_Worksheet $parent) { $cacheMethodIsAvailable = true; if (self::$cacheStorageMethod === null) { $cacheMethodIsAvailable = self::initialize(); } if ($cacheMethodIsAvailable) { $instance = new self::$cacheStorageClass( $parent, self::$storageMethodParameters[self::$cacheStorageMethod] ); if ($instance !== null) { return $instance; } } return false; } /** * Clear the cache storage * **/ public static function finalize() { self::$cacheStorageMethod = null; self::$cacheStorageClass = null; self::$storageMethodParameters = array(); } }