Update HTMLPurifier to v4.7.0
This commit is contained in:
		
					parent
					
						
							
								3c97a6703c
							
						
					
				
			
			
				commit
				
					
						c28109ca94
					
				
			
		
					 465 changed files with 22433 additions and 10865 deletions
				
			
		
							
								
								
									
										141
									
								
								library/ezyang/htmlpurifier/extras/FSTools/File.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								library/ezyang/htmlpurifier/extras/FSTools/File.php
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,141 @@
 | 
			
		|||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Represents a file in the filesystem
 | 
			
		||||
 *
 | 
			
		||||
 * @warning Be sure to distinguish between get() and write() versus
 | 
			
		||||
 *      read() and put(), the former operates on the entire file, while
 | 
			
		||||
 *      the latter operates on a handle.
 | 
			
		||||
 */
 | 
			
		||||
class FSTools_File
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
    /** Filename of file this object represents */
 | 
			
		||||
    protected $name;
 | 
			
		||||
 | 
			
		||||
    /** Handle for the file */
 | 
			
		||||
    protected $handle = false;
 | 
			
		||||
 | 
			
		||||
    /** Instance of FSTools for interfacing with filesystem */
 | 
			
		||||
    protected $fs;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Filename of file you wish to instantiate.
 | 
			
		||||
     * @note This file need not exist
 | 
			
		||||
     */
 | 
			
		||||
    public function __construct($name, $fs = false)
 | 
			
		||||
    {
 | 
			
		||||
        $this->name = $name;
 | 
			
		||||
        $this->fs = $fs ? $fs : FSTools::singleton();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Returns the filename of the file. */
 | 
			
		||||
    public function getName() {return $this->name;}
 | 
			
		||||
 | 
			
		||||
    /** Returns directory of the file without trailing slash */
 | 
			
		||||
    public function getDirectory() {return $this->fs->dirname($this->name);}
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Retrieves the contents of a file
 | 
			
		||||
     * @todo Throw an exception if file doesn't exist
 | 
			
		||||
     */
 | 
			
		||||
    public function get()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->fs->file_get_contents($this->name);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Writes contents to a file, creates new file if necessary */
 | 
			
		||||
    public function write($contents)
 | 
			
		||||
    {
 | 
			
		||||
        return $this->fs->file_put_contents($this->name, $contents);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Deletes the file */
 | 
			
		||||
    public function delete()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->fs->unlink($this->name);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Returns true if file exists and is a file. */
 | 
			
		||||
    public function exists()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->fs->is_file($this->name);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Returns last file modification time */
 | 
			
		||||
    public function getMTime()
 | 
			
		||||
    {
 | 
			
		||||
        return $this->fs->filemtime($this->name);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Chmod a file
 | 
			
		||||
     * @note We ignore errors because of some weird owner trickery due
 | 
			
		||||
     *       to SVN duality
 | 
			
		||||
     */
 | 
			
		||||
    public function chmod($octal_code)
 | 
			
		||||
    {
 | 
			
		||||
        return @$this->fs->chmod($this->name, $octal_code);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Opens file's handle */
 | 
			
		||||
    public function open($mode)
 | 
			
		||||
    {
 | 
			
		||||
        if ($this->handle) $this->close();
 | 
			
		||||
        $this->handle = $this->fs->fopen($this->name, $mode);
 | 
			
		||||
        return true;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Closes file's handle */
 | 
			
		||||
    public function close()
 | 
			
		||||
    {
 | 
			
		||||
        if (!$this->handle) return false;
 | 
			
		||||
        $status = $this->fs->fclose($this->handle);
 | 
			
		||||
        $this->handle = false;
 | 
			
		||||
        return $status;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Retrieves a line from an open file, with optional max length $length */
 | 
			
		||||
    public function getLine($length = null)
 | 
			
		||||
    {
 | 
			
		||||
        if (!$this->handle) $this->open('r');
 | 
			
		||||
        if ($length === null) return $this->fs->fgets($this->handle);
 | 
			
		||||
        else return $this->fs->fgets($this->handle, $length);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Retrieves a character from an open file */
 | 
			
		||||
    public function getChar()
 | 
			
		||||
    {
 | 
			
		||||
        if (!$this->handle) $this->open('r');
 | 
			
		||||
        return $this->fs->fgetc($this->handle);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Retrieves an $length bytes of data from an open data */
 | 
			
		||||
    public function read($length)
 | 
			
		||||
    {
 | 
			
		||||
        if (!$this->handle) $this->open('r');
 | 
			
		||||
        return $this->fs->fread($this->handle, $length);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Writes to an open file */
 | 
			
		||||
    public function put($string)
 | 
			
		||||
    {
 | 
			
		||||
        if (!$this->handle) $this->open('a');
 | 
			
		||||
        return $this->fs->fwrite($this->handle, $string);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /** Returns TRUE if the end of the file has been reached */
 | 
			
		||||
    public function eof()
 | 
			
		||||
    {
 | 
			
		||||
        if (!$this->handle) return true;
 | 
			
		||||
        return $this->fs->feof($this->handle);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function __destruct()
 | 
			
		||||
    {
 | 
			
		||||
        if ($this->handle) $this->close();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// vim: et sw=4 sts=4
 | 
			
		||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue