From: Lang Hames Date: Thu, 8 Dec 2011 19:26:24 +0000 (+0000) Subject: Added missing testcase from r145849. Thanks to Dave Blaikie for catching this. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2cad9e32e6067260f166977e64c49175be1da202;p=clang Added missing testcase from r145849. Thanks to Dave Blaikie for catching this. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@146169 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/SemaCXX/warn-func-as-bool.cpp b/test/SemaCXX/warn-func-as-bool.cpp new file mode 100644 index 0000000000..2606b4da95 --- /dev/null +++ b/test/SemaCXX/warn-func-as-bool.cpp @@ -0,0 +1,28 @@ +// RUN: %clang_cc1 -x c++ -verify -fsyntax-only %s + +void f1(); + +struct S { + static void f2(); +}; + +extern void f3() __attribute__((weak_import)); + +struct S2 { + static void f4() __attribute__((weak_import)); +}; + +void bar() { + bool b; + + b = f1; // expected-warning {{address of function 'f1' will always evaluate to 'true'}} + if (f1) {} // expected-warning {{address of function 'f1' will always evaluate to 'true'}} + b = S::f2; // expected-warning {{address of function 'S::f2' will always evaluate to 'true'}} + if (S::f2) {} // expected-warning {{address of function 'S::f2' will always evaluate to 'true'}} + + // implicit casts of weakly imported symbols are ok: + b = f3; + if (f3) {} + b = S2::f4; + if (S2::f4) {} +}