diff options
author | Steve Naroff <snaroff@apple.com> | 2007-11-11 14:15:57 +0000 |
---|---|---|
committer | Steve Naroff <snaroff@apple.com> | 2007-11-11 14:15:57 +0000 |
commit | d848a3867794f4a9297bced70178834936e59d3d (patch) | |
tree | 623c0e75dbbeaeabe19d91110bbbcd3b99af8eef | |
parent | c43d868355374d48296ad3be2c9c536698a5e9a8 (diff) |
Make sure Sema::CheckIncrementDecrementOperand() removes typedefs when doing it's analysis.
Thanks to Seo Sanghyeon for his excellent (first) bug fix!
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@43994 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | Sema/SemaExpr.cpp | 2 | ||||
-rw-r--r-- | test/Sema/check-increment.c | 10 |
2 files changed, 11 insertions, 1 deletions
diff --git a/Sema/SemaExpr.cpp b/Sema/SemaExpr.cpp index bd210c3adf..31c09be7cb 100644 --- a/Sema/SemaExpr.cpp +++ b/Sema/SemaExpr.cpp @@ -1414,7 +1414,7 @@ QualType Sema::CheckIncrementDecrementOperand(Expr *op, SourceLocation OpLoc) { assert(!resType.isNull() && "no type for increment/decrement expression"); // C99 6.5.2.4p1: We allow complex as a GCC extension. - if (const PointerType *pt = dyn_cast<PointerType>(resType)) { + if (const PointerType *pt = resType->getAsPointerType()) { if (!pt->getPointeeType()->isObjectType()) { // C99 6.5.2.4p2, 6.5.6p2 Diag(OpLoc, diag::err_typecheck_arithmetic_incomplete_type, resType.getAsString(), op->getSourceRange()); diff --git a/test/Sema/check-increment.c b/test/Sema/check-increment.c new file mode 100644 index 0000000000..4447feb0b8 --- /dev/null +++ b/test/Sema/check-increment.c @@ -0,0 +1,10 @@ +// RUN: clang -fsyntax-only -verify %s + +#include <stdio.h> +typedef int *pint; +int main() { + int a[5] = {0}; + pint p = a; + p++; + printf("%d\n", *p); +} |