2018-08-16 02:42:11 +08:00
|
|
|
/*===------- llvm-c/Error.h - llvm::Error class C Interface -------*- C -*-===*\
|
|
|
|
|* *|
|
2019-01-19 16:50:56 +08:00
|
|
|
|* Part of the LLVM Project, under the Apache License v2.0 with LLVM *|
|
|
|
|
|* Exceptions. *|
|
|
|
|
|* See https://llvm.org/LICENSE.txt for license information. *|
|
|
|
|
|* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception *|
|
2018-08-16 02:42:11 +08:00
|
|
|
|* *|
|
|
|
|
|*===----------------------------------------------------------------------===*|
|
|
|
|
|* *|
|
|
|
|
|* This file defines the C interface to LLVM's Error class. *|
|
|
|
|
|* *|
|
|
|
|
\*===----------------------------------------------------------------------===*/
|
|
|
|
|
|
|
|
#ifndef LLVM_C_ERROR_H
|
|
|
|
#define LLVM_C_ERROR_H
|
|
|
|
|
2019-11-15 05:57:57 +08:00
|
|
|
#include "llvm-c/ExternC.h"
|
|
|
|
|
|
|
|
LLVM_C_EXTERN_C_BEGIN
|
2018-08-16 02:42:11 +08:00
|
|
|
|
2018-09-23 10:09:18 +08:00
|
|
|
#define LLVMErrorSuccess 0
|
|
|
|
|
2018-08-16 02:42:11 +08:00
|
|
|
/**
|
|
|
|
* Opaque reference to an error instance. Null serves as the 'success' value.
|
|
|
|
*/
|
|
|
|
typedef struct LLVMOpaqueError *LLVMErrorRef;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Error type identifier.
|
|
|
|
*/
|
|
|
|
typedef const void *LLVMErrorTypeId;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the type id for the given error instance, which must be a failure
|
|
|
|
* value (i.e. non-null).
|
|
|
|
*/
|
|
|
|
LLVMErrorTypeId LLVMGetErrorTypeId(LLVMErrorRef Err);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Dispose of the given error without handling it. This operation consumes the
|
|
|
|
* error, and the given LLVMErrorRef value is not usable once this call returns.
|
|
|
|
* Note: This method *only* needs to be called if the error is not being passed
|
|
|
|
* to some other consuming operation, e.g. LLVMGetErrorMessage.
|
|
|
|
*/
|
|
|
|
void LLVMConsumeError(LLVMErrorRef Err);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the given string's error message. This operation consumes the error,
|
|
|
|
* and the given LLVMErrorRef value is not usable once this call returns.
|
2018-09-30 07:49:54 +08:00
|
|
|
* The caller is responsible for disposing of the string by calling
|
|
|
|
* LLVMDisposeErrorMessage.
|
2018-08-16 02:42:11 +08:00
|
|
|
*/
|
|
|
|
char *LLVMGetErrorMessage(LLVMErrorRef Err);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Dispose of the given error message.
|
|
|
|
*/
|
|
|
|
void LLVMDisposeErrorMessage(char *ErrMsg);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the type id for llvm StringError.
|
|
|
|
*/
|
2019-05-06 14:42:06 +08:00
|
|
|
LLVMErrorTypeId LLVMGetStringErrorTypeId(void);
|
2018-08-16 02:42:11 +08:00
|
|
|
|
2020-10-16 08:31:14 +08:00
|
|
|
/**
|
|
|
|
* Create a StringError.
|
|
|
|
*/
|
|
|
|
LLVMErrorRef LLVMCreateStringError(const char *ErrMsg);
|
|
|
|
|
2019-11-15 05:57:57 +08:00
|
|
|
LLVM_C_EXTERN_C_END
|
2018-08-16 02:42:11 +08:00
|
|
|
|
|
|
|
#endif
|