|
|
@ -58,7 +58,7 @@ class Status { |
|
|
|
kAborted = 10, |
|
|
|
kAborted = 10, |
|
|
|
kBusy = 11, |
|
|
|
kBusy = 11, |
|
|
|
kExpired = 12, |
|
|
|
kExpired = 12, |
|
|
|
kTryAgain = 13, |
|
|
|
kTryAgain = 13 |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
Code code() const { return code_; } |
|
|
|
Code code() const { return code_; } |
|
|
@ -68,6 +68,7 @@ class Status { |
|
|
|
kMutexTimeout = 1, |
|
|
|
kMutexTimeout = 1, |
|
|
|
kLockTimeout = 2, |
|
|
|
kLockTimeout = 2, |
|
|
|
kLockLimit = 3, |
|
|
|
kLockLimit = 3, |
|
|
|
|
|
|
|
kNoSpace = 4, |
|
|
|
kMaxSubCode |
|
|
|
kMaxSubCode |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
@ -157,6 +158,11 @@ class Status { |
|
|
|
return Status(kTryAgain, msg, msg2); |
|
|
|
return Status(kTryAgain, msg, msg2); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static Status NoSpace() { return Status(kIOError, kNoSpace); } |
|
|
|
|
|
|
|
static Status NoSpace(const Slice& msg, const Slice& msg2 = Slice()) { |
|
|
|
|
|
|
|
return Status(kIOError, kNoSpace, msg, msg2); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Returns true iff the status indicates success.
|
|
|
|
// Returns true iff the status indicates success.
|
|
|
|
bool ok() const { return code() == kOk; } |
|
|
|
bool ok() const { return code() == kOk; } |
|
|
|
|
|
|
|
|
|
|
@ -200,6 +206,15 @@ class Status { |
|
|
|
// re-attempted.
|
|
|
|
// re-attempted.
|
|
|
|
bool IsTryAgain() const { return code() == kTryAgain; } |
|
|
|
bool IsTryAgain() const { return code() == kTryAgain; } |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Returns true iff the status indicates a NoSpace error
|
|
|
|
|
|
|
|
// This is caused by an I/O error returning the specific "out of space"
|
|
|
|
|
|
|
|
// error condition. Stricto sensu, an NoSpace error is an I/O error
|
|
|
|
|
|
|
|
// with a specific subcode, enabling users to take the appropriate action
|
|
|
|
|
|
|
|
// if needed
|
|
|
|
|
|
|
|
bool IsNoSpace() const { |
|
|
|
|
|
|
|
return (code() == kIOError) && (subcode() == kNoSpace); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Return a string representation of this status suitable for printing.
|
|
|
|
// Return a string representation of this status suitable for printing.
|
|
|
|
// Returns the string "OK" for success.
|
|
|
|
// Returns the string "OK" for success.
|
|
|
|
std::string ToString() const; |
|
|
|
std::string ToString() const; |
|
|
@ -219,7 +234,10 @@ class Status { |
|
|
|
explicit Status(Code _code, SubCode _subcode = kNone) |
|
|
|
explicit Status(Code _code, SubCode _subcode = kNone) |
|
|
|
: code_(_code), subcode_(_subcode), state_(nullptr) {} |
|
|
|
: code_(_code), subcode_(_subcode), state_(nullptr) {} |
|
|
|
|
|
|
|
|
|
|
|
Status(Code _code, const Slice& msg, const Slice& msg2); |
|
|
|
Status(Code _code, SubCode _subcode, const Slice& msg, const Slice& msg2); |
|
|
|
|
|
|
|
Status(Code _code, const Slice& msg, const Slice& msg2) |
|
|
|
|
|
|
|
: Status(_code, kNone, msg, msg2) {} |
|
|
|
|
|
|
|
|
|
|
|
static const char* CopyState(const char* s); |
|
|
|
static const char* CopyState(const char* s); |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|