LLVM  8.0.1
Public Member Functions | Static Public Attributes | List of all members
llvm::StringError Class Reference

This class wraps a string in an Error. More...

#include "llvm/Support/Error.h"

Inheritance diagram for llvm::StringError:
Inheritance graph
[legend]
Collaboration diagram for llvm::StringError:
Collaboration graph
[legend]

Public Member Functions

 StringError (std::error_code EC, const Twine &S=Twine())
 
 StringError (const Twine &S, std::error_code EC)
 
void log (raw_ostream &OS) const override
 Print an error message to an output stream. More...
 
std::error_code convertToErrorCode () const override
 Convert this error to a std::error_code. More...
 
const std::string & getMessage () const
 
- Public Member Functions inherited from llvm::ErrorInfo< StringError >
const void * dynamicClassID () const override
 
bool isA (const void *const ClassID) const override
 
- Public Member Functions inherited from llvm::ErrorInfoBase
virtual ~ErrorInfoBase ()=default
 
virtual std::string message () const
 Return the error message as a string. More...
 
template<typename ErrorInfoT >
bool isA () const
 

Static Public Attributes

static char ID = 0
 

Additional Inherited Members

- Static Public Member Functions inherited from llvm::ErrorInfo< StringError >
static const void * classID ()
 
- Static Public Member Functions inherited from llvm::ErrorInfoBase
static const void * classID ()
 

Detailed Description

This class wraps a string in an Error.

StringError is useful in cases where the client is not expected to be able to consume the specific error message programmatically (for example, if the error message is to be presented to the user).

StringError can also be used when additional information is to be printed along with a error_code message. Depending on the constructor called, this class can either display:

  1. the error_code message (ECError behavior)
  2. a string
  3. the error_code message and a string

These behaviors are useful when subtyping is required; for example, when a specific library needs an explicit error type. In the example below, PDBError is derived from StringError:

Expected<int> foo() {
return llvm::make_error<PDBError>(pdb_error_code::dia_failed_loading,
"Additional information");
}

Definition at line 1141 of file Error.h.

Constructor & Destructor Documentation

◆ StringError() [1/2]

llvm::StringError::StringError ( std::error_code  EC,
const Twine S = Twine() 
)

Definition at line 116 of file Error.cpp.

◆ StringError() [2/2]

llvm::StringError::StringError ( const Twine S,
std::error_code  EC 
)

Definition at line 119 of file Error.cpp.

Member Function Documentation

◆ convertToErrorCode()

std::error_code llvm::StringError::convertToErrorCode ( ) const
overridevirtual

Convert this error to a std::error_code.

This is a temporary crutch to enable interaction with code still using std::error_code. It will be removed in the future.

Implements llvm::ErrorInfoBase.

Definition at line 132 of file Error.cpp.

◆ getMessage()

const std::string& llvm::StringError::getMessage ( ) const
inline

Definition at line 1154 of file Error.h.

◆ log()

void llvm::StringError::log ( raw_ostream OS) const
overridevirtual

Print an error message to an output stream.

Implements llvm::ErrorInfoBase.

Definition at line 122 of file Error.cpp.

Member Data Documentation

◆ ID

char llvm::StringError::ID = 0
static

Definition at line 1143 of file Error.h.


The documentation for this class was generated from the following files: