2012-08-15 84 views
10

我正在使用C++ 11 system_error錯誤代碼庫爲我創建的庫創建自定義錯誤類。我之前用boost::error_code這樣做過,但我無法完成與std::error_code的合作。我正在使用GCC 4.6。將錯誤代碼枚舉與std :: error_code進行比較

基本上,我已經奠定了所有的樣板代碼創建一個錯誤類,一個error_category,並在STD命名空間中的轉換程序,以我的自定義枚舉轉換成std::error_code對象:

namespace mylib 
{ 
    namespace errc { 

     enum my_error 
     { 
      failed = 0 
     }; 

     inline const char* error_message(int c) 
     { 
      static const char* err_msg[] = 
      { 
       "Failed", 
      }; 

      assert(c < sizeof(err_msg)/sizeof(err_msg[0])); 
      return err_msg[c]; 
     } 

     class my_error_category : public std::error_category 
     { 
      public: 

      my_error_category() 
      { } 

      std::string message(int c) const 
      { 
       return error_message(c); 
      } 

      const char* name() const { return "My Error Category"; } 

      const static error_category& get() 
      { 
       const static my_error_category category_const; 
       return category_const; 
      } 
     }; 

    } // end namespace errc 
} // end namespace mylib 

namespace std { 

inline error_code make_error_code(mylib::errc::my_error e) 
{ 
    return error_code(static_cast<int>(e), mylib::errc::my_error_category::get()); 
} 

template<> 
struct is_error_code_enum<mylib::errc::my_error> 
    : std::true_type 
{ }; 


是,我的錯誤代碼枚舉和std::error_code對象之間的隱式轉換似乎問題不奏效,所以我不能例如試着和枚舉文字比較std::error_code一個實例:

int main() 
{ 
    std::error_code ec1 = std::make_error_code(mylib::errc::failed); // works 
    std::error_code ec2 = mylib::errc::failed; // doesn't compile 
    bool result = (ec2 == mylib::errc::failed); // doesn't compile 
} 

表達式ec2 == mylib::errc::failed不會編譯 - 我必須說ec2 == std::make_error_code(mylib::errc::failed)

編譯器發出的錯誤是:

In file included from test6.cc:3:0: 
/usr/include/c++/4.6/system_error: In constructor ‘std::error_code::error_code(_ErrorCodeEnum, typename std::enable_if<std::is_error_code_enum<_ErrorCodeEnum>::value>::type*) [with _ErrorCodeEnum = mylib::errc::my_error, typename std::enable_if<std::is_error_code_enum<_ErrorCodeEnum>::value>::type = void]’: 
test6.cc:70:37: instantiated from here 
/usr/include/c++/4.6/system_error:127:9: error: cannot convert ‘mylib::errc::my_error’ to ‘std::errc’ for argument ‘1’ to ‘std::error_code std::make_error_code(std::errc)’ 

這裏是一個Ideone link

那麼,爲什麼這不工作?我是否需要額外的樣板代碼來使mylib::errc::my_error枚舉可以隱式轉換爲std::error_code?我認爲std::make_error_code的專業化處理呢?

回答

8

您必須將error_code make_error_code(mylib::errc::my_error e)函數從std移動到您的錯誤命名空間(mylib::errc)。請檢查http://ideone.com/eSfee