aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/CodeGen/ModuleBuilder.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2008-08-07 19:47:41 +0000
committerTed Kremenek <kremenek@apple.com>2008-08-07 19:47:41 +0000
commit7db4f60b2654c10835dea950dce71f6206d04a2e (patch)
tree91db34301b9503b739a3d3866aee5345d8386618 /clang/lib/CodeGen/ModuleBuilder.cpp
parent02ff450f1332a67c005bbe87cfc7f98f772b6e9c (diff)
downloadllvm-7db4f60b2654c10835dea950dce71f6206d04a2e.zip
llvm-7db4f60b2654c10835dea950dce71f6206d04a2e.tar.gz
llvm-7db4f60b2654c10835dea950dce71f6206d04a2e.tar.bz2
ParseAST now conditionally deletes the passed ASTConsumer.
ModuleBuilder now performs llvmgen in HandleTranslationUnit. This patch follows from the discussion on the following thread on cfe-commits: http://lists.cs.uiuc.edu/pipermail/cfe-commits/Week-of-Mon-20080804/006849.html llvm-svn: 54486
Diffstat (limited to 'clang/lib/CodeGen/ModuleBuilder.cpp')
-rw-r--r--clang/lib/CodeGen/ModuleBuilder.cpp19
1 files changed, 11 insertions, 8 deletions
diff --git a/clang/lib/CodeGen/ModuleBuilder.cpp b/clang/lib/CodeGen/ModuleBuilder.cpp
index 7329ed1d..6ce4e68 100644
--- a/clang/lib/CodeGen/ModuleBuilder.cpp
+++ b/clang/lib/CodeGen/ModuleBuilder.cpp
@@ -49,13 +49,7 @@ namespace {
virtual ~CodeGeneratorImpl() {}
- virtual llvm::Module* ReleaseModule() {
- if (Diags.hasErrorOccurred())
- return 0;
-
- if (Builder)
- Builder->Release();
-
+ virtual llvm::Module* ReleaseModule() {
return M.take();
}
@@ -134,7 +128,16 @@ namespace {
virtual void HandleTagDeclDefinition(TagDecl *D) {
Builder->UpdateCompletedType(D);
}
-
+
+ virtual void HandleTranslationUnit(TranslationUnit& TU) {
+ if (Diags.hasErrorOccurred()) {
+ M.reset();
+ return;
+ }
+
+ if (Builder)
+ Builder->Release();
+ };
};
}