1e4446923SMichael J. Spencer //===- Error.cpp - system_error extensions for Object -----------*- C++ -*-===// 2e4446923SMichael J. Spencer // 3e4446923SMichael J. Spencer // The LLVM Compiler Infrastructure 4e4446923SMichael J. Spencer // 5e4446923SMichael J. Spencer // This file is distributed under the University of Illinois Open Source 6e4446923SMichael J. Spencer // License. See LICENSE.TXT for details. 7e4446923SMichael J. Spencer // 8e4446923SMichael J. Spencer //===----------------------------------------------------------------------===// 9e4446923SMichael J. Spencer // 10e4446923SMichael J. Spencer // This defines a new error_category for the Object library. 11e4446923SMichael J. Spencer // 12e4446923SMichael J. Spencer //===----------------------------------------------------------------------===// 13e4446923SMichael J. Spencer 14e4446923SMichael J. Spencer #include "llvm/Object/Error.h" 15e4446923SMichael J. Spencer #include "llvm/Support/ErrorHandling.h" 16684981e4SChris Bieneman #include "llvm/Support/ManagedStatic.h" 17e4446923SMichael J. Spencer 18e4446923SMichael J. Spencer using namespace llvm; 19e4446923SMichael J. Spencer using namespace object; 20e4446923SMichael J. Spencer 21e4446923SMichael J. Spencer namespace { 2225188c95SRafael Espindola class _object_error_category : public std::error_category { 23e4446923SMichael J. Spencer public: 24f5d07fa5SRafael Espindola const char* name() const LLVM_NOEXCEPT override; 25e3bfdc4eSJustin Bogner std::string message(int ev) const override; 26e4446923SMichael J. Spencer }; 27e4446923SMichael J. Spencer } 28e4446923SMichael J. Spencer 299c2f73edSAbramo Bagnara const char *_object_error_category::name() const LLVM_NOEXCEPT { 30e4446923SMichael J. Spencer return "llvm.object"; 31e4446923SMichael J. Spencer } 32e4446923SMichael J. Spencer 33e00fec8fSRafael Espindola std::string _object_error_category::message(int EV) const { 34e00fec8fSRafael Espindola object_error E = static_cast<object_error>(EV); 35e107ade3SRafael Espindola switch (E) { 36e6388e62SAlexey Samsonov case object_error::arch_not_found: 37e6388e62SAlexey Samsonov return "No object file for requested architecture"; 38e4446923SMichael J. Spencer case object_error::invalid_file_type: 39e4446923SMichael J. Spencer return "The file was not recognized as a valid object file"; 40e4446923SMichael J. Spencer case object_error::parse_failed: 41e4446923SMichael J. Spencer return "Invalid data was encountered while parsing the file"; 421d6167fdSMichael J. Spencer case object_error::unexpected_eof: 431d6167fdSMichael J. Spencer return "The end of the file was unexpectedly encountered"; 446a1bfb2fSRafael Espindola case object_error::string_table_non_null_end: 456a1bfb2fSRafael Espindola return "String table must end with a null terminator"; 466def3042SRafael Espindola case object_error::invalid_section_index: 476def3042SRafael Espindola return "Invalid section index"; 4810039c02SPeter Collingbourne case object_error::bitcode_section_not_found: 4910039c02SPeter Collingbourne return "Bitcode section not found in object file"; 50e107ade3SRafael Espindola } 51e4446923SMichael J. Spencer llvm_unreachable("An enumerator of object_error does not have a message " 52e4446923SMichael J. Spencer "defined."); 53e4446923SMichael J. Spencer } 54e4446923SMichael J. Spencer 559e964f37SLang Hames char BinaryError::ID = 0; 569e964f37SLang Hames char GenericBinaryError::ID = 0; 579e964f37SLang Hames 58d4e075beSKevin Enderby GenericBinaryError::GenericBinaryError(Twine Msg) : Msg(Msg.str()) {} 599e964f37SLang Hames 60d4e075beSKevin Enderby GenericBinaryError::GenericBinaryError(Twine Msg, object_error ECOverride) 61d4e075beSKevin Enderby : Msg(Msg.str()) { 629e964f37SLang Hames setErrorCode(make_error_code(ECOverride)); 639e964f37SLang Hames } 649e964f37SLang Hames 659e964f37SLang Hames void GenericBinaryError::log(raw_ostream &OS) const { 66d4e075beSKevin Enderby OS << Msg; 679e964f37SLang Hames } 689e964f37SLang Hames 69684981e4SChris Bieneman static ManagedStatic<_object_error_category> error_category; 70684981e4SChris Bieneman 7125188c95SRafael Espindola const std::error_category &object::object_category() { 72684981e4SChris Bieneman return *error_category; 73e4446923SMichael J. Spencer } 74*8a63b2afSLang Hames 75*8a63b2afSLang Hames llvm::Error llvm::object::isNotObjectErrorInvalidFileType(llvm::Error Err) { 76*8a63b2afSLang Hames if (auto Err2 = 77*8a63b2afSLang Hames handleErrors(std::move(Err), 78*8a63b2afSLang Hames [](std::unique_ptr<ECError> M) { 79*8a63b2afSLang Hames // Try to handle 'M'. If successful, return a success value from 80*8a63b2afSLang Hames // the handler. 81*8a63b2afSLang Hames if (M->convertToErrorCode() == object_error::invalid_file_type) 82*8a63b2afSLang Hames return Error::success(); 83*8a63b2afSLang Hames 84*8a63b2afSLang Hames // We failed to handle 'M' - return it from the handler. 85*8a63b2afSLang Hames // This value will be passed back from catchErrors and 86*8a63b2afSLang Hames // wind up in Err2, where it will be returned from this function. 87*8a63b2afSLang Hames return Error(std::move(M)); 88*8a63b2afSLang Hames })) 89*8a63b2afSLang Hames return Err2; 90*8a63b2afSLang Hames return Err; 91*8a63b2afSLang Hames } 92