/usr/include/BALL/SYSTEM/directory.h is in libball1.4-dev 1.4.3~beta1-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 | // -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//
// $Id: directory.h,v 1.29.16.1 2007/03/25 21:25:38 oliver Exp $
//
#ifndef BALL_SYSTEM_DIRECTORY_H
#define BALL_SYSTEM_DIRECTORY_H
#ifndef BALL_COMMON_H
# include <BALL/common.h>
#endif
#ifndef BALL_CONCEPT_PROCESSOR_H
# include <BALL/CONCEPT/processor.h>
#endif
#ifndef BALL_DATATYPE_STRING_H
# include <BALL/DATATYPE/string.h>
#endif
#ifndef BALL_SYSTEM_FILESYSTEM_H
# include <BALL/SYSTEM/fileSystem.h>
#endif
#ifdef BALL_HAS_DIRENT_H
# include <dirent.h>
#endif
#ifdef BALL_HAS_UNISTD_H
# include <unistd.h>
#endif
#ifdef BALL_HAS_SYS_STAT_H
# include <sys/stat.h>
#endif
#ifdef BALL_HAS_DIRECT_H
# include <direct.h>
#endif
#include <cstdio>
#ifdef BALL_COMPILER_MSVC
#define WINDOWS_LEAN_AND_MEAN
#include <windows.h>
#define mode_t int
#endif
namespace BALL
{
/** Directory class.
\ingroup System
*/
class BALL_EXPORT Directory
{
#ifndef BALL_OS_WINDOWS
# define INVALID_HANDLE_VALUE 0
#endif
public:
/** @name Constants
*/
//@{
/** The maximum length of a path.
This constant is used for system calls that require
a maximum length (e.g., getcwd()). Default is 8192.
*/
static const Size MAX_PATH_LENGTH;
//@}
/** @name Constructors and Destructors
*/
//@{
/** Default constructor.
Constructs new Directory object.
The directory path is set to the current working directory.
The directory path does not have a path seperator {\em "/"} at its end.
@return Directory - new constructed Directory object
*/
Directory();
/** Detailed constructor.
Construct new Directory object from {\em directory_path}.
The directory path does not have a path seperator {\em "/"} at its end.
If the given directory does not exists, the directory path is set to an empty string.
@param directory_path the name of the directory to be opend
@param set_current true, to set the directory as the current, default = false
@return Directory - new constructed Directory object
*/
Directory(const String& directory_path, bool set_current = false);
/** Copy constructor.
Construct new Directory object by copying <b> directory </b>.
@param directory the Directory object to be copied (cloned)
@return Directory - new constructed Directory cloned from <b> directory </b>
*/
Directory(const Directory& directory);
/** Destructor.
*/
~Directory();
/** Explicit default initialization.
Set the state to the default values.
The path is set to an empty string.
*/
void clear();
/** Explicit destructor.
*/
void destroy();
//@}
/** @name Assignment
*/
//@{
/** Assign the Directory with the path <tt>directory_path</tt>.
The given directory path can be either absolute or relative.
If the path starts with a path seperator it is set as a absolute path.
@param directory_path the name of the directory to be cloned
@param set_current true to set the directory as the current, default = false
@return bool true if the path could be set and is valid
*/
bool set(const String& directory_path, bool set_current = false);
/** Assignment with cloning facility.
Assign the Directory <tt> directory</tt> to <tt> *this</tt>.
@param directory the directory to be cloned
*/
void set(const Directory& directory);
/** Assignment operator.
Assign <b> directory </b> to this instance.
*/
Directory& operator = (const Directory& directory);
/** Copying with cloning facility.
Copy this instance to <b> directory </b>.
@param directory the directory to be assigned to
*/
void get(Directory& directory) const;
//@}
/** @name Accessors
*/
//@{
/** Get the path of this instance.
The directory path does not have a path seperator {\em "/"} at its end
and is absolute. If a unvalid path was set the path is an empty string.
@return String the name of the directory
*/
const String& getPath() const;
/** Rename a given directory.
With this method the directory associated with this object can not
be renamed. Use renameTo instead to do so.
@param old_path the old path
@param new_path the new path
@return bool true if the directory could be renamed
*/
bool rename(String old_path, String new_path);
/** Rename the directory associated with this object.
@param new_path the new path
@return bool true if the directory could be renamed
*/
bool renameTo(String new_path);
/** Set a directory as the current.
@param directory_path the name of the directory
@return bool true if the directory could be set as the current
*/
bool setCurrent(String directory_path);
/** Set this directory as the current working directory.
@return bool true if the directory could be set as the current
*/
bool setCurrent();
/** Create a new directory.
The directory is created using an absolute path, if it starts
with a path seperator, else it is created in this directory.
@param path the path of the new directory
@param mode the access mode of the directory
@return bool true if the directory could be created
*/
bool create(String path, const mode_t& mode = 0777);
/** Remove a directory.
With this method the directory associated with this object can not
be removed. Use remove() instead to do so.
@param old_path the path of the directory
@return bool true if the directory could be removed
*/
bool remove(String old_path);
/** Remove this directory.
The directory this object points to is deleted and the object is cleared.
@return bool true if the directory could be removed
*/
bool remove();
/** Get the name of the first entry in the directory.
@param entry reference to the name of the first entry
@return bool true if an entry was found
*/
bool getFirstEntry(String& entry);
/** Get the name of the next entry in the directory.
@param entry reference to the name of the next entry
@return bool true if an entry was found
*/
bool getNextEntry(String& entry);
/** Count all items in the directory.
@return Size the number of items (files, links, directories)
*/
Size countItems();
/** Count the files in the directory.
@return Size the number of files
*/
Size countFiles();
/** Count the subdirectories in the directory.
@return Size the number of subdirectories
*/
Size countDirectories();
/** Find a file in the directory.
The search is recursive.
@param filename the name of the file to be searched
@param filepath the path of the file, if it was found
@return bool true if the file was found
*/
bool find(const String& filename, String& filepath);
//@}
/** @name Predicates
*/
//@{
/** Test if the directory has an item.
@param item the name of the item to look for
@return bool true if the directory has the item
*/
bool has(const String& item);
/** Test if the directory is valid.
The directory is valid if it exists.
This function uses ::opendir(const char *dirname).
@return bool true if the directory is valid
*/
bool isValid() const;
/** Test if the directory is the current working directory.
@return bool
*/
bool isCurrent() const;
/** Test if the directory is empty.
@return bool
*/
bool isEmpty();
/** Equality operator.
@return bool, <b>true</b> if the name of both directories are equal
*/
bool operator == (const Directory& directory) const;
/** Inequality operator.
@return bool, <b>true</b> if the name of both directories are inequal
*/
bool operator != (const Directory& directory) const;
/// Get the home directory of the current user
static String getUserHomeDir();
/// Goto the home directory of the current user
static bool changeToUserHomeDir();
//@}
private:
//_wrapper function around getcwd to handle different naming conventions in different OS
String getcwd_();
//_wrapper function around chdir to handle different naming conventions in different OS
int chdir_(const String& new_dir);
//_switch to this dir
void synchronize_();
//_switch back to the working directory
bool desynchronize_(bool result = true);
#ifdef BALL_COMPILER_MSVC
HANDLE dirent_;
HANDLE dir_;
#else
DIR* dir_;
dirent* dirent_;
#endif
String directory_path_;
String backup_path_;
};
# ifndef BALL_NO_INLINE_FUNCTIONS
# include <BALL/SYSTEM/directory.iC>
# endif
} // namespace BALL
#endif // BALL_SYSTEM_DIRECTORY_H
|