//===-- Parser.h - Parser for LLVM IR text assembly files -------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // These classes are implemented by the lib/AsmParser library. // //===----------------------------------------------------------------------===// #ifndef LLVM_ASMPARSER_PARSER_H #define LLVM_ASMPARSER_PARSER_H #include "llvm/Support/MemoryBuffer.h" namespace llvm { class Constant; class LLVMContext; class Module; struct SlotMapping; class SMDiagnostic; class Type; /// This function is the main interface to the LLVM Assembly Parser. It parses /// an ASCII file that (presumably) contains LLVM Assembly code. It returns a /// Module (intermediate representation) with the corresponding features. Note /// that this does not verify that the generated Module is valid, so you should /// run the verifier after parsing the file to check that it is okay. /// \brief Parse LLVM Assembly from a file /// \param Filename The name of the file to parse /// \param Error Error result info. /// \param Context Context in which to allocate globals info. /// \param Slots The optional slot mapping that will be initialized during /// parsing. /// \param UpgradeDebugInfo Run UpgradeDebugInfo, which runs the Verifier. /// This option should only be set to false by llvm-as /// for use inside the LLVM testuite! /// \param DataLayoutString Override datalayout in the llvm assembly. std::unique_ptr<Module> parseAssemblyFile(StringRef Filename, SMDiagnostic &Error, LLVMContext &Context, SlotMapping *Slots = nullptr, bool UpgradeDebugInfo = true, StringRef DataLayoutString = ""); /// The function is a secondary interface to the LLVM Assembly Parser. It parses /// an ASCII string that (presumably) contains LLVM Assembly code. It returns a /// Module (intermediate representation) with the corresponding features. Note /// that this does not verify that the generated Module is valid, so you should /// run the verifier after parsing the file to check that it is okay. /// \brief Parse LLVM Assembly from a string /// \param AsmString The string containing assembly /// \param Error Error result info. /// \param Context Context in which to allocate globals info. /// \param Slots The optional slot mapping that will be initialized during /// parsing. /// \param UpgradeDebugInfo Run UpgradeDebugInfo, which runs the Verifier. /// This option should only be set to false by llvm-as /// for use inside the LLVM testuite! /// \param DataLayoutString Override datalayout in the llvm assembly. std::unique_ptr<Module> parseAssemblyString(StringRef AsmString, SMDiagnostic &Error, LLVMContext &Context, SlotMapping *Slots = nullptr, bool UpgradeDebugInfo = true, StringRef DataLayoutString = ""); /// parseAssemblyFile and parseAssemblyString are wrappers around this function. /// \brief Parse LLVM Assembly from a MemoryBuffer. /// \param F The MemoryBuffer containing assembly /// \param Err Error result info. /// \param Slots The optional slot mapping that will be initialized during /// parsing. /// \param UpgradeDebugInfo Run UpgradeDebugInfo, which runs the Verifier. /// This option should only be set to false by llvm-as /// for use inside the LLVM testuite! /// \param DataLayoutString Override datalayout in the llvm assembly. std::unique_ptr<Module> parseAssembly(MemoryBufferRef F, SMDiagnostic &Err, LLVMContext &Context, SlotMapping *Slots = nullptr, bool UpgradeDebugInfo = true, StringRef DataLayoutString = ""); /// This function is the low-level interface to the LLVM Assembly Parser. /// This is kept as an independent function instead of being inlined into /// parseAssembly for the convenience of interactive users that want to add /// recently parsed bits to an existing module. /// /// \param F The MemoryBuffer containing assembly /// \param M The module to add data to. /// \param Err Error result info. /// \param Slots The optional slot mapping that will be initialized during /// parsing. /// \return true on error. /// \param UpgradeDebugInfo Run UpgradeDebugInfo, which runs the Verifier. /// This option should only be set to false by llvm-as /// for use inside the LLVM testuite! /// \param DataLayoutString Override datalayout in the llvm assembly. bool parseAssemblyInto(MemoryBufferRef F, Module &M, SMDiagnostic &Err, SlotMapping *Slots = nullptr, bool UpgradeDebugInfo = true, StringRef DataLayoutString = ""); /// Parse a type and a constant value in the given string. /// /// The constant value can be any LLVM constant, including a constant /// expression. /// /// \param Slots The optional slot mapping that will restore the parsing state /// of the module. /// \return null on error. Constant *parseConstantValue(StringRef Asm, SMDiagnostic &Err, const Module &M, const SlotMapping *Slots = nullptr); /// Parse a type in the given string. /// /// \param Slots The optional slot mapping that will restore the parsing state /// of the module. /// \return null on error. Type *parseType(StringRef Asm, SMDiagnostic &Err, const Module &M, const SlotMapping *Slots = nullptr); /// Parse a string \p Asm that starts with a type. /// \p Read[out] gives the number of characters that have been read to parse /// the type in \p Asm. /// /// \param Slots The optional slot mapping that will restore the parsing state /// of the module. /// \return null on error. Type *parseTypeAtBeginning(StringRef Asm, unsigned &Read, SMDiagnostic &Err, const Module &M, const SlotMapping *Slots = nullptr); } // End llvm namespace #endif