199 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			199 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| 
								 | 
							
								<?php
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * 
							 | 
						||
| 
								 | 
							
								 * Utility class for static directory methods.
							 | 
						||
| 
								 | 
							
								 * 
							 | 
						||
| 
								 | 
							
								 * @category Solar
							 | 
						||
| 
								 | 
							
								 * 
							 | 
						||
| 
								 | 
							
								 * @package Solar
							 | 
						||
| 
								 | 
							
								 * 
							 | 
						||
| 
								 | 
							
								 * @author Paul M. Jones <pmjones@solarphp.com>
							 | 
						||
| 
								 | 
							
								 * 
							 | 
						||
| 
								 | 
							
								 * @license http://opensource.org/licenses/bsd-license.php BSD
							 | 
						||
| 
								 | 
							
								 * 
							 | 
						||
| 
								 | 
							
								 * @version $Id: Dir.php 2926 2007-11-09 16:25:44Z pmjones $
							 | 
						||
| 
								 | 
							
								 * 
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								class Solar_Dir {
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * The OS-specific temporary directory location.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @var string
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected static $_tmp;
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * Hack for [[php::is_dir() | ]] that checks the include_path.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * Use this to see if a directory exists anywhere in the include_path.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * {{code: php
							 | 
						||
| 
								 | 
							
								     *     $dir = Solar_Dir::exists('path/to/dir')
							 | 
						||
| 
								 | 
							
								     *     if ($dir) {
							 | 
						||
| 
								 | 
							
								     *         $files = scandir($dir);
							 | 
						||
| 
								 | 
							
								     *     } else {
							 | 
						||
| 
								 | 
							
								     *         echo "Not found in the include-path.";
							 | 
						||
| 
								 | 
							
								     *     }
							 | 
						||
| 
								 | 
							
								     * }}
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @param string $dir Check for this directory in the include_path.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @return mixed If the directory exists in the include_path, returns the
							 | 
						||
| 
								 | 
							
								     * absolute path; if not, returns boolean false.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public static function exists($dir)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        // no file requested?
							 | 
						||
| 
								 | 
							
								        $dir = trim($dir);
							 | 
						||
| 
								 | 
							
								        if (! $dir) {
							 | 
						||
| 
								 | 
							
								            return false;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        
							 | 
						||
| 
								 | 
							
								        // using an absolute path for the file?
							 | 
						||
| 
								 | 
							
								        // dual check for Unix '/' and Windows '\',
							 | 
						||
| 
								 | 
							
								        // or Windows drive letter and a ':'.
							 | 
						||
| 
								 | 
							
								        $abs = ($dir[0] == '/' || $dir[0] == '\\' || $dir[1] == ':');
							 | 
						||
| 
								 | 
							
								        if ($abs && is_dir($dir)) {
							 | 
						||
| 
								 | 
							
								            return $dir;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        
							 | 
						||
| 
								 | 
							
								        // using a relative path on the file
							 | 
						||
| 
								 | 
							
								        $path = explode(PATH_SEPARATOR, ini_get('include_path'));
							 | 
						||
| 
								 | 
							
								        foreach ($path as $base) {
							 | 
						||
| 
								 | 
							
								            // strip Unix '/' and Windows '\'
							 | 
						||
| 
								 | 
							
								            $target = rtrim($base, '\\/') . DIRECTORY_SEPARATOR . $dir;
							 | 
						||
| 
								 | 
							
								            if (is_dir($target)) {
							 | 
						||
| 
								 | 
							
								                return $target;
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        
							 | 
						||
| 
								 | 
							
								        // never found it
							 | 
						||
| 
								 | 
							
								        return false;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * "Fixes" a directory string for the operating system.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * Use slashes anywhere you need a directory separator. Then run the
							 | 
						||
| 
								 | 
							
								     * string through fixdir() and the slashes will be converted to the
							 | 
						||
| 
								 | 
							
								     * proper separator (for example '\' on Windows).
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * Always adds a final trailing separator.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @param string $dir The directory string to 'fix'.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @return string The "fixed" directory string.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public static function fix($dir)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $dir = str_replace('/', DIRECTORY_SEPARATOR, $dir);
							 | 
						||
| 
								 | 
							
								        return rtrim($dir, DIRECTORY_SEPARATOR) . DIRECTORY_SEPARATOR;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * Convenience method for dirname() and higher-level directories.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @param string $file Get the dirname() of this file.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @param int $up Move up in the directory structure this many 
							 | 
						||
| 
								 | 
							
								     * times, default 0.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @return string The dirname() of the file.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public static function name($file, $up = 0)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $dir = dirname($file);
							 | 
						||
| 
								 | 
							
								        while ($up --) {
							 | 
						||
| 
								 | 
							
								            $dir = dirname($dir);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        return $dir;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * Returns the OS-specific directory for temporary files.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @param string $sub Add this subdirectory to the returned temporary
							 | 
						||
| 
								 | 
							
								     * directory name.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @return string The temporary directory path.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public static function tmp($sub = '')
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        // find the tmp dir if needed
							 | 
						||
| 
								 | 
							
								        if (! Solar_Dir::$_tmp) {
							 | 
						||
| 
								 | 
							
								            
							 | 
						||
| 
								 | 
							
								            // use the system if we can
							 | 
						||
| 
								 | 
							
								            if (function_exists('sys_get_temp_dir')) {
							 | 
						||
| 
								 | 
							
								                $tmp = sys_get_temp_dir();
							 | 
						||
| 
								 | 
							
								            } else {
							 | 
						||
| 
								 | 
							
								                $tmp = Solar_Dir::_tmp();
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								            
							 | 
						||
| 
								 | 
							
								            // remove trailing separator and save
							 | 
						||
| 
								 | 
							
								            Solar_Dir::$_tmp = rtrim($tmp, DIRECTORY_SEPARATOR);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        
							 | 
						||
| 
								 | 
							
								        // do we have a subdirectory request?
							 | 
						||
| 
								 | 
							
								        $sub = trim($sub);
							 | 
						||
| 
								 | 
							
								        if ($sub) {
							 | 
						||
| 
								 | 
							
								            // remove leading and trailing separators, and force exactly
							 | 
						||
| 
								 | 
							
								            // one trailing separator
							 | 
						||
| 
								 | 
							
								            $sub = trim($sub, DIRECTORY_SEPARATOR)
							 | 
						||
| 
								 | 
							
								                 . DIRECTORY_SEPARATOR;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        
							 | 
						||
| 
								 | 
							
								        return Solar_Dir::$_tmp . DIRECTORY_SEPARATOR . $sub;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * Returns the OS-specific temporary directory location.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     * @return string The temp directory path.
							 | 
						||
| 
								 | 
							
								     * 
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected static function _tmp()
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        // non-Windows system?
							 | 
						||
| 
								 | 
							
								        if (strtolower(substr(PHP_OS, 0, 3)) != 'win') {
							 | 
						||
| 
								 | 
							
								            $tmp = empty($_ENV['TMPDIR']) ? getenv('TMPDIR') : $_ENV['TMPDIR'];
							 | 
						||
| 
								 | 
							
								            if ($tmp) {
							 | 
						||
| 
								 | 
							
								                return $tmp;
							 | 
						||
| 
								 | 
							
								            } else {
							 | 
						||
| 
								 | 
							
								                return '/tmp';
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        
							 | 
						||
| 
								 | 
							
								        // Windows 'TEMP'
							 | 
						||
| 
								 | 
							
								        $tmp = empty($_ENV['TEMP']) ? getenv('TEMP') : $_ENV['TEMP'];
							 | 
						||
| 
								 | 
							
								        if ($tmp) {
							 | 
						||
| 
								 | 
							
								            return $tmp;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								        // Windows 'TMP'
							 | 
						||
| 
								 | 
							
								        $tmp = empty($_ENV['TMP']) ? getenv('TMP') : $_ENV['TMP'];
							 | 
						||
| 
								 | 
							
								        if ($tmp) {
							 | 
						||
| 
								 | 
							
								            return $tmp;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								        // Windows 'windir'
							 | 
						||
| 
								 | 
							
								        $tmp = empty($_ENV['windir']) ? getenv('windir') : $_ENV['windir'];
							 | 
						||
| 
								 | 
							
								        if ($tmp) {
							 | 
						||
| 
								 | 
							
								            return $tmp;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								        // final fallback for Windows
							 | 
						||
| 
								 | 
							
								        return getenv('SystemRoot') . '\\temp';
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 |