[docs] Add LICENSE.txt to the root of the mono-repo
[llvm-project.git] / llvm / include / llvm-c / Support.h
blob17657861b32b92914a55cb0eff54f3f783015799
1 /*===-- llvm-c/Support.h - Support C Interface --------------------*- C -*-===*\
2 |* *|
3 |* Part of the LLVM Project, under the Apache License v2.0 with LLVM *|
4 |* Exceptions. *|
5 |* See https://llvm.org/LICENSE.txt for license information. *|
6 |* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception *|
7 |* *|
8 |*===----------------------------------------------------------------------===*|
9 |* *|
10 |* This file defines the C interface to the LLVM support library. *|
11 |* *|
12 \*===----------------------------------------------------------------------===*/
14 #ifndef LLVM_C_SUPPORT_H
15 #define LLVM_C_SUPPORT_H
17 #include "llvm-c/DataTypes.h"
18 #include "llvm-c/ExternC.h"
19 #include "llvm-c/Types.h"
21 LLVM_C_EXTERN_C_BEGIN
23 /**
24 * @addtogroup LLVMCCore
26 * @{
29 /**
30 * This function permanently loads the dynamic library at the given path.
31 * It is safe to call this function multiple times for the same library.
33 * @see sys::DynamicLibrary::LoadLibraryPermanently()
35 LLVMBool LLVMLoadLibraryPermanently(const char* Filename);
37 /**
38 * This function parses the given arguments using the LLVM command line parser.
39 * Note that the only stable thing about this function is its signature; you
40 * cannot rely on any particular set of command line arguments being interpreted
41 * the same way across LLVM versions.
43 * @see llvm::cl::ParseCommandLineOptions()
45 void LLVMParseCommandLineOptions(int argc, const char *const *argv,
46 const char *Overview);
48 /**
49 * This function will search through all previously loaded dynamic
50 * libraries for the symbol \p symbolName. If it is found, the address of
51 * that symbol is returned. If not, null is returned.
53 * @see sys::DynamicLibrary::SearchForAddressOfSymbol()
55 void *LLVMSearchForAddressOfSymbol(const char *symbolName);
57 /**
58 * This functions permanently adds the symbol \p symbolName with the
59 * value \p symbolValue. These symbols are searched before any
60 * libraries.
62 * @see sys::DynamicLibrary::AddSymbol()
64 void LLVMAddSymbol(const char *symbolName, void *symbolValue);
66 /**
67 * @}
70 LLVM_C_EXTERN_C_END
72 #endif