//This file is part of Photon (http://photon.sourceforge.net) //Copyright (C) 2004-2005 James Turk // // Author: // James Turk (jpt2433@rit.edu) // // Version: // $Id: filesys.h,v 1.1 2005/02/06 21:30:10 cozman Exp $ // // Revisions: // $Log: filesys.h,v $ // Revision 1.1 2005/02/06 21:30:10 cozman // PhysFS initial integration // // #ifndef PHOTON_UTIL_FILESYS_FILESYS_H #define PHOTON_UTIL_FILESYS_FILESYS_H #include "exceptions.h" #include "physfs.h" #include #include // Title: File System namespace photon { namespace util { namespace filesys { // Function: getDirSeparator // Gets the system standard directory separator. // (/ on unix, \\ on windows, : on MacOS) // // Returns: // System directory separator. std::string getDirSeparator(); // Function: permitSymbolicLinks // Enables or disables symbolic linking. (which is off by default) // // Parameters: // allow - true if you wish to enable linking, false if you wish to disable it void permitSymbolicLinks(bool allow); // Group: System Directories /////////////////////////////////////////////////// // Function: getCDDirs // Gets a listing of the CD directories on a system (not supported on all // systems) // // Returns: // A vector of strings containing the path to the CD directories. std::vector getCDDirs(); // Function: getBaseDir // Get the path to the directory that the application is running in. // // Returns: // Path to directory that application is running from. std::string getBaseDir(); // Function: getUserDir // Get the path to the directory that the OS specifies for the user's home. // // Returns: // Path to user's home directory. std::string getUserDir(); // Group: Search Path ////////////////////////////////////////////////////////// // Function: addToSearchPath // Attempts to add a directory to the search path. // // Parameters: // dir - Directory to add to the search path // append - if true, directory will be added to end of path // if false, directory will be added to front of path // // See Also: // // void addToSearchPath(std::string dir, bool append); // Function: removeFromSearchPath // Removes a directory from the search path, if it exists on the path. // // Parameters: // dir - Directory to remove from the search path, if it doesn't exist // nothing happens. // // See Also: // // void removeFromSearchPath(std::string dir); // Function: getSearchPath // Obtain the currently configured search path. // // Returns: // List of strings in search path. // // See Also: // // std::vector getSearchPath(); // Group: Manipulation ///////////////////////////////////////////////////////// // Function: mkdir // Attempts to create a directory. // // Parameters: // dir - name of directory to create // // Returns: // true iff directory was created, false if not bool mkdir(std::string dir); // Function: remove // Attempts to remove a file or directory. // // Parameters: // remove - name of file or directory to remove // // Returns: // true iff file/directory was removed, false if not bool remove(std::string item); // Group: Searching //////////////////////////////////////////////////////////// // Function: listDir // Lists the contents of a directory. // // Parameters: // dir - name of directory to get contents of // // Returns: // list of strings representing items found in 'dir' std::vector listDir(std::string dir); // Function: exists // Checks if a file/directory exists. // // Parameters: // item - file/directory to check existance of // // Returns: // true iff file/directory exists, false if not bool exists(std::string item); // Function: isDirectory // Checks if a name refers to a directory. // // Parameters: // item - name to check // // Returns: // true iff item is a directory, false if not bool isDirectory(std::string item); // Function: isSymbolicLink // Checks if a name refers to a symbolic link. // // Parameters: // item - name to check // // Returns: // true iff item is a symbolic link, false if not bool isSymbolicLink(std::string item); // Function: getModTime // Gets last modification time for a file. // // Parameters: // item - name of item to get last modification time of // // Returns: // Last modification time of a file in seconds since the epoch. PHYSFS_sint64 getModTime(std::string item); } } } #endif //PHOTON_UTIL_FILESYS_FILESYS_H