BALL::Path Class Reference
[Operating system support]

Data path management class. More...

#include <path.h>

List of all members.


Public Member Functions

string getDataPath ()
Return a list of paths to the BALL data directories.
void setDataPath (const string &path)
Modify the data path.
void addDataPath (const string &path)
Add a single path to the list of paths.
string getDefaultDataPath ()
Returns the default data path compiled into the library.
string find (const string &name)
Returns the full path to a file residing in one of the data directories.
string findStrict (const string &name)
Returns the full path to a file residing in one of the data directories.
void reset ()
Reset the path variable to its default state (as it was a the start of the application).
Constructors and Destructors
Path ()
Default constructor.

Protected Member Functions

void buildPathArray_ ()

Static Protected Attributes

static string path_
static bool path_array_valid_
static bool environment_checked_
static std::vector< std::string > path_array_
static bool initialized_

Detailed Description

Data path management class.

This class is intended to provide a unique interface to directories where the data files needed by BALL reside.

Path is a singleton, so there is only one unique application-wide instance of and changes to this will be seen by all classes using path.

Member Function Documentation

void BALL::Path::addDataPath ( const string & path )

Add a single path to the list of paths.

Parameters:
path the path to be added to the path list

string BALL::Path::find ( const string & name )

Returns the full path to a file residing in one of the data directories.

If a file that matches the name is not found, an empty string is returned. Directories are searched in the order of occurence in the data path. If name contains relative path information but no file matching this path could be found, another search is performed as a second step taking in account only the basename of the file.

E.g.:
Specifying data/test.dat will search for data/test.dat in each data directory first. If this search doesn't yield a match, find will search for a file named test.dat in each of the directories.
If this behaviour is not desired, try findStrict instead.

string BALL::Path::findStrict ( const string & name )

Returns the full path to a file residing in one of the data directories.

See also:
find

string BALL::Path::getDataPath ( )

Return a list of paths to the BALL data directories.

This directory is set to a default value at compile time of the library. It may be overridden at runtime by setting the environment variable "BALL_DATA" to the desired value. This value is then prepended to the list of directories. Directories are separated by linefeeds and returned as a single string. To locate files in these directories, find will search the directories in the specified order.

The default path may be accessed using getDefaultDataPath . The path may also be modified at runtime by calling setDataPath .
The path contains a newline ("\n") separated list of paths that are searched in the order of occurence.

string BALL::Path::getDefaultDataPath ( )

Returns the default data path compiled into the library.

This method ignores possible contents of the environment variable "BALL\_DATA".

void BALL::Path::setDataPath ( const string & path )

Modify the data path.

This method accepts a newline separated list of paths to specify data paths.


Generated on Thu Aug 6 18:30:49 2009 for BALL by doxygen 1.5.8