mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	Since our error_category is based on the std one, we should have the same visibility for the constructor. This also allows us to avoid using the _do_message implementation detail in our own categories. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@203998 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			60 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //===- Error.cpp - system_error extensions for Object -----------*- C++ -*-===//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file is distributed under the University of Illinois Open Source
 | |
| // License. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| //
 | |
| // This defines a new error_category for the Object library.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| #include "llvm/Object/Error.h"
 | |
| #include "llvm/Support/ErrorHandling.h"
 | |
| 
 | |
| using namespace llvm;
 | |
| using namespace object;
 | |
| 
 | |
| namespace {
 | |
| class _object_error_category : public error_category {
 | |
| public:
 | |
|   const char* name() const override;
 | |
|   std::string message(int ev) const override;
 | |
|   error_condition default_error_condition(int ev) const override;
 | |
| };
 | |
| }
 | |
| 
 | |
| const char *_object_error_category::name() const {
 | |
|   return "llvm.object";
 | |
| }
 | |
| 
 | |
| std::string _object_error_category::message(int ev) const {
 | |
|   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";
 | |
|   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 {
 | |
|   if (ev == object_error::success)
 | |
|     return errc::success;
 | |
|   return errc::invalid_argument;
 | |
| }
 | |
| 
 | |
| const error_category &object::object_category() {
 | |
|   static _object_error_category o;
 | |
|   return o;
 | |
| }
 |