diff options
author | Ted Kremenek <kremenek@apple.com> | 2008-08-07 19:47:41 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2008-08-07 19:47:41 +0000 |
commit | 7db4f60b2654c10835dea950dce71f6206d04a2e (patch) | |
tree | 91db34301b9503b739a3d3866aee5345d8386618 /clang/lib/CodeGen/ModuleBuilder.cpp | |
parent | 02ff450f1332a67c005bbe87cfc7f98f772b6e9c (diff) | |
download | llvm-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.cpp | 19 |
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(); + }; }; } |