Home | History | Annotate | Download | only in llvm-c
      1 /*===-- llvm-c/BitWriter.h - BitWriter Library C Interface ------*- C++ -*-===*\
      2 |*                                                                            *|
      3 |*                     The LLVM Compiler Infrastructure                       *|
      4 |*                                                                            *|
      5 |* This file is distributed under the University of Illinois Open Source      *|
      6 |* License. See LICENSE.TXT for details.                                      *|
      7 |*                                                                            *|
      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
     25 extern "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. */
     38 int LLVMWriteBitcodeToFile(LLVMModuleRef M, const char *Path);
     39 
     40 /** Writes a module to an open file descriptor. Returns 0 on success. */
     41 int 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. */
     46 int LLVMWriteBitcodeToFileHandle(LLVMModuleRef M, int Handle);
     47 
     48 /** Writes a module to a new memory buffer and returns it. */
     49 LLVMMemoryBufferRef LLVMWriteBitcodeToMemoryBuffer(LLVMModuleRef M);
     50 
     51 /**
     52  * @}
     53  */
     54 
     55 #ifdef __cplusplus
     56 }
     57 #endif
     58 
     59 #endif
     60