diff options
author | Chris Lattner <sabre@nondot.org> | 2007-10-29 04:26:44 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-10-29 04:26:44 +0000 |
commit | 3da2db468d9a694535d62e7b96a010ce95c26fb6 (patch) | |
tree | ced9385fb3aaaf2360531719c845ec3579ca3fe8 | |
parent | 52735a0339dd31750251a13aac73677693410c9d (diff) |
casting to void is ok for structs (C99 6.5.4p2), this fixes
one bogus error on PR1750.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@43436 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | Sema/SemaExpr.cpp | 17 | ||||
-rw-r--r-- | test/Sema/cast.c | 8 |
2 files changed, 17 insertions, 8 deletions
diff --git a/Sema/SemaExpr.cpp b/Sema/SemaExpr.cpp index 40205d335c..88a72eb982 100644 --- a/Sema/SemaExpr.cpp +++ b/Sema/SemaExpr.cpp @@ -693,14 +693,15 @@ ActOnCastExpr(SourceLocation LParenLoc, TypeTy *Ty, // C99 6.5.4p2: the cast type needs to be void or scalar and the expression // type needs to be scalar. - if (!castType->isScalarType() && !castType->isVoidType()) { - return Diag(LParenLoc, diag::err_typecheck_cond_expect_scalar, - castType.getAsString(), SourceRange(LParenLoc, RParenLoc)); - } - if (!castExpr->getType()->isScalarType()) { - return Diag(castExpr->getLocStart(), - diag::err_typecheck_expect_scalar_operand, - castExpr->getType().getAsString(), castExpr->getSourceRange()); + if (!castType->isVoidType()) { // Cast to void allows any expr type. + if (!castType->isScalarType()) + return Diag(LParenLoc, diag::err_typecheck_cond_expect_scalar, + castType.getAsString(), SourceRange(LParenLoc, RParenLoc)); + if (!castExpr->getType()->isScalarType()) { + return Diag(castExpr->getLocStart(), + diag::err_typecheck_expect_scalar_operand, + castExpr->getType().getAsString(),castExpr->getSourceRange()); + } } return new CastExpr(castType, castExpr, LParenLoc); } diff --git a/test/Sema/cast.c b/test/Sema/cast.c new file mode 100644 index 0000000000..14bfe138f3 --- /dev/null +++ b/test/Sema/cast.c @@ -0,0 +1,8 @@ +// RUN: clang -fsyntax-only %s -verify + +typedef struct { unsigned long bits[(((1) + (64) - 1) / (64))]; } cpumask_t; +cpumask_t x; +void foo() { + (void)x; +} + |