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