diff options
| author | Sebastian Redl <sebastian.redl@getdesigned.at> | 2009-10-22 15:07:22 +0000 |
|---|---|---|
| committer | Sebastian Redl <sebastian.redl@getdesigned.at> | 2009-10-22 15:07:22 +0000 |
| commit | 802f14ccdef1b9c90fef56e185aa7f7e72660c21 (patch) | |
| tree | 645f66927fcb71d425a27fdbb56436a84343b293 /clang/test/SemaCXX/static-cast.cpp | |
| parent | 7e8017cce756eed30478f14f0f195830a3690b66 (diff) | |
| download | bcm5719-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/static-cast.cpp')
| -rw-r--r-- | clang/test/SemaCXX/static-cast.cpp | 11 |
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; +} |

