From 9088dee9e265db8176b61e53ac43a916fdd34a3d Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Wed, 8 Mar 2006 14:11:19 +0000 Subject: * Some refactoring of the exception handling code so that we can catch Nix expression assertion failures. --- src/libutil/util.cc | 7 +++++++ src/libutil/util.hh | 14 +++++++++----- 2 files changed, 16 insertions(+), 5 deletions(-) (limited to 'src/libutil') diff --git a/src/libutil/util.cc b/src/libutil/util.cc index ee34cb18a59e..0d970e69e303 100644 --- a/src/libutil/util.cc +++ b/src/libutil/util.cc @@ -25,6 +25,13 @@ Error::Error(const format & f) } +Error & Error::addPrefix(const format & f) +{ + err = f.str() + err; + return *this; +} + + SysError::SysError(const format & f) : Error(format("%1%: %2%") % f.str() % strerror(errno)) { diff --git a/src/libutil/util.hh b/src/libutil/util.hh index aac2acd1730b..05cf777f1eb6 100644 --- a/src/libutil/util.hh +++ b/src/libutil/util.hh @@ -26,6 +26,7 @@ public: ~Error() throw () { }; const char * what() const throw () { return err.c_str(); } const string & msg() const throw () { return err; } + Error & addPrefix(const format & f); }; class SysError : public Error @@ -34,11 +35,14 @@ public: SysError(const format & f); }; -class UsageError : public Error -{ -public: - UsageError(const format & f) : Error(f) { }; -}; +#define MakeError(newClass, superClass) \ + class newClass : public superClass \ + { \ + public: \ + newClass(const format & f) : superClass(f) { }; \ + }; + +MakeError(UsageError, Error) typedef list Strings; -- cgit 1.4.1