SimpleCxxLib
package#include "filelib.h"
Functions | |
Creates a new directory for the specified path. | |
Creates a new directory for the specified path. | |
Adds an extension to a file name if none already exists. | |
Deletes the specified file. | |
Expands a filename into a canonical name for the platform. | |
Returns true if the specified file exists. | |
Returns the canonical name of a file found using a search path. | |
Returns an absolute filename for the current directory. | |
Returns the standard directory path separator used on this platform. | |
Returns the extension of filename . | |
Returns all but the last component of a path name. | |
Returns the root of filename . | |
Returns the standard search path separator used on this platform. | |
Returns the last component of a path name. | |
Returns true if the specified file is a directory. | |
Returns true if the specified file is a regular file. | |
Returns true if the specified file is a symbolic link. | |
Adds an alphabetized list of the files in the specified directory to the string vector list . | |
Determines whether the filename matches the specified pattern. | |
Opens the filestream stream using the specified filename. | |
openFileDialog(stream, title) openFileDialog(stream, title, path) | Opens a dialog that allows the user to choose the file. |
Opens a file using a search path. | |
Asks the user for the name of a file. | |
Reads the entire contents of the specified input stream into the string vector lines . | |
Renames a file. | |
Changes the current directory to the specified path. |
bool openFile(ifstream & stream, string filename); bool openFile(ofstream & stream, string filename);
stream
using the specified
filename. This function is similar to the open
method of the stream classes, but uses a C++ string
object instead of the older C-style string. If the operation
succeeds, openFile
returns true
;
if it fails, openFile
sets the failure flag in the
stream and returns false
.
Usage:
if (openFile(stream, filename)) ...
string promptUserForFile(ifstream & stream, string prompt = ""); string promptUserForFile(ofstream & stream, string prompt = "");
stream
, and the function
returns the name of the file. If the requested file cannot be
opened, the user is given additional chances to enter a valid file.
The optional prompt
argument provides an input prompt
for the user.
Usage:
string filename = promptUserForFile(stream, prompt);
string openFileDialog(ifstream & stream); string openFileDialog(ifstream & stream, string title); string openFileDialog(ifstream & stream, string title, string path); string openFileDialog(ofstream & stream); string openFileDialog(ofstream & stream, string title); string openFileDialog(ofstream & stream, string title, string path);
title
parameter is displayed in the dialog title.
The path
parameter is used to set the working directory;
if path
does not appear, openFileDialog
uses the current directory.
Usage:
string filename = openFileDialog(stream); string filename = openFileDialog(stream, title); string filename = openFileDialog(stream, title, path);
void readEntireFile(istream & is, Vector<string> & lines); void readEntireFile(istream & is, vector<string> & lines);
lines
. The client is responsible for
opening and closing the stream. The vector can be either an STL
vector
or a Vector
as defined in the
Stanford C++ libraries.
Usage:
readEntireFile(is, lines);
string getRoot(string filename);
filename
. The root consists
of everything in filename
up to the last dot and
the subsequent extension. If no dot appears in the final component
of the filename, getRoot
returns the entire name.
Usage:
string root = getRoot(filename);
string getExtension(string filename);
filename
. The extension
consists of the separating dot and all subsequent characters.
If no dot exists in the final component, getExtension
returns the empty string. These semantics ensure that concatenating
the root and the extension always returns the original filename.
Usage:
ext = getExtension(filename);
string getHead(string filename);
getHead("a/b") = "a" getTail("a/b") = "b" getHead("a") = "" getTail("a") = "a" getHead("/a") = "/" getTail("/a") = "a" getHead("/") = "/" getTail("/") = ""
Usage:
head = getHead(filename);
string getTail(string filename);
getHead
function.
Usage:
tail = getTail(filename);
string defaultExtension(string filename, string ext);
extension
argument begins with a leading *
,
any existing extension in filename
is replaced by
ext
.
Usage:
string newname = defaultExtension(filename, ext);
string openOnPath(ifstream & stream, string path, string filename); string openOnPath(ofstream & stream, string path, string filename);
openOnPath
is successful, it returns the first path name on the search path
for which stream.open
succeeds. The path
argument consists of a list of directories that are prepended to the
filename, unless filename
begins with an absolute
directory marker, such as /
or ~
.
The directories in the search path may be separated either
by colons (Unix or Mac OS) or semicolons (Windows). If the file
cannot be opened, the failure bit is set in the stream
parameter, and the openOnPath
function returns the
empty string.
Usage:
string pathname = openOnPath(stream, path, filename);
string findOnPath(string path, string filename);
findOnPath
function is similar to
openOnPath
, except that it doesn't actually
return an open stream. If no matching file is found,
findOnPath
returns the empty string.
Usage:
string pathname = findOnPath(path, filename);
void deleteFile(string filename);
error
.
Usage:
deleteFile(filename);
void renameFile(string oldname, string newname);
error
in the implementation.
Usage:
renameFile(oldname, newname);
bool fileExists(string filename);
true
if the specified file exists.
Usage:
if (fileExists(filename)) ...
bool isFile(string filename);
true
if the specified file is a regular file.
Usage:
if (isFile(filename)) ...
bool isSymbolicLink(string filename);
true
if the specified file is a symbolic link.
Usage:
if (isSymbolicLink(filename)) ...
bool isDirectory(string filename);
true
if the specified file is a directory.
Usage:
if (isDirectory(filename)) ...
void setCurrentDirectory(string path);
Usage:
setCurrentDirectory(filename);
string getCurrentDirectory();
Usage:
string filename = getCurrentDirectory();
void createDirectory(string path);
createDirectory
function does not report an error if
the directory already exists. Unlike createDirectoryPath
,
createDirectory
does not create missing directories
along the path. If some component of path
does
not exist, this function signals an error.
Usage:
createDirectory(path);
void createDirectoryPath(string path);
path
do not exist, this function creates
them as needed.
Usage:
createDirectoryPath(path);
string expandPathname(string filename);
Usage:
string pathname = expandPathname(filename);
void listDirectory(string path, Vector<string> & list); void listDirectory(string path, vector<string> & list);
list
. This list excludes the
names .
and ..
entries.
Usage:
listDirectory(path, list);
bool matchFilenamePattern(string filename, string pattern);
? Matches any single character * Matches any sequence of characters [...] Matches any of the specified characters [^...] Matches any character except the specified onesThe last two options allow a range of characters to be specified in the form
a-z
.
Usage:
if (matchFilenamePattern(filename, pattern)) ...
string getDirectoryPathSeparator();
Usage:
string sep = getDirectoryPathSeparator();
string getSearchPathSeparator();
Usage:
string sep = getSearchPathSeparator();