2003-04-04 19:14:56 +03:00
|
|
|
#ifndef __UTIL_H
|
|
|
|
#define __UTIL_H
|
|
|
|
|
2003-04-08 15:00:51 +03:00
|
|
|
#include <string>
|
2003-06-20 17:11:31 +03:00
|
|
|
#include <list>
|
2003-07-17 15:27:55 +03:00
|
|
|
#include <set>
|
2003-04-08 15:00:51 +03:00
|
|
|
#include <sstream>
|
|
|
|
|
|
|
|
#include <unistd.h>
|
|
|
|
|
2003-06-27 16:55:12 +03:00
|
|
|
#include <boost/format.hpp>
|
|
|
|
|
2003-04-04 19:14:56 +03:00
|
|
|
using namespace std;
|
2003-06-27 16:55:12 +03:00
|
|
|
using namespace boost;
|
2003-04-04 19:14:56 +03:00
|
|
|
|
|
|
|
|
|
|
|
class Error : public exception
|
|
|
|
{
|
2003-06-16 16:33:38 +03:00
|
|
|
protected:
|
2003-04-04 19:14:56 +03:00
|
|
|
string err;
|
|
|
|
public:
|
2003-06-27 17:56:12 +03:00
|
|
|
Error(const format & f);
|
|
|
|
~Error() throw () { };
|
2003-04-04 19:14:56 +03:00
|
|
|
const char * what() const throw () { return err.c_str(); }
|
2003-07-07 12:25:26 +03:00
|
|
|
const string & msg() const throw () { return err; }
|
2003-04-04 19:14:56 +03:00
|
|
|
};
|
|
|
|
|
2003-06-16 16:33:38 +03:00
|
|
|
class SysError : public Error
|
|
|
|
{
|
|
|
|
public:
|
2003-06-27 17:56:12 +03:00
|
|
|
SysError(const format & f);
|
2003-06-16 16:33:38 +03:00
|
|
|
};
|
|
|
|
|
2003-04-04 19:14:56 +03:00
|
|
|
class UsageError : public Error
|
|
|
|
{
|
|
|
|
public:
|
2003-06-27 17:56:12 +03:00
|
|
|
UsageError(const format & f) : Error(f) { };
|
2003-04-04 19:14:56 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2003-06-20 17:11:31 +03:00
|
|
|
typedef list<string> Strings;
|
2003-07-17 15:27:55 +03:00
|
|
|
typedef set<string> StringSet;
|
2003-04-04 19:14:56 +03:00
|
|
|
|
|
|
|
|
2003-04-08 15:00:51 +03:00
|
|
|
/* The canonical system name, as returned by config.guess. */
|
2003-05-26 16:45:00 +03:00
|
|
|
extern string thisSystem;
|
2003-04-08 15:00:51 +03:00
|
|
|
|
|
|
|
|
2003-06-16 16:33:38 +03:00
|
|
|
/* Return an absolutized path, resolving paths relative to the
|
2003-07-07 12:25:26 +03:00
|
|
|
specified directory, or the current directory otherwise. The path
|
|
|
|
is also canonicalised. */
|
2003-06-16 16:33:38 +03:00
|
|
|
string absPath(string path, string dir = "");
|
|
|
|
|
2003-07-07 12:25:26 +03:00
|
|
|
/* Canonicalise a path (as in realpath(3)). */
|
|
|
|
string canonPath(const string & path);
|
|
|
|
|
2003-06-16 16:33:38 +03:00
|
|
|
/* Return the directory part of the given path, i.e., everything
|
|
|
|
before the final `/'. */
|
|
|
|
string dirOf(string path);
|
|
|
|
|
|
|
|
/* Return the base name of the given path, i.e., everything following
|
|
|
|
the final `/'. */
|
|
|
|
string baseNameOf(string path);
|
2003-04-08 15:00:51 +03:00
|
|
|
|
2003-07-08 16:22:08 +03:00
|
|
|
/* Return true iff the given path exists. */
|
|
|
|
bool pathExists(const string & path);
|
2003-04-08 15:00:51 +03:00
|
|
|
|
2003-06-23 17:40:49 +03:00
|
|
|
/* Delete a path; i.e., in the case of a directory, it is deleted
|
|
|
|
recursively. Don't use this at home, kids. */
|
2003-08-22 23:12:44 +03:00
|
|
|
void deletePath(const string & path);
|
|
|
|
|
|
|
|
/* Make a path read-only recursively. */
|
|
|
|
void makePathReadOnly(const string & path);
|
2003-06-23 17:40:49 +03:00
|
|
|
|
2003-10-02 14:55:38 +03:00
|
|
|
/* Create a temporary directory. */
|
|
|
|
string createTempDir();
|
|
|
|
|
2003-06-23 17:40:49 +03:00
|
|
|
|
2003-07-04 15:18:06 +03:00
|
|
|
/* Messages. */
|
|
|
|
|
2003-07-24 11:53:43 +03:00
|
|
|
typedef enum {
|
2003-07-24 16:43:16 +03:00
|
|
|
lvlError,
|
|
|
|
lvlTalkative,
|
|
|
|
lvlChatty,
|
|
|
|
lvlDebug,
|
|
|
|
lvlVomit
|
2003-07-24 11:53:43 +03:00
|
|
|
} Verbosity;
|
|
|
|
|
|
|
|
extern Verbosity verbosity; /* supress msgs > this */
|
|
|
|
|
2003-07-04 15:18:06 +03:00
|
|
|
class Nest
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
bool nest;
|
|
|
|
public:
|
2003-07-24 11:53:43 +03:00
|
|
|
Nest(Verbosity level, const format & f);
|
2003-07-04 15:18:06 +03:00
|
|
|
~Nest();
|
|
|
|
};
|
|
|
|
|
2003-07-24 11:53:43 +03:00
|
|
|
void msg(Verbosity level, const format & f);
|
2003-07-24 16:43:16 +03:00
|
|
|
void debug(const format & f); /* short-hand for msg(lvlDebug, ...) */
|
2003-05-26 01:42:19 +03:00
|
|
|
|
|
|
|
|
2003-07-21 00:11:43 +03:00
|
|
|
/* 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);
|
|
|
|
|
|
|
|
|
2003-04-04 19:14:56 +03:00
|
|
|
#endif /* !__UTIL_H */
|