From: Douglas Gregor Date: Mon, 8 Nov 2010 03:58:01 +0000 (+0000) Subject: Add missing test case for PR8230 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=717a2bf760ef1daf74f839eb3c9ad73ad2aa6d60;p=clang Add missing test case for PR8230 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@118402 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/SemaCXX/addr-of-overloaded-function-casting.cpp b/test/SemaCXX/addr-of-overloaded-function-casting.cpp new file mode 100644 index 0000000000..49abdea029 --- /dev/null +++ b/test/SemaCXX/addr-of-overloaded-function-casting.cpp @@ -0,0 +1,57 @@ +// RUN: %clang_cc1 -fsyntax-only -verify %s +void g(); + +void f(); // expected-note 9{{candidate function}} +void f(int); // expected-note 9{{candidate function}} + +template void t(T); // expected-note 3{{candidate function}} +template void t(T*); // expected-note 3{{candidate function}} + +template void u(T); + +int main() +{ + { bool b = (void (&)(char))f; } // expected-error{{does not match required type}} + { bool b = (void (*)(char))f; } // expected-error{{does not match required type}} + + { bool b = (void (&)(int))f; } //ok + { bool b = (void (*)(int))f; } //ok + + { bool b = static_cast(f); } // expected-error{{does not match}} + { bool b = static_cast(f); } // expected-error{{address of overloaded function}} + + { bool b = static_cast(f); } //ok + { bool b = static_cast(f); } //ok + + + { bool b = reinterpret_cast(f); } // expected-error{{cannot resolve}} + { bool b = reinterpret_cast(f); } // expected-error{{cannot resolve}} + + { bool b = reinterpret_cast(g); } //ok + { bool b = static_cast(g); } // expected-error{{not allowed}} + + { bool b = reinterpret_cast(f); } // expected-error{{cannot resolve}} + { bool b = reinterpret_cast(f); } // expected-error{{cannot resolve}} + + { bool b = (int (&)(char))t; } // expected-error{{does not match}} + { bool b = (int (*)(char))t; } // expected-error{{does not match}} + + { bool b = (void (&)(int))t; } //ok + { bool b = (void (*)(int))t; } //ok + + { bool b = static_cast(t); } //ok + { bool b = static_cast(t); } //ok + + { bool b = static_cast(t); } //ok + { bool b = static_cast(t); } //ok + + + { bool b = reinterpret_cast(t); } // expected-error{{cannot resolve}} + { bool b = reinterpret_cast(t); } // expected-error{{cannot resolve}} + + { bool b = reinterpret_cast(g); } //ok + { bool b = static_cast(t); } // expected-error{{cannot be static_cast}} + { bool b = static_cast(t); } // expected-error{{does not match required}} + + { bool b = static_cast(f); } // expected-error{{does not match}} +}