blob: 797d03179ab3e991e065aa99dc26e4bedc59f9cd [file] [log] [blame]
Gordon Henriksen8b94a142007-09-18 03:18:57 +00001/*===-- llvm-c/BitWriter.h - BitWriter Library C Interface ------*- C++ -*-===*\
2|* *|
3|* The LLVM Compiler Infrastructure *|
4|* *|
Chris Lattner7ed47a12007-12-29 19:59:42 +00005|* This file is distributed under the University of Illinois Open Source *|
6|* License. See LICENSE.TXT for details. *|
Gordon Henriksen8b94a142007-09-18 03:18:57 +00007|* *|
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
Stephen Hines37ed9c12014-12-01 14:51:49 -080019#ifndef LLVM_C_BITWRITER_H
20#define LLVM_C_BITWRITER_H
Gordon Henriksen8b94a142007-09-18 03:18:57 +000021
Pirama Arumuga Nainarf3ef5332016-03-03 15:48:50 -080022#include "llvm-c/Types.h"
Gordon Henriksen8b94a142007-09-18 03:18:57 +000023
24#ifdef __cplusplus
25extern "C" {
26#endif
27
Gregory Szorc6244b512012-03-21 03:54:29 +000028/**
29 * @defgroup LLVMCBitWriter Bit Writer
30 * @ingroup LLVMC
31 *
32 * @{
33 */
Gordon Henriksen8b94a142007-09-18 03:18:57 +000034
35/*===-- Operations on modules ---------------------------------------------===*/
36
NAKAMURA Takumie21c3132013-10-23 17:56:29 +000037/** Writes a module to the specified path. Returns 0 on success. */
Gordon Henriksen8b94a142007-09-18 03:18:57 +000038int LLVMWriteBitcodeToFile(LLVMModuleRef M, const char *Path);
39
Erick Tryzelaare6230502010-03-06 00:30:06 +000040/** 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
NAKAMURA Takumie21c3132013-10-23 17:56:29 +000045 descriptor. Returns 0 on success. Closes the Handle. */
Erick Tryzelaare6230502010-03-06 00:30:06 +000046int LLVMWriteBitcodeToFileHandle(LLVMModuleRef M, int Handle);
Gordon Henriksen8b94a142007-09-18 03:18:57 +000047
Stephen Hines37ed9c12014-12-01 14:51:49 -080048/** Writes a module to a new memory buffer and returns it. */
49LLVMMemoryBufferRef LLVMWriteBitcodeToMemoryBuffer(LLVMModuleRef M);
50
Gregory Szorc6244b512012-03-21 03:54:29 +000051/**
52 * @}
53 */
54
Gordon Henriksen8b94a142007-09-18 03:18:57 +000055#ifdef __cplusplus
56}
57#endif
58
59#endif