From: Chris Lattner Date: Mon, 29 Oct 2007 04:26:44 +0000 (+0000) Subject: casting to void is ok for structs (C99 6.5.4p2), this fixes X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3da2db468d9a694535d62e7b96a010ce95c26fb6;p=clang 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 --- 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; +} +