BALL::Path Class Reference
[Operating system support]

#include <BALL/SYSTEM/path.h>

List of all members.

Public Member Functions

String getDataPath ()
void setDataPath (const String &path)
void addDataPath (const String &path)
String getDefaultDataPath ()
String find (const String &name)
String findStrict (const String &name)
void reset ()
 Reset the path variable to its default state (as it was a the start of the application).
Constructors and Destructors

 Path ()

Protected Member Functions

void buildPathArray_ ()

Static Protected Attributes

static String path_
static bool path_array_valid_
static bool environment_checked_
static std::vector< Stringpath_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.

Definition at line 39 of file path.h.


Constructor & Destructor Documentation

BALL::Path::Path (  ) 

Default constructor


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
void BALL::Path::buildPathArray_ (  )  [protected]
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::reset (  ) 

Reset the path variable to its default state (as it was a the start of the application).

void BALL::Path::setDataPath ( const String path  ) 

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


Member Data Documentation

Definition at line 116 of file path.h.

bool BALL::Path::initialized_ [static, protected]

Definition at line 118 of file path.h.

String BALL::Path::path_ [static, protected]

Definition at line 114 of file path.h.

std::vector<String> BALL::Path::path_array_ [static, protected]

Definition at line 117 of file path.h.

bool BALL::Path::path_array_valid_ [static, protected]

Definition at line 115 of file path.h.

Generated by  doxygen 1.6.3