blob: 187051555b9a29139fa070d9a7f3ad97950ee8e9 [file] [log] [blame]
Andrew Scull5e1ddfa2018-08-14 10:06:54 +01001/*===-- llvm-c/BitWriter.h - BitWriter Library C Interface ------*- C++ -*-===*\
2|* *|
Andrew Walbran16937d02019-10-22 13:54:20 +01003|* 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 *|
Andrew Scull5e1ddfa2018-08-14 10:06:54 +01007|* *|
8|*===----------------------------------------------------------------------===*|
9|* *|
10|* This header declares the C interface to libLLVMBitWriter.a, which *|
11|* implements output of the LLVM bitcode format. *|
12|* *|
13|* Many exotic languages can interoperate with C code but have a harder time *|
14|* with C++ due to name mangling. So in addition to C, this interface enables *|
15|* tools written in such languages. *|
16|* *|
17\*===----------------------------------------------------------------------===*/
18
19#ifndef LLVM_C_BITWRITER_H
20#define LLVM_C_BITWRITER_H
21
22#include "llvm-c/Types.h"
23
24#ifdef __cplusplus
25extern "C" {
26#endif
27
28/**
29 * @defgroup LLVMCBitWriter Bit Writer
30 * @ingroup LLVMC
31 *
32 * @{
33 */
34
35/*===-- Operations on modules ---------------------------------------------===*/
36
37/** Writes a module to the specified path. Returns 0 on success. */
38int LLVMWriteBitcodeToFile(LLVMModuleRef M, const char *Path);
39
40/** Writes a module to an open file descriptor. Returns 0 on success. */
41int LLVMWriteBitcodeToFD(LLVMModuleRef M, int FD, int ShouldClose,
42 int Unbuffered);
43
44/** Deprecated for LLVMWriteBitcodeToFD. Writes a module to an open file
45 descriptor. Returns 0 on success. Closes the Handle. */
46int LLVMWriteBitcodeToFileHandle(LLVMModuleRef M, int Handle);
47
48/** Writes a module to a new memory buffer and returns it. */
49LLVMMemoryBufferRef LLVMWriteBitcodeToMemoryBuffer(LLVMModuleRef M);
50
51/**
52 * @}
53 */
54
55#ifdef __cplusplus
56}
57#endif
58
59#endif