clang 20.0.0git
ModuleBuilder.h
Go to the documentation of this file.
1//===--- CodeGen/ModuleBuilder.h - Build LLVM from ASTs ---------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file defines the ModuleBuilder interface.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_CLANG_CODEGEN_MODULEBUILDER_H
14#define LLVM_CLANG_CODEGEN_MODULEBUILDER_H
15
17#include "clang/Basic/LLVM.h"
18#include "llvm/ADT/StringRef.h"
19
20namespace llvm {
21 class Constant;
22 class LLVMContext;
23 class Module;
24 class StringRef;
25
26 namespace vfs {
27 class FileSystem;
28 }
29}
30
31// Prefix of the name of the artificial inline frame.
32inline constexpr llvm::StringRef ClangTrapPrefix = "__clang_trap_msg";
33
34namespace clang {
35 class CodeGenOptions;
36 class CoverageSourceInfo;
37 class Decl;
38 class DiagnosticsEngine;
39 class GlobalDecl;
40 class HeaderSearchOptions;
41 class LangOptions;
42 class PreprocessorOptions;
43
44namespace CodeGen {
45 class CodeGenModule;
46 class CGDebugInfo;
47}
48
49/// The primary public interface to the Clang code generator.
50///
51/// This is not really an abstract interface.
52class CodeGenerator : public ASTConsumer {
53 virtual void anchor();
54
55public:
56 /// Return an opaque reference to the CodeGenModule object, which can
57 /// be used in various secondary APIs. It is valid as long as the
58 /// CodeGenerator exists.
60
61 /// Return the module that this code generator is building into.
62 ///
63 /// This may return null after HandleTranslationUnit is called;
64 /// this signifies that there was an error generating code. A
65 /// diagnostic will have been generated in this case, and the module
66 /// will be deleted.
67 ///
68 /// It will also return null if the module is released.
69 llvm::Module *GetModule();
70
71 /// Release ownership of the module to the caller.
72 ///
73 /// It is illegal to call methods other than GetModule on the
74 /// CodeGenerator after releasing its module.
75 llvm::Module *ReleaseModule();
76
77 /// Return debug info code generator.
79
80 /// Given a mangled name, return a declaration which mangles that way
81 /// which has been added to this code generator via a Handle method.
82 ///
83 /// This may return null if there was no matching declaration.
84 const Decl *GetDeclForMangledName(llvm::StringRef MangledName);
85
86 /// Given a global declaration, return a mangled name for this declaration
87 /// which has been added to this code generator via a Handle method.
88 llvm::StringRef GetMangledName(GlobalDecl GD);
89
90 /// Return the LLVM address of the given global entity.
91 ///
92 /// \param isForDefinition If true, the caller intends to define the
93 /// entity; the object returned will be an llvm::GlobalValue of
94 /// some sort. If false, the caller just intends to use the entity;
95 /// the object returned may be any sort of constant value, and the
96 /// code generator will schedule the entity for emission if a
97 /// definition has been registered with this code generator.
98 llvm::Constant *GetAddrOfGlobal(GlobalDecl decl, bool isForDefinition);
99
100 /// Create a new \c llvm::Module after calling HandleTranslationUnit. This
101 /// enable codegen in interactive processing environments.
102 llvm::Module* StartModule(llvm::StringRef ModuleName, llvm::LLVMContext &C);
103};
104
105/// CreateLLVMCodeGen - Create a CodeGenerator instance.
106/// It is the responsibility of the caller to call delete on
107/// the allocated CodeGenerator instance.
109 llvm::StringRef ModuleName,
111 const HeaderSearchOptions &HeaderSearchOpts,
112 const PreprocessorOptions &PreprocessorOpts,
113 const CodeGenOptions &CGO,
114 llvm::LLVMContext &C,
115 CoverageSourceInfo *CoverageInfo = nullptr);
116
117} // end namespace clang
118
119#endif
Forward-declares and imports various common LLVM datatypes that clang wants to use unqualified.
constexpr llvm::StringRef ClangTrapPrefix
Definition: ModuleBuilder.h:32
ASTConsumer - This is an abstract interface that should be implemented by clients that read ASTs.
Definition: ASTConsumer.h:34
CodeGenOptions - Track various options which control how the code is optimized and passed to the back...
This class gathers all debug information during compilation and is responsible for emitting to llvm g...
Definition: CGDebugInfo.h:58
This class organizes the cross-function state that is used while generating LLVM code.
The primary public interface to the Clang code generator.
Definition: ModuleBuilder.h:52
llvm::Module * ReleaseModule()
Release ownership of the module to the caller.
const Decl * GetDeclForMangledName(llvm::StringRef MangledName)
Given a mangled name, return a declaration which mangles that way which has been added to this code g...
llvm::Module * StartModule(llvm::StringRef ModuleName, llvm::LLVMContext &C)
Create a new llvm::Module after calling HandleTranslationUnit.
llvm::Constant * GetAddrOfGlobal(GlobalDecl decl, bool isForDefinition)
Return the LLVM address of the given global entity.
llvm::StringRef GetMangledName(GlobalDecl GD)
Given a global declaration, return a mangled name for this declaration which has been added to this c...
CodeGen::CGDebugInfo * getCGDebugInfo()
Return debug info code generator.
CodeGen::CodeGenModule & CGM()
Return an opaque reference to the CodeGenModule object, which can be used in various secondary APIs.
llvm::Module * GetModule()
Return the module that this code generator is building into.
Stores additional source code information like skipped ranges which is required by the coverage mappi...
Decl - This represents one declaration (or definition), e.g.
Definition: DeclBase.h:86
Concrete class used by the front-end to report problems and issues.
Definition: Diagnostic.h:192
GlobalDecl - represents a global declaration.
Definition: GlobalDecl.h:56
HeaderSearchOptions - Helper class for storing options related to the initialization of the HeaderSea...
PreprocessorOptions - This class is used for passing the various options used in preprocessor initial...
const internal::VariadicAllOfMatcher< Decl > decl
Matches declarations.
The JSON file list parser is used to communicate input to InstallAPI.
CodeGenerator * CreateLLVMCodeGen(DiagnosticsEngine &Diags, llvm::StringRef ModuleName, IntrusiveRefCntPtr< llvm::vfs::FileSystem > FS, const HeaderSearchOptions &HeaderSearchOpts, const PreprocessorOptions &PreprocessorOpts, const CodeGenOptions &CGO, llvm::LLVMContext &C, CoverageSourceInfo *CoverageInfo=nullptr)
CreateLLVMCodeGen - Create a CodeGenerator instance.
@ Module
Module linkage, which indicates that the entity can be referred to from other translation units withi...
Diagnostic wrappers for TextAPI types for error reporting.
Definition: Dominators.h:30