aboutsummaryrefslogtreecommitdiff
path: root/src/libutil
diff options
context:
space:
mode:
Diffstat (limited to 'src/libutil')
-rw-r--r--src/libutil/types.hh5
-rw-r--r--src/libutil/util.cc3
2 files changed, 5 insertions, 3 deletions
diff --git a/src/libutil/types.hh b/src/libutil/types.hh
index 854a0f689..533fcca22 100644
--- a/src/libutil/types.hh
+++ b/src/libutil/types.hh
@@ -29,7 +29,8 @@ protected:
string prefix_; // used for location traces etc.
string err;
public:
- BaseError(const format & f);
+ unsigned int status; // exit status
+ BaseError(const format & f, unsigned int status = 1);
~BaseError() throw () { };
const char * what() const throw () { return err.c_str(); }
const string & msg() const throw () { return err; }
@@ -41,7 +42,7 @@ public:
class newClass : public superClass \
{ \
public: \
- newClass(const format & f) : superClass(f) { }; \
+ newClass(const format & f, unsigned int status = 1) : superClass(f, status) { }; \
};
MakeError(Error, BaseError)
diff --git a/src/libutil/util.cc b/src/libutil/util.cc
index 990962763..9adaac40d 100644
--- a/src/libutil/util.cc
+++ b/src/libutil/util.cc
@@ -20,7 +20,8 @@ extern char * * environ;
namespace nix {
-BaseError::BaseError(const format & f)
+BaseError::BaseError(const format & f, unsigned int status)
+ : status(status)
{
err = f.str();
}