2009-06-02 17:52:33 +00:00
|
|
|
/*===-- llvm-c/BitReader.h - BitReader Library C Interface ------*- C++ -*-===*\
|
|
|
|
|* *|
|
|
|
|
|* The LLVM Compiler Infrastructure *|
|
|
|
|
|* *|
|
|
|
|
|* This file is distributed under the University of Illinois Open Source *|
|
|
|
|
|* License. See LICENSE.TXT for details. *|
|
|
|
|
|* *|
|
|
|
|
|*===----------------------------------------------------------------------===*|
|
|
|
|
|* *|
|
|
|
|
|* 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. *|
|
|
|
|
|* *|
|
|
|
|
\*===----------------------------------------------------------------------===*/
|
|
|
|
|
|
|
|
#ifndef LLVM_C_BITCODEREADER_H
|
|
|
|
#define LLVM_C_BITCODEREADER_H
|
|
|
|
|
|
|
|
#include "llvm-c/Core.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2012-04-14 13:54:10 +00:00
|
|
|
/**
|
|
|
|
* @defgroup LLVMCBitReader Bit Reader
|
|
|
|
* @ingroup LLVMC
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
2009-06-02 17:52:33 +00: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.
|
|
|
|
Optionally returns a human-readable error message via OutMessage. */
|
2010-01-15 15:37:28 +00:00
|
|
|
LLVMBool LLVMParseBitcode(LLVMMemoryBufferRef MemBuf,
|
|
|
|
LLVMModuleRef *OutModule, char **OutMessage);
|
2009-06-02 17:52:33 +00:00
|
|
|
|
2010-01-15 15:37:28 +00:00
|
|
|
LLVMBool LLVMParseBitcodeInContext(LLVMContextRef ContextRef,
|
|
|
|
LLVMMemoryBufferRef MemBuf,
|
|
|
|
LLVMModuleRef *OutModule, char **OutMessage);
|
2009-07-04 13:58:26 +00:00
|
|
|
|
2010-03-03 17:27:15 +00:00
|
|
|
/** Reads a module from the specified path, returning via the OutMP parameter
|
|
|
|
a module provider which performs lazy deserialization. Returns 0 on success.
|
|
|
|
Optionally returns a human-readable error message via OutMessage. */
|
|
|
|
LLVMBool LLVMGetBitcodeModuleInContext(LLVMContextRef ContextRef,
|
|
|
|
LLVMMemoryBufferRef MemBuf,
|
|
|
|
LLVMModuleRef *OutM,
|
|
|
|
char **OutMessage);
|
|
|
|
|
|
|
|
LLVMBool LLVMGetBitcodeModule(LLVMMemoryBufferRef MemBuf, LLVMModuleRef *OutM,
|
|
|
|
char **OutMessage);
|
2010-01-15 15:37:28 +00:00
|
|
|
|
2010-03-03 17:27:15 +00:00
|
|
|
|
|
|
|
/** Deprecated: Use LLVMGetBitcodeModuleInContext instead. */
|
2010-01-15 15:37:28 +00:00
|
|
|
LLVMBool LLVMGetBitcodeModuleProviderInContext(LLVMContextRef ContextRef,
|
|
|
|
LLVMMemoryBufferRef MemBuf,
|
|
|
|
LLVMModuleProviderRef *OutMP,
|
|
|
|
char **OutMessage);
|
2009-07-04 13:58:26 +00:00
|
|
|
|
2010-03-03 17:27:15 +00:00
|
|
|
/** Deprecated: Use LLVMGetBitcodeModule instead. */
|
|
|
|
LLVMBool LLVMGetBitcodeModuleProvider(LLVMMemoryBufferRef MemBuf,
|
|
|
|
LLVMModuleProviderRef *OutMP,
|
|
|
|
char **OutMessage);
|
2009-06-02 17:52:33 +00:00
|
|
|
|
2012-04-14 13:54:10 +00:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2009-06-02 17:52:33 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|