diff options
author | Lang Hames <lhames@gmail.com> | 2011-12-08 19:26:24 +0000 |
---|---|---|
committer | Lang Hames <lhames@gmail.com> | 2011-12-08 19:26:24 +0000 |
commit | 2cad9e32e6067260f166977e64c49175be1da202 (patch) | |
tree | c6c645d022a97d45c1ff50eab17fea27762973cc | |
parent | 77d029f6a24dbf70d97e61757945df53fb250ea0 (diff) |
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
-rw-r--r-- | test/SemaCXX/warn-func-as-bool.cpp | 28 |
1 files changed, 28 insertions, 0 deletions
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) {} +} |