tvl-depot/src/libutil/util.hh

173 lines
3.3 KiB
C++
Raw Normal View History

#ifndef __UTIL_H
#define __UTIL_H
#include <string>
#include <list>
#include <set>
#include <sstream>
#include <sys/types.h>
#include <dirent.h>
#include <unistd.h>
#include <boost/format.hpp>
using namespace std;
using namespace boost;
class Error : public exception
{
protected:
string err;
public:
Error(const format & f);
~Error() throw () { };
const char * what() const throw () { return err.c_str(); }
const string & msg() const throw () { return err; }
};
class SysError : public Error
{
public:
SysError(const format & f);
};
class UsageError : public Error
{
public:
UsageError(const format & f) : Error(f) { };
};
typedef list<string> Strings;
typedef set<string> StringSet;
2003-10-07 16:37:41 +02:00
/* Paths are just strings. */
typedef string Path;
typedef list<Path> Paths;
typedef set<Path> PathSet;
/* The canonical system name, as returned by config.guess. */
2003-05-26 15:45:00 +02:00
extern string thisSystem;
/* Return an absolutized path, resolving paths relative to the
specified directory, or the current directory otherwise. The path
is also canonicalised. */
2003-10-07 16:37:41 +02:00
Path absPath(Path path, Path dir = "");
/* Canonicalise a path (as in realpath(3)). */
2003-10-07 16:37:41 +02:00
Path canonPath(const Path & path);
/* Return the directory part of the given path, i.e., everything
before the final `/'. */
2003-10-07 16:37:41 +02:00
Path dirOf(const Path & path);
/* Return the base name of the given path, i.e., everything following
the final `/'. */
2003-10-07 16:37:41 +02:00
string baseNameOf(const Path & path);
/* Return true iff the given path exists. */
2003-10-07 16:37:41 +02:00
bool pathExists(const Path & path);
/* Read the contents of a directory. The entries `.' and `..' are
removed. */
Strings readDirectory(const Path & path);
2003-06-23 16:40:49 +02:00
/* Delete a path; i.e., in the case of a directory, it is deleted
recursively. Don't use this at home, kids. */
2003-10-07 16:37:41 +02:00
void deletePath(const Path & path);
/* Make a path read-only recursively. */
2003-10-07 16:37:41 +02:00
void makePathReadOnly(const Path & path);
2003-06-23 16:40:49 +02:00
/* Create a temporary directory. */
2003-10-07 16:37:41 +02:00
Path createTempDir();
2003-06-23 16:40:49 +02:00
2003-07-04 14:18:06 +02:00
/* Messages. */
typedef enum {
lvlError,
lvlTalkative,
lvlChatty,
lvlDebug,
lvlVomit
} Verbosity;
extern Verbosity verbosity; /* supress msgs > this */
2003-07-04 14:18:06 +02:00
class Nest
{
private:
bool nest;
public:
Nest();
2003-07-04 14:18:06 +02:00
~Nest();
void open(Verbosity level, const format & f);
2003-07-04 14:18:06 +02:00
};
void printMsg_(Verbosity level, const format & f);
#define startNest(varName, level, f) \
Nest varName; \
if (level <= verbosity) { \
varName.open(level, (f)); \
}
#define printMsg(level, f) \
do { \
if (level <= verbosity) { \
printMsg_(level, (f)); \
} \
} while (0)
#define debug(f) printMsg(lvlDebug, f)
/* Wrappers arount read()/write() that read/write exactly the
requested number of bytes. */
void readFull(int fd, unsigned char * buf, size_t count);
void writeFull(int fd, const unsigned char * buf, size_t count);
/* Automatic cleanup of resources. */
class AutoDelete
{
string path;
bool del;
public:
AutoDelete(const string & p);
~AutoDelete();
void cancel();
};
class AutoCloseFD
{
int fd;
public:
AutoCloseFD();
AutoCloseFD(int fd);
~AutoCloseFD();
void operator =(int fd);
operator int();
};
class AutoCloseDir
{
DIR * dir;
public:
AutoCloseDir();
AutoCloseDir(DIR * dir);
~AutoCloseDir();
void operator =(DIR * dir);
operator DIR *();
};
#endif /* !__UTIL_H */