diff options
author | Steve Naroff <snaroff@apple.com> | 2007-12-16 21:42:28 +0000 |
---|---|---|
committer | Steve Naroff <snaroff@apple.com> | 2007-12-16 21:42:28 +0000 |
commit | eaaae467c79ea15c1f77740b56f3e28b6fd5c75e (patch) | |
tree | 14271edc7608a42d6148504ca1af87082a0e76e5 | |
parent | 56ed48036bc1c86066e1a44cd18bdcf76a551a0c (diff) | |
download | bcm5719-llvm-eaaae467c79ea15c1f77740b56f3e28b6fd5c75e.tar.gz bcm5719-llvm-eaaae467c79ea15c1f77740b56f3e28b6fd5c75e.zip |
Sema::ActOnMemberReferenceExpr() needs to perform the default conversions.
Bug and test case provided by Carl Lewis.
llvm-svn: 45078
-rw-r--r-- | clang/Sema/SemaExpr.cpp | 3 | ||||
-rw-r--r-- | clang/test/Sema/member-reference.c | 9 |
2 files changed, 12 insertions, 0 deletions
diff --git a/clang/Sema/SemaExpr.cpp b/clang/Sema/SemaExpr.cpp index 1d8b8834353..dae5325ac40 100644 --- a/clang/Sema/SemaExpr.cpp +++ b/clang/Sema/SemaExpr.cpp @@ -503,6 +503,9 @@ ActOnMemberReferenceExpr(ExprTy *Base, SourceLocation OpLoc, IdentifierInfo &Member) { Expr *BaseExpr = static_cast<Expr *>(Base); assert(BaseExpr && "no record expression"); + + // Perform default conversions. + DefaultFunctionArrayConversion(BaseExpr); QualType BaseType = BaseExpr->getType(); assert(!BaseType.isNull() && "no type for member expression"); diff --git a/clang/test/Sema/member-reference.c b/clang/test/Sema/member-reference.c new file mode 100644 index 00000000000..784d60020ad --- /dev/null +++ b/clang/test/Sema/member-reference.c @@ -0,0 +1,9 @@ +// RUN: clang %s -verify -fsyntax-only + +struct simple { int i; }; + +void f(void) { + struct simple s[1]; + s->i = 1; +} + |