summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX
diff options
context:
space:
mode:
authorSebastian Redl <sebastian.redl@getdesigned.at>2009-10-22 15:07:22 +0000
committerSebastian Redl <sebastian.redl@getdesigned.at>2009-10-22 15:07:22 +0000
commit802f14ccdef1b9c90fef56e185aa7f7e72660c21 (patch)
tree645f66927fcb71d425a27fdbb56436a84343b293 /clang/test/SemaCXX
parent7e8017cce756eed30478f14f0f195830a3690b66 (diff)
downloadbcm5719-llvm-802f14ccdef1b9c90fef56e185aa7f7e72660c21.tar.gz
bcm5719-llvm-802f14ccdef1b9c90fef56e185aa7f7e72660c21.zip
Try to instantiate templates before doing hierarchy checks in static_cast. Fixes PR5261.
llvm-svn: 84860
Diffstat (limited to 'clang/test/SemaCXX')
-rw-r--r--clang/test/SemaCXX/static-cast.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/static-cast.cpp b/clang/test/SemaCXX/static-cast.cpp
index 8db8e33b93c..d816c05e3ee 100644
--- a/clang/test/SemaCXX/static-cast.cpp
+++ b/clang/test/SemaCXX/static-cast.cpp
@@ -133,3 +133,14 @@ void t_529_9()
(void)static_cast<int A::*>((int H::*)0); // expected-error {{ambiguous conversion from pointer to member of derived class 'struct H'}}
(void)static_cast<int A::*>((int F::*)0); // expected-error {{conversion from pointer to member of class 'struct F'}}
}
+
+// PR 5261 - static_cast should instantiate template if possible
+namespace pr5261 {
+ struct base {};
+ template<typename E> struct derived : public base {};
+ template<typename E> struct outer {
+ base *pb;
+ ~outer() { (void)static_cast<derived<E>*>(pb); }
+ };
+ outer<int> EntryList;
+}
OpenPOWER on IntegriCloud