llvm-project/clang/test/SemaTemplate/value-dependent-null-pointer-constant.cpp
Douglas Gregor 56751b5981 Fix checking for a null pointer constant when the expression itself is
value-dependent. Audit (and fixed) all calls to
Expr::isNullPointerConstant() to provide the correct behavior with
value-dependent expressions. Fixes PR5041 and a crash in libstdc++
<locale>.

In the same vein, properly compute value- and type-dependence for
ChooseExpr. Fixes PR4996.

llvm-svn: 82748
2009-09-25 04:25:58 +00:00

29 lines
462 B
C++

// RUN: clang-cc -fsyntax-only %s
template<typename T, int N>
struct X0 {
const char *f0(bool Cond) {
return Cond? "honk" : N;
}
const char *f1(bool Cond) {
return Cond? N : "honk";
}
bool f2(const char *str) {
return str == N;
}
};
// PR4996
template<unsigned I> int f0() {
return __builtin_choose_expr(I, 0, 1);
}
// PR5041
struct A { };
template <typename T> void f(T *t)
{
(void)static_cast<void*>(static_cast<A*>(t));
}