mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 18:20:39 +00:00 
			
		
		
		
	This gives a lot of love to the docs for the C API. Like Clang's documentation, the C API is now organized into a Doxygen "module" (LLVMC). Each C header file is a child of the main module. Some modules (like Core) have a hierarchy of there own. The produced documentation is thus better organized (before everything was in one monolithic list). This patch also includes a lot of new documentation for APIs in Core.h. It doesn't document them all, but is better than none. Function docs are missing @param and @return annotation, but the documentation body now commonly provides help details (like the expected llvm::Value sub-type to expect). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@153157 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			77 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*===-- llvm-c/BitReader.h - BitReader Library 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 header declares the C interface to libLLVMBitReader.a, which          *|
 | |
| |* implements input of the LLVM bitcode format.                               *|
 | |
| |*                                                                            *|
 | |
| |* Many exotic languages can interoperate with C code but have a harder time  *|
 | |
| |* with C++ due to name mangling. So in addition to C, this interface enables *|
 | |
| |* tools written in such languages.                                           *|
 | |
| |*                                                                            *|
 | |
| \*===----------------------------------------------------------------------===*/
 | |
| 
 | |
| #ifndef LLVM_C_BITCODEREADER_H
 | |
| #define LLVM_C_BITCODEREADER_H
 | |
| 
 | |
| #include "llvm-c/Core.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /**
 | |
|  * @defgroup LLVMCBitReader Bit Reader
 | |
|  * @ingroup LLVMC
 | |
|  *
 | |
|  * @{
 | |
|  */
 | |
| 
 | |
| /* Builds a module from the bitcode in the specified memory buffer, returning a
 | |
|    reference to the module via the OutModule parameter. Returns 0 on success.
 | |
|    Optionally returns a human-readable error message via OutMessage. */ 
 | |
| LLVMBool LLVMParseBitcode(LLVMMemoryBufferRef MemBuf,
 | |
|                           LLVMModuleRef *OutModule, char **OutMessage);
 | |
| 
 | |
| LLVMBool LLVMParseBitcodeInContext(LLVMContextRef ContextRef,
 | |
|                                    LLVMMemoryBufferRef MemBuf,
 | |
|                                    LLVMModuleRef *OutModule, char **OutMessage);
 | |
| 
 | |
| /** Reads a module from the specified path, returning via the OutMP parameter
 | |
|     a module provider which performs lazy deserialization. Returns 0 on success.
 | |
|     Optionally returns a human-readable error message via OutMessage. */ 
 | |
| LLVMBool LLVMGetBitcodeModuleInContext(LLVMContextRef ContextRef,
 | |
|                                        LLVMMemoryBufferRef MemBuf,
 | |
|                                        LLVMModuleRef *OutM,
 | |
|                                        char **OutMessage);
 | |
| 
 | |
| LLVMBool LLVMGetBitcodeModule(LLVMMemoryBufferRef MemBuf, LLVMModuleRef *OutM,
 | |
|                               char **OutMessage);
 | |
| 
 | |
| 
 | |
| /** Deprecated: Use LLVMGetBitcodeModuleInContext instead. */
 | |
| LLVMBool LLVMGetBitcodeModuleProviderInContext(LLVMContextRef ContextRef,
 | |
|                                                LLVMMemoryBufferRef MemBuf,
 | |
|                                                LLVMModuleProviderRef *OutMP,
 | |
|                                                char **OutMessage);
 | |
| 
 | |
| /** Deprecated: Use LLVMGetBitcodeModule instead. */
 | |
| LLVMBool LLVMGetBitcodeModuleProvider(LLVMMemoryBufferRef MemBuf,
 | |
|                                       LLVMModuleProviderRef *OutMP,
 | |
|                                       char **OutMessage);
 | |
| 
 | |
| /**
 | |
|  * @}
 | |
|  */
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif
 |