From dbb8260f7e50659166415fb188bb288955723280 Mon Sep 17 00:00:00 2001 From: Dmitri Smirnov Date: Tue, 22 Dec 2015 16:06:20 -0800 Subject: [PATCH] Make Status moveable Status is a class which is frequently returned by value from functions. Making it movable avoids 99% of the copies automatically on return by value. --- include/rocksdb/status.h | 46 +++++++++++++++++++++++++++++++++++----- 1 file changed, 41 insertions(+), 5 deletions(-) diff --git a/include/rocksdb/status.h b/include/rocksdb/status.h index f3f652af7..511f6661f 100644 --- a/include/rocksdb/status.h +++ b/include/rocksdb/status.h @@ -30,7 +30,17 @@ class Status { // Copy the specified status. Status(const Status& s); - void operator=(const Status& s); + Status& operator=(const Status& s); + Status(Status&& s) +#if !(defined _MSC_VER) || ((defined _MSC_VER) && (_MSC_VER >= 1900)) + noexcept +#endif + ; + Status& operator=(Status&& s) +#if !(defined _MSC_VER) || ((defined _MSC_VER) && (_MSC_VER >= 1900)) + noexcept +#endif + ; bool operator==(const Status& rhs) const; bool operator!=(const Status& rhs) const; @@ -214,15 +224,41 @@ class Status { inline Status::Status(const Status& s) : code_(s.code_), subcode_(s.subcode_) { state_ = (s.state_ == nullptr) ? nullptr : CopyState(s.state_); } -inline void Status::operator=(const Status& s) { +inline Status& Status::operator=(const Status& s) { // The following condition catches both aliasing (when this == &s), // and the common case where both s and *this are ok. - code_ = s.code_; - subcode_ = s.subcode_; - if (state_ != s.state_) { + if(this != &s) { + code_ = s.code_; + subcode_ = s.subcode_; delete[] state_; state_ = (s.state_ == nullptr) ? nullptr : CopyState(s.state_); } + return *this; +} + +inline Status::Status(Status&& s) +#if !(defined _MSC_VER) || ((defined _MSC_VER) && (_MSC_VER >= 1900)) +noexcept +#endif + : Status() { + *this = std::move(s); +} + +inline Status& Status::operator=(Status&& s) +#if !(defined _MSC_VER) || ((defined _MSC_VER) && (_MSC_VER >= 1900)) +noexcept +#endif +{ + if(this != &s) { + code_ = std::move(s.code_); + s.code_ = kOk; + subcode_ = std::move(s.subcode_); + s.subcode_ = kNone; + delete [] state_; + state_ = nullptr; + std::swap(state_, s.state_); + } + return *this; } inline bool Status::operator==(const Status& rhs) const {