2007-12-11 08:20:48 +08:00
|
|
|
/*===-- llvm-c/BitReader.h - BitReader Library C Interface ------*- C++ -*-===*\
|
|
|
|
|* *|
|
|
|
|
|* The LLVM Compiler Infrastructure *|
|
|
|
|
|* *|
|
2007-12-30 03:59:42 +08:00
|
|
|
|* This file is distributed under the University of Illinois Open Source *|
|
|
|
|
|* License. See LICENSE.TXT for details. *|
|
2007-12-11 08:20:48 +08:00
|
|
|
|* *|
|
|
|
|
|*===----------------------------------------------------------------------===*|
|
|
|
|
|* *|
|
|
|
|
|* This header declares the C interface to libLLVMBitReader.a, which *|
|
|
|
|
|* implements input of the LLVM bitcode format. *|
|
|
|
|
|* *|
|
|
|
|
|* Many exotic languages can interoperate with C code but have a harder time *|
|
|
|
|
|* with C++ due to name mangling. So in addition to C, this interface enables *|
|
|
|
|
|* tools written in such languages. *|
|
|
|
|
|* *|
|
|
|
|
\*===----------------------------------------------------------------------===*/
|
|
|
|
|
2014-08-14 00:26:38 +08:00
|
|
|
#ifndef LLVM_C_BITREADER_H
|
|
|
|
#define LLVM_C_BITREADER_H
|
2007-12-11 08:20:48 +08:00
|
|
|
|
|
|
|
#include "llvm-c/Core.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2012-03-21 11:54:29 +08:00
|
|
|
/**
|
|
|
|
* @defgroup LLVMCBitReader Bit Reader
|
|
|
|
* @ingroup LLVMC
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
2007-12-11 08:20:48 +08:00
|
|
|
|
2007-12-20 06:30:40 +08:00
|
|
|
/* Builds a module from the bitcode in the specified memory buffer, returning a
|
|
|
|
reference to the module via the OutModule parameter. Returns 0 on success.
|
2013-10-24 01:56:29 +08:00
|
|
|
Optionally returns a human-readable error message via OutMessage. */
|
2010-01-10 06:27:07 +08:00
|
|
|
LLVMBool LLVMParseBitcode(LLVMMemoryBufferRef MemBuf,
|
|
|
|
LLVMModuleRef *OutModule, char **OutMessage);
|
2007-12-20 06:30:40 +08:00
|
|
|
|
2010-01-10 06:27:07 +08:00
|
|
|
LLVMBool LLVMParseBitcodeInContext(LLVMContextRef ContextRef,
|
|
|
|
LLVMMemoryBufferRef MemBuf,
|
|
|
|
LLVMModuleRef *OutModule, char **OutMessage);
|
2009-07-02 15:17:57 +08:00
|
|
|
|
2010-03-03 07:58:54 +08:00
|
|
|
/** Reads a module from the specified path, returning via the OutMP parameter
|
|
|
|
a module provider which performs lazy deserialization. Returns 0 on success.
|
2013-10-24 01:56:29 +08:00
|
|
|
Optionally returns a human-readable error message via OutMessage. */
|
2010-03-03 07:58:54 +08:00
|
|
|
LLVMBool LLVMGetBitcodeModuleInContext(LLVMContextRef ContextRef,
|
|
|
|
LLVMMemoryBufferRef MemBuf,
|
|
|
|
LLVMModuleRef *OutM,
|
|
|
|
char **OutMessage);
|
|
|
|
|
|
|
|
LLVMBool LLVMGetBitcodeModule(LLVMMemoryBufferRef MemBuf, LLVMModuleRef *OutM,
|
|
|
|
char **OutMessage);
|
2010-01-10 06:27:07 +08:00
|
|
|
|
2010-03-03 07:58:54 +08:00
|
|
|
|
|
|
|
/** Deprecated: Use LLVMGetBitcodeModuleInContext instead. */
|
2010-01-10 06:27:07 +08:00
|
|
|
LLVMBool LLVMGetBitcodeModuleProviderInContext(LLVMContextRef ContextRef,
|
|
|
|
LLVMMemoryBufferRef MemBuf,
|
|
|
|
LLVMModuleProviderRef *OutMP,
|
|
|
|
char **OutMessage);
|
2009-07-02 15:17:57 +08:00
|
|
|
|
2010-03-03 07:58:54 +08:00
|
|
|
/** Deprecated: Use LLVMGetBitcodeModule instead. */
|
|
|
|
LLVMBool LLVMGetBitcodeModuleProvider(LLVMMemoryBufferRef MemBuf,
|
|
|
|
LLVMModuleProviderRef *OutMP,
|
|
|
|
char **OutMessage);
|
2007-12-11 08:20:48 +08:00
|
|
|
|
2012-03-21 11:54:29 +08:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2007-12-11 08:20:48 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|