blob: 03771e187ee2c020ee70ae946a8ddded3f80c569 [file] [log] [blame]
Reid Spencer5f016e22007-07-11 17:01:13 +00001//===--- ModuleBuilder.cpp - Emit LLVM Code from ASTs ---------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner0bc735f2007-12-29 19:59:25 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Reid Spencer5f016e22007-07-11 17:01:13 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This builds an AST and converts it to LLVM Code.
11//
12//===----------------------------------------------------------------------===//
13
14#include "clang/CodeGen/ModuleBuilder.h"
David Blaikie658cd2c2013-07-13 21:08:14 +000015#include "CGDebugInfo.h"
Stephen Hines651f13c2014-04-23 16:59:28 -070016#include "CodeGenModule.h"
Chris Lattner8ee3c032008-02-06 02:01:47 +000017#include "clang/AST/ASTContext.h"
Daniel Dunbare91593e2008-08-11 04:54:23 +000018#include "clang/AST/DeclObjC.h"
19#include "clang/AST/Expr.h"
Chris Lattner8ee3c032008-02-06 02:01:47 +000020#include "clang/Basic/Diagnostic.h"
21#include "clang/Basic/TargetInfo.h"
Chandler Carruth55fc8732012-12-04 09:13:33 +000022#include "clang/Frontend/CodeGenOptions.h"
Reid Kleckner3190ca92013-05-08 13:44:39 +000023#include "llvm/ADT/StringRef.h"
Chandler Carruth3b844ba2013-01-02 11:45:17 +000024#include "llvm/IR/DataLayout.h"
25#include "llvm/IR/LLVMContext.h"
26#include "llvm/IR/Module.h"
Stephen Hines651f13c2014-04-23 16:59:28 -070027#include <memory>
Chris Lattnerbd360642009-03-26 05:00:52 +000028using namespace clang;
Ted Kremenek815c78f2008-08-05 18:50:11 +000029
Chris Lattner8ee3c032008-02-06 02:01:47 +000030namespace {
Benjamin Kramer85b45212009-11-28 19:45:26 +000031 class CodeGeneratorImpl : public CodeGenerator {
David Blaikied6471f72011-09-25 23:23:43 +000032 DiagnosticsEngine &Diags;
Stephen Hines651f13c2014-04-23 16:59:28 -070033 std::unique_ptr<const llvm::DataLayout> TD;
Chris Lattner8ee3c032008-02-06 02:01:47 +000034 ASTContext *Ctx;
Chandler Carruth2811ccf2009-11-12 17:24:48 +000035 const CodeGenOptions CodeGenOpts; // Intentionally copied in.
Stephen Hines176edba2014-12-01 14:53:08 -080036
37 unsigned HandlingTopLevelDecls;
38 struct HandlingTopLevelDeclRAII {
39 CodeGeneratorImpl &Self;
40 HandlingTopLevelDeclRAII(CodeGeneratorImpl &Self) : Self(Self) {
41 ++Self.HandlingTopLevelDecls;
42 }
43 ~HandlingTopLevelDeclRAII() {
44 if (--Self.HandlingTopLevelDecls == 0)
45 Self.EmitDeferredDecls();
46 }
47 };
48
49 CoverageSourceInfo *CoverageInfo;
50
Chris Lattner8ee3c032008-02-06 02:01:47 +000051 protected:
Stephen Hines651f13c2014-04-23 16:59:28 -070052 std::unique_ptr<llvm::Module> M;
53 std::unique_ptr<CodeGen::CodeGenModule> Builder;
54
Stephen Hines0e2c34f2015-03-23 12:09:02 -070055 private:
56 SmallVector<CXXMethodDecl *, 8> DeferredInlineMethodDefinitions;
57
Chris Lattner8ee3c032008-02-06 02:01:47 +000058 public:
David Blaikied6471f72011-09-25 23:23:43 +000059 CodeGeneratorImpl(DiagnosticsEngine &diags, const std::string& ModuleName,
Stephen Hines176edba2014-12-01 14:53:08 -080060 const CodeGenOptions &CGO, llvm::LLVMContext& C,
61 CoverageSourceInfo *CoverageInfo = nullptr)
Stephen Hines0e2c34f2015-03-23 12:09:02 -070062 : Diags(diags), Ctx(nullptr), CodeGenOpts(CGO), HandlingTopLevelDecls(0),
Stephen Hines176edba2014-12-01 14:53:08 -080063 CoverageInfo(CoverageInfo),
Bill Wendlinge1092df2013-02-14 08:09:20 +000064 M(new llvm::Module(ModuleName, C)) {}
Mike Stump1eb44332009-09-09 15:08:12 +000065
Stephen Hines0e2c34f2015-03-23 12:09:02 -070066 virtual ~CodeGeneratorImpl() {
67 // There should normally not be any leftover inline method definitions.
68 assert(DeferredInlineMethodDefinitions.empty() ||
69 Diags.hasErrorOccurred());
70 }
Mike Stump1eb44332009-09-09 15:08:12 +000071
Stephen Hines651f13c2014-04-23 16:59:28 -070072 llvm::Module* GetModule() override {
Daniel Dunbard8c0ea12008-10-21 19:55:09 +000073 return M.get();
74 }
Mike Stump1eb44332009-09-09 15:08:12 +000075
Stephen Hinesc568f1e2014-07-21 00:47:37 -070076 const Decl *GetDeclForMangledName(StringRef MangledName) override {
77 GlobalDecl Result;
78 if (!Builder->lookupRepresentativeDecl(MangledName, Result))
79 return nullptr;
80 const Decl *D = Result.getCanonicalDecl().getDecl();
81 if (auto FD = dyn_cast<FunctionDecl>(D)) {
82 if (FD->hasBody(FD))
83 return FD;
84 } else if (auto TD = dyn_cast<TagDecl>(D)) {
85 if (auto Def = TD->getDefinition())
86 return Def;
87 }
88 return D;
89 }
90
Stephen Hines651f13c2014-04-23 16:59:28 -070091 llvm::Module *ReleaseModule() override { return M.release(); }
Mike Stump1eb44332009-09-09 15:08:12 +000092
Stephen Hines651f13c2014-04-23 16:59:28 -070093 void Initialize(ASTContext &Context) override {
Chris Lattner8ee3c032008-02-06 02:01:47 +000094 Ctx = &Context;
Mike Stump1eb44332009-09-09 15:08:12 +000095
Douglas Gregorbcfd1f52011-09-02 00:18:52 +000096 M->setTargetTriple(Ctx->getTargetInfo().getTriple().getTriple());
97 M->setDataLayout(Ctx->getTargetInfo().getTargetDescription());
Stephen Hines0e2c34f2015-03-23 12:09:02 -070098 TD.reset(
99 new llvm::DataLayout(Ctx->getTargetInfo().getTargetDescription()));
John McCall3abae092013-04-16 22:48:20 +0000100 Builder.reset(new CodeGen::CodeGenModule(Context, CodeGenOpts, *M, *TD,
Stephen Hines176edba2014-12-01 14:53:08 -0800101 Diags, CoverageInfo));
Hans Wennborgb3574792013-08-08 00:17:41 +0000102
103 for (size_t i = 0, e = CodeGenOpts.DependentLibraries.size(); i < e; ++i)
104 HandleDependentLibrary(CodeGenOpts.DependentLibraries[i]);
Chris Lattner8ee3c032008-02-06 02:01:47 +0000105 }
Mike Stump1eb44332009-09-09 15:08:12 +0000106
Stephen Hines651f13c2014-04-23 16:59:28 -0700107 void HandleCXXStaticMemberVarInstantiation(VarDecl *VD) override {
David Blaikie0a1c8622013-08-19 21:02:26 +0000108 if (Diags.hasErrorOccurred())
109 return;
110
Rafael Espindola02503932012-03-08 15:51:03 +0000111 Builder->HandleCXXStaticMemberVarInstantiation(VD);
Rafael Espindola234fe652012-03-05 10:54:55 +0000112 }
113
Stephen Hines651f13c2014-04-23 16:59:28 -0700114 bool HandleTopLevelDecl(DeclGroupRef DG) override {
David Blaikie0a1c8622013-08-19 21:02:26 +0000115 if (Diags.hasErrorOccurred())
116 return true;
117
Stephen Hines176edba2014-12-01 14:53:08 -0800118 HandlingTopLevelDeclRAII HandlingDecl(*this);
119
Douglas Gregor4afa39d2009-01-20 01:17:11 +0000120 // Make sure to emit all elements of a Decl.
Chris Lattner682bf922009-03-29 16:50:03 +0000121 for (DeclGroupRef::iterator I = DG.begin(), E = DG.end(); I != E; ++I)
122 Builder->EmitTopLevelDecl(*I);
Stephen Hinesc568f1e2014-07-21 00:47:37 -0700123
Argyrios Kyrtzidis88c25962011-11-18 00:26:59 +0000124 return true;
Chris Lattner8ee3c032008-02-06 02:01:47 +0000125 }
Daniel Dunbar41071de2008-08-15 23:26:23 +0000126
Stephen Hines176edba2014-12-01 14:53:08 -0800127 void EmitDeferredDecls() {
128 if (DeferredInlineMethodDefinitions.empty())
129 return;
130
131 // Emit any deferred inline method definitions. Note that more deferred
132 // methods may be added during this loop, since ASTConsumer callbacks
133 // can be invoked if AST inspection results in declarations being added.
134 HandlingTopLevelDeclRAII HandlingDecl(*this);
135 for (unsigned I = 0; I != DeferredInlineMethodDefinitions.size(); ++I)
136 Builder->EmitTopLevelDecl(DeferredInlineMethodDefinitions[I]);
137 DeferredInlineMethodDefinitions.clear();
138 }
139
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700140 void HandleInlineMethodDefinition(CXXMethodDecl *D) override {
141 if (Diags.hasErrorOccurred())
142 return;
143
144 assert(D->doesThisDeclarationHaveABody());
145
Stephen Hinesc568f1e2014-07-21 00:47:37 -0700146 // We may want to emit this definition. However, that decision might be
147 // based on computing the linkage, and we have to defer that in case we
148 // are inside of something that will change the method's final linkage,
149 // e.g.
150 // typedef struct {
151 // void bar();
152 // void foo() { bar(); }
153 // } A;
154 DeferredInlineMethodDefinitions.push_back(D);
Stephen Hines176edba2014-12-01 14:53:08 -0800155
156 // Provide some coverage mapping even for methods that aren't emitted.
157 // Don't do this for templated classes though, as they may not be
158 // instantiable.
159 if (!D->getParent()->getDescribedClassTemplate())
160 Builder->AddDeferredUnusedCoverageMapping(D);
Stephen Hines6bcf27b2014-05-29 04:14:42 -0700161 }
162
Chris Lattner9eee0f82008-02-06 04:51:19 +0000163 /// HandleTagDeclDefinition - This callback is invoked each time a TagDecl
Chris Lattner682bf922009-03-29 16:50:03 +0000164 /// to (e.g. struct, union, enum, class) is completed. This allows the
165 /// client hack on the type, which can occur at any point in the file
166 /// (because these can be defined in declspecs).
Stephen Hines651f13c2014-04-23 16:59:28 -0700167 void HandleTagDeclDefinition(TagDecl *D) override {
David Blaikie0a1c8622013-08-19 21:02:26 +0000168 if (Diags.hasErrorOccurred())
169 return;
170
Chris Lattnerc5b88062008-02-06 05:08:19 +0000171 Builder->UpdateCompletedType(D);
Stephen Hines176edba2014-12-01 14:53:08 -0800172
173 // For MSVC compatibility, treat declarations of static data members with
174 // inline initializers as definitions.
175 if (Ctx->getLangOpts().MSVCCompat) {
176 for (Decl *Member : D->decls()) {
177 if (VarDecl *VD = dyn_cast<VarDecl>(Member)) {
178 if (Ctx->isMSStaticDataMemberInlineDefinition(VD) &&
179 Ctx->DeclMustBeEmitted(VD)) {
180 Builder->EmitGlobal(VD);
181 }
182 }
183 }
184 }
Chris Lattner9eee0f82008-02-06 04:51:19 +0000185 }
Ted Kremenek159346a2008-08-07 19:47:41 +0000186
Stephen Hines651f13c2014-04-23 16:59:28 -0700187 void HandleTagDeclRequiredDefinition(const TagDecl *D) override {
David Blaikie0a1c8622013-08-19 21:02:26 +0000188 if (Diags.hasErrorOccurred())
189 return;
190
David Blaikie658cd2c2013-07-13 21:08:14 +0000191 if (CodeGen::CGDebugInfo *DI = Builder->getModuleDebugInfo())
192 if (const RecordDecl *RD = dyn_cast<RecordDecl>(D))
David Blaikie27804892013-08-15 20:49:17 +0000193 DI->completeRequiredType(RD);
David Blaikie658cd2c2013-07-13 21:08:14 +0000194 }
195
Stephen Hines651f13c2014-04-23 16:59:28 -0700196 void HandleTranslationUnit(ASTContext &Ctx) override {
Ted Kremenek159346a2008-08-07 19:47:41 +0000197 if (Diags.hasErrorOccurred()) {
Stephen Hines651f13c2014-04-23 16:59:28 -0700198 if (Builder)
199 Builder->clear();
Ted Kremenek159346a2008-08-07 19:47:41 +0000200 M.reset();
201 return;
202 }
203
204 if (Builder)
205 Builder->Release();
Daniel Dunbar7177dee2009-12-19 17:50:07 +0000206 }
Douglas Gregorb6c8c8b2009-04-21 17:11:58 +0000207
Stephen Hines651f13c2014-04-23 16:59:28 -0700208 void CompleteTentativeDefinition(VarDecl *D) override {
Douglas Gregorb6c8c8b2009-04-21 17:11:58 +0000209 if (Diags.hasErrorOccurred())
210 return;
211
212 Builder->EmitTentativeDefinition(D);
213 }
Douglas Gregor6fb745b2010-05-13 16:44:06 +0000214
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700215 void HandleVTable(CXXRecordDecl *RD) override {
Douglas Gregor6fb745b2010-05-13 16:44:06 +0000216 if (Diags.hasErrorOccurred())
217 return;
218
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700219 Builder->EmitVTable(RD);
Douglas Gregor6fb745b2010-05-13 16:44:06 +0000220 }
Reid Kleckner3190ca92013-05-08 13:44:39 +0000221
Stephen Hines651f13c2014-04-23 16:59:28 -0700222 void HandleLinkerOptionPragma(llvm::StringRef Opts) override {
Reid Kleckner3190ca92013-05-08 13:44:39 +0000223 Builder->AppendLinkerOptions(Opts);
224 }
225
Stephen Hines651f13c2014-04-23 16:59:28 -0700226 void HandleDetectMismatch(llvm::StringRef Name,
227 llvm::StringRef Value) override {
Aaron Ballmana7ff62f2013-06-04 02:07:14 +0000228 Builder->AddDetectMismatch(Name, Value);
229 }
230
Stephen Hines651f13c2014-04-23 16:59:28 -0700231 void HandleDependentLibrary(llvm::StringRef Lib) override {
Reid Kleckner3190ca92013-05-08 13:44:39 +0000232 Builder->AddDependentLib(Lib);
233 }
Chris Lattner8ee3c032008-02-06 02:01:47 +0000234 };
Reid Spencer5f016e22007-07-11 17:01:13 +0000235}
236
David Blaikie99ba9e32011-12-20 02:48:34 +0000237void CodeGenerator::anchor() { }
238
David Blaikied6471f72011-09-25 23:23:43 +0000239CodeGenerator *clang::CreateLLVMCodeGen(DiagnosticsEngine &Diags,
Ted Kremenek815c78f2008-08-05 18:50:11 +0000240 const std::string& ModuleName,
Chandler Carruth2811ccf2009-11-12 17:24:48 +0000241 const CodeGenOptions &CGO,
Stephen Hines176edba2014-12-01 14:53:08 -0800242 llvm::LLVMContext& C,
243 CoverageSourceInfo *CoverageInfo) {
244 return new CodeGeneratorImpl(Diags, ModuleName, CGO, C, CoverageInfo);
Reid Spencer5f016e22007-07-11 17:01:13 +0000245}