Fix a FIXME about the format and add a test.
[oota-llvm.git] / lib / Object / Error.cpp
index 40f97d48a1dc0dfe340726c182f40d59d9d6ef82..47ce38c88839483313f928aaff2a4afe4d443481 100644 (file)
@@ -31,16 +31,20 @@ const char *_object_error_category::name() const {
 }
 
 std::string _object_error_category::message(int ev) const {
-  switch (ev) {
+  object_error::Impl E = static_cast<object_error::Impl>(ev);
+  switch (E) {
   case object_error::success: return "Success";
+  case object_error::arch_not_found:
+    return "No object file for requested architecture";
   case object_error::invalid_file_type:
     return "The file was not recognized as a valid object file";
   case object_error::parse_failed:
     return "Invalid data was encountered while parsing the file";
-  default:
-    llvm_unreachable("An enumerator of object_error does not have a message "
-                     "defined.");
+  case object_error::unexpected_eof:
+    return "The end of the file was unexpectedly encountered";
   }
+  llvm_unreachable("An enumerator of object_error does not have a message "
+                   "defined.");
 }
 
 error_condition _object_error_category::default_error_condition(int ev) const {