(*===-- llvm_bitreader.mli - LLVM OCaml Interface -------------*- OCaml -*-===* * * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. * See https://llvm.org/LICENSE.txt for license information. * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception * *===----------------------------------------------------------------------===*) (** Bitcode reader. This interface provides an OCaml API for the LLVM bitcode reader, the classes in the Bitreader library. *) exception Error of string (** [get_module context mb] reads the bitcode for a new module [m] from the memory buffer [mb] in the context [context]. Returns [m] if successful, or raises [Error msg] otherwise, where [msg] is a description of the error encountered. If parsing succeeds, ownership of [mb] is transferred to the returned module (for lazy deserialization); the caller must not dispose [mb]. If parsing fails, ownership is retained by the caller, which must dispose it. See the function [llvm::getBitcodeModule]. *) val get_module : Llvm.llcontext -> Llvm.llmemorybuffer -> Llvm.llmodule (** [parse_bitcode context mb] parses the bitcode for a new module [m] from the memory buffer [mb] in the context [context]. Returns [m] if successful, or raises [Error msg] otherwise, where [msg] is a description of the error encountered. This function does not take ownership of [mb]; the caller should dispose it (see {!Llvm.MemoryBuffer.dispose}) when it is no longer needed. See the function [llvm::ParseBitcodeFile]. *) val parse_bitcode : Llvm.llcontext -> Llvm.llmemorybuffer -> Llvm.llmodule