You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							134 lines
						
					
					
						
							4.8 KiB
						
					
					
				
			
		
		
	
	
							134 lines
						
					
					
						
							4.8 KiB
						
					
					
				<?php | 
						|
/** | 
						|
 * CDirectoryCacheDependency class file. | 
						|
 * | 
						|
 * @author Qiang Xue <qiang.xue@gmail.com> | 
						|
 * @link http://www.yiiframework.com/ | 
						|
 * @copyright Copyright © 2008-2011 Yii Software LLC | 
						|
 * @license http://www.yiiframework.com/license/ | 
						|
 */ | 
						|
 | 
						|
/** | 
						|
 * CDirectoryCacheDependency represents a dependency based on change of a directory. | 
						|
 * | 
						|
 * CDirectoryCacheDependency performs dependency checking based on the | 
						|
 * modification time of the files contained in the specified directory. | 
						|
 * The directory being checked is specified via {@link directory}. | 
						|
 * | 
						|
 * By default, all files under the specified directory and subdirectories | 
						|
 * will be checked. If the last modification time of any of them is changed | 
						|
 * or if different number of files are contained in a directory, the dependency | 
						|
 * is reported as changed. By specifying {@link recursiveLevel}, | 
						|
 * one can limit the checking to a certain depth of the directory. | 
						|
 * | 
						|
 * Note, dependency checking for a directory is expensive because it involves | 
						|
 * accessing modification time of multiple files under the directory. | 
						|
 * | 
						|
 * @author Qiang Xue <qiang.xue@gmail.com> | 
						|
 * @version $Id$ | 
						|
 * @package system.caching.dependencies | 
						|
 * @since 1.0 | 
						|
 */ | 
						|
class CDirectoryCacheDependency extends CCacheDependency | 
						|
{ | 
						|
	/** | 
						|
	 * @var string the directory whose change is used to determine if the dependency has been changed. | 
						|
	 * If any of the files under the directory is changed, the dependency is considered as changed. | 
						|
	 */ | 
						|
	public $directory; | 
						|
	/** | 
						|
	 * @var integer the depth of the subdirectories to be recursively checked. | 
						|
	 * If the value is less than 0, it means unlimited depth. | 
						|
	 * If the value is 0, it means checking the files directly under the specified directory. | 
						|
	 */ | 
						|
	public $recursiveLevel=-1; | 
						|
	/** | 
						|
	 * @var string the regular expression matching valid file/directory names. | 
						|
	 * Only the matching files or directories will be checked for changes. | 
						|
	 * Defaults to null, meaning all files/directories will qualify. | 
						|
	 */ | 
						|
	public $namePattern; | 
						|
 | 
						|
	/** | 
						|
	 * Constructor. | 
						|
	 * @param string $directory the directory to be checked | 
						|
	 */ | 
						|
	public function __construct($directory=null) | 
						|
	{ | 
						|
		$this->directory=$directory; | 
						|
	} | 
						|
 | 
						|
	/** | 
						|
	 * Generates the data needed to determine if dependency has been changed. | 
						|
	 * This method returns the modification timestamps for files under the directory. | 
						|
	 * @return mixed the data needed to determine if dependency has been changed. | 
						|
	 */ | 
						|
	protected function generateDependentData() | 
						|
	{ | 
						|
		if($this->directory!==null) | 
						|
			return $this->generateTimestamps($this->directory); | 
						|
		else | 
						|
			throw new CException(Yii::t('yii','CDirectoryCacheDependency.directory cannot be empty.')); | 
						|
	} | 
						|
 | 
						|
	/** | 
						|
	 * Determines the last modification time for files under the directory. | 
						|
	 * This method may go recursively into subdirectories if {@link recursiveLevel} is not 0. | 
						|
	 * @param string $directory the directory name | 
						|
	 * @param integer $level level of the recursion | 
						|
	 * @return array list of file modification time indexed by the file path | 
						|
	 */ | 
						|
	protected function generateTimestamps($directory,$level=0) | 
						|
	{ | 
						|
		if(($dir=@opendir($directory))===false) | 
						|
			throw new CException(Yii::t('yii','"{path}" is not a valid directory.', | 
						|
				array('{path}'=>$directory))); | 
						|
		$timestamps=array(); | 
						|
		while(($file=readdir($dir))!==false) | 
						|
		{ | 
						|
			$path=$directory.DIRECTORY_SEPARATOR.$file; | 
						|
			if($file==='.' || $file==='..') | 
						|
				continue; | 
						|
			if($this->namePattern!==null && !preg_match($this->namePattern,$file)) | 
						|
				continue; | 
						|
			if(is_file($path)) | 
						|
			{ | 
						|
				if($this->validateFile($path)) | 
						|
					$timestamps[$path]=filemtime($path); | 
						|
			} | 
						|
			else | 
						|
			{ | 
						|
				if(($this->recursiveLevel<0 || $level<$this->recursiveLevel) && $this->validateDirectory($path)) | 
						|
					$timestamps=array_merge($timestamps, $this->generateTimestamps($path,$level+1)); | 
						|
			} | 
						|
		} | 
						|
		closedir($dir); | 
						|
		return $timestamps; | 
						|
	} | 
						|
 | 
						|
	/** | 
						|
	 * Checks to see if the file should be checked for dependency. | 
						|
	 * This method is invoked when dependency of the whole directory is being checked. | 
						|
	 * By default, it always returns true, meaning the file should be checked. | 
						|
	 * You may override this method to check only certain files. | 
						|
	 * @param string $fileName the name of the file that may be checked for dependency. | 
						|
	 * @return boolean whether this file should be checked. | 
						|
	 */ | 
						|
	protected function validateFile($fileName) | 
						|
	{ | 
						|
		return true; | 
						|
	} | 
						|
 | 
						|
	/** | 
						|
	 * Checks to see if the specified subdirectory should be checked for dependency. | 
						|
	 * This method is invoked when dependency of the whole directory is being checked. | 
						|
	 * By default, it always returns true, meaning the subdirectory should be checked. | 
						|
	 * You may override this method to check only certain subdirectories. | 
						|
	 * @param string $directory the name of the subdirectory that may be checked for dependency. | 
						|
	 * @return boolean whether this subdirectory should be checked. | 
						|
	 */ | 
						|
	protected function validateDirectory($directory) | 
						|
	{ | 
						|
		return true; | 
						|
	} | 
						|
}
 | 
						|
 |