2013-11-06 17:21:31 +08:00
|
|
|
/*===-- llvm-c/Support.h - Support 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 file defines the C interface to the LLVM support library. *|
|
|
|
|
|* *|
|
|
|
|
\*===----------------------------------------------------------------------===*/
|
|
|
|
|
|
|
|
#ifndef LLVM_C_SUPPORT_H
|
|
|
|
#define LLVM_C_SUPPORT_H
|
|
|
|
|
2014-03-06 12:13:12 +08:00
|
|
|
#include "llvm/Support/DataTypes.h"
|
2013-11-06 17:21:31 +08:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-03-06 12:13:12 +08:00
|
|
|
/**
|
|
|
|
* @defgroup LLVMCSupportTypes Types and Enumerations
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
typedef int LLVMBool;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to pass regions of memory through LLVM interfaces.
|
|
|
|
*
|
|
|
|
* @see llvm::MemoryBuffer
|
|
|
|
*/
|
|
|
|
typedef struct LLVMOpaqueMemoryBuffer *LLVMMemoryBufferRef;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2013-11-06 17:21:31 +08:00
|
|
|
/**
|
|
|
|
* This function permanently loads the dynamic library at the given path.
|
|
|
|
* It is safe to call this function multiple times for the same library.
|
|
|
|
*
|
|
|
|
* @see sys::DynamicLibrary::LoadLibraryPermanently()
|
|
|
|
*/
|
|
|
|
LLVMBool LLVMLoadLibraryPermanently(const char* Filename);
|
|
|
|
|
2014-10-17 06:47:52 +08:00
|
|
|
/**
|
|
|
|
* This function parses the given arguments using the LLVM command line parser.
|
|
|
|
* Note that the only stable thing about this function is its signature; you
|
|
|
|
* cannot rely on any particular set of command line arguments being interpreted
|
|
|
|
* the same way across LLVM versions.
|
|
|
|
*
|
|
|
|
* @see llvm::cl::ParseCommandLineOptions()
|
|
|
|
*/
|
|
|
|
void LLVMParseCommandLineOptions(int argc, const char *const *argv,
|
|
|
|
const char *Overview);
|
|
|
|
|
2015-06-09 23:57:30 +08:00
|
|
|
/**
|
|
|
|
* This function will search through all previously loaded dynamic
|
|
|
|
* libraries for the symbol \p symbolName. If it is found, the address of
|
|
|
|
* that symbol is returned. If not, null is returned.
|
|
|
|
*
|
|
|
|
* @see sys::DynamicLibrary::SearchForAddressOfSymbol()
|
|
|
|
*/
|
|
|
|
void *LLVMSearchForAddressOfSymbol(const char *symbolName);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This functions permanently adds the symbol \p symbolName with the
|
|
|
|
* value \p symbolValue. These symbols are searched before any
|
|
|
|
* libraries.
|
|
|
|
*
|
|
|
|
* @see sys::DynamicLibrary::AddSymbol()
|
|
|
|
*/
|
|
|
|
void LLVMAddSymbol(const char *symbolName, void *symbolValue);
|
|
|
|
|
2013-11-06 17:21:31 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2013-11-07 21:54:24 +08:00
|
|
|
#endif
|