aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/CodeGen/ModuleBuilder.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2012-03-05 10:54:55 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2012-03-05 10:54:55 +0000
commit189fa748ec9e05820f7c5df8ff00aa3c7bc0546c (patch)
tree20583052017fe002b904ee90abb1f5cde9e6a733 /clang/lib/CodeGen/ModuleBuilder.cpp
parent08a47fd708680fc67f8c1c80f64379b35d6f472c (diff)
downloadllvm-189fa748ec9e05820f7c5df8ff00aa3c7bc0546c.zip
llvm-189fa748ec9e05820f7c5df8ff00aa3c7bc0546c.tar.gz
llvm-189fa748ec9e05820f7c5df8ff00aa3c7bc0546c.tar.bz2
Fix a small difference in sema and codegen views of what needs to be output.
In the included testcase, soma thinks that we already have a definition after we see the out of line decl. Codegen puts it in a deferred list, to be output if a use is seen. This would break when we saw an explicit template instantiation definition, since codegen would not be notified. This patch adds a method to the consumer interface so that soma can notify codegen that this decl is now required. llvm-svn: 152024
Diffstat (limited to 'clang/lib/CodeGen/ModuleBuilder.cpp')
-rw-r--r--clang/lib/CodeGen/ModuleBuilder.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/ModuleBuilder.cpp b/clang/lib/CodeGen/ModuleBuilder.cpp
index ddbe27b..f81f623 100644
--- a/clang/lib/CodeGen/ModuleBuilder.cpp
+++ b/clang/lib/CodeGen/ModuleBuilder.cpp
@@ -59,6 +59,10 @@ namespace {
*M, *TD, Diags));
}
+ virtual void MarkVarRequired(VarDecl *VD) {
+ Builder->MarkVarRequired(VD);
+ }
+
virtual bool HandleTopLevelDecl(DeclGroupRef DG) {
// Make sure to emit all elements of a Decl.
for (DeclGroupRef::iterator I = DG.begin(), E = DG.end(); I != E; ++I)