| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 | <?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
 |