blob: 8eab793c27bc188e14840377bd4b0a224d5303a7 [file] [log] [blame]
Michael J. Spencere4446922011-06-25 17:42:56 +00001//===- Error.cpp - system_error extensions for Object -----------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This defines a new error_category for the Object library.
11//
12//===----------------------------------------------------------------------===//
13
14#include "llvm/Object/Error.h"
15#include "llvm/Support/ErrorHandling.h"
Chris Bieneman684981e2014-09-19 22:09:18 +000016#include "llvm/Support/ManagedStatic.h"
Michael J. Spencere4446922011-06-25 17:42:56 +000017
18using namespace llvm;
19using namespace object;
20
21namespace {
Rafael Espindola25188c92014-06-12 01:45:43 +000022class _object_error_category : public std::error_category {
Michael J. Spencere4446922011-06-25 17:42:56 +000023public:
Rafael Espindolaf5d07fa2014-06-10 21:26:47 +000024 const char* name() const LLVM_NOEXCEPT override;
Justin Bognere3bfdc42014-03-15 04:05:59 +000025 std::string message(int ev) const override;
Michael J. Spencere4446922011-06-25 17:42:56 +000026};
27}
28
Abramo Bagnara9c2f73e2014-08-18 07:48:18 +000029const char *_object_error_category::name() const LLVM_NOEXCEPT {
Michael J. Spencere4446922011-06-25 17:42:56 +000030 return "llvm.object";
31}
32
Rafael Espindolae00fec82014-06-03 05:26:12 +000033std::string _object_error_category::message(int EV) const {
34 object_error E = static_cast<object_error>(EV);
Rafael Espindolae107ade2013-06-18 13:30:31 +000035 switch (E) {
Alexey Samsonove6388e62013-06-18 15:03:28 +000036 case object_error::arch_not_found:
37 return "No object file for requested architecture";
Michael J. Spencere4446922011-06-25 17:42:56 +000038 case object_error::invalid_file_type:
39 return "The file was not recognized as a valid object file";
40 case object_error::parse_failed:
41 return "Invalid data was encountered while parsing the file";
Michael J. Spencer1d6167f2011-06-25 17:55:23 +000042 case object_error::unexpected_eof:
43 return "The end of the file was unexpectedly encountered";
Rafael Espindola6a1bfb22015-06-29 14:39:25 +000044 case object_error::string_table_non_null_end:
45 return "String table must end with a null terminator";
Rafael Espindola6def3042015-07-01 12:56:27 +000046 case object_error::invalid_section_index:
47 return "Invalid section index";
Peter Collingbourne10039c02014-09-18 21:28:49 +000048 case object_error::bitcode_section_not_found:
49 return "Bitcode section not found in object file";
Michael J. Spencere4446922011-06-25 17:42:56 +000050 }
Rafael Espindolae107ade2013-06-18 13:30:31 +000051 llvm_unreachable("An enumerator of object_error does not have a message "
52 "defined.");
Michael J. Spencere4446922011-06-25 17:42:56 +000053}
54
Lang Hames9e964f32016-03-25 17:25:34 +000055char BinaryError::ID = 0;
56char GenericBinaryError::ID = 0;
57
Kevin Enderbyd4e075b2016-05-06 20:16:28 +000058GenericBinaryError::GenericBinaryError(Twine Msg) : Msg(Msg.str()) {}
Lang Hames9e964f32016-03-25 17:25:34 +000059
Kevin Enderbyd4e075b2016-05-06 20:16:28 +000060GenericBinaryError::GenericBinaryError(Twine Msg, object_error ECOverride)
61 : Msg(Msg.str()) {
Lang Hames9e964f32016-03-25 17:25:34 +000062 setErrorCode(make_error_code(ECOverride));
63}
64
65void GenericBinaryError::log(raw_ostream &OS) const {
Kevin Enderbyd4e075b2016-05-06 20:16:28 +000066 OS << Msg;
Lang Hames9e964f32016-03-25 17:25:34 +000067}
68
Chris Bieneman684981e2014-09-19 22:09:18 +000069static ManagedStatic<_object_error_category> error_category;
70
Rafael Espindola25188c92014-06-12 01:45:43 +000071const std::error_category &object::object_category() {
Chris Bieneman684981e2014-09-19 22:09:18 +000072 return *error_category;
Michael J. Spencere4446922011-06-25 17:42:56 +000073}
Lang Hames8a63b2a2016-05-17 21:38:53 +000074
75llvm::Error llvm::object::isNotObjectErrorInvalidFileType(llvm::Error Err) {
76 if (auto Err2 =
77 handleErrors(std::move(Err),
78 [](std::unique_ptr<ECError> M) {
79 // Try to handle 'M'. If successful, return a success value from
80 // the handler.
81 if (M->convertToErrorCode() == object_error::invalid_file_type)
82 return Error::success();
83
84 // We failed to handle 'M' - return it from the handler.
85 // This value will be passed back from catchErrors and
86 // wind up in Err2, where it will be returned from this function.
87 return Error(std::move(M));
88 }))
89 return Err2;
90 return Err;
91}