From: Ted Kremenek Date: Sat, 18 Oct 2008 03:28:48 +0000 (+0000) Subject: Use "VisitLValue" when processing the base for "x.f" field accesses, and "Visit"... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=5c456fe4d354dab9e8a1309aefe828ea7b6d6f26;p=clang Use "VisitLValue" when processing the base for "x.f" field accesses, and "Visit" when processing the base for "x->f" field accesses. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@57754 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/GRExprEngine.cpp b/lib/Analysis/GRExprEngine.cpp index 98e8427a69..ee7141782f 100644 --- a/lib/Analysis/GRExprEngine.cpp +++ b/lib/Analysis/GRExprEngine.cpp @@ -891,8 +891,12 @@ void GRExprEngine::VisitMemberExpr(MemberExpr* M, NodeTy* Pred, Expr* Base = M->getBase()->IgnoreParens(); NodeSet Tmp; - Visit(Base, Pred, Tmp); - + + if (M->isArrow()) + Visit(Base, Pred, Tmp); // p->f = ... or ... = p->f + else + VisitLValue(Base, Pred, Tmp); // x.f = ... or ... = x.f + for (NodeSet::iterator I = Tmp.begin(), E = Tmp.end(); I != E; ++I) { const GRState* St = GetState(*I); // FIXME: Should we insert some assumption logic in here to determine diff --git a/test/Analysis/fields.c b/test/Analysis/fields.c new file mode 100644 index 0000000000..72de12c4dc --- /dev/null +++ b/test/Analysis/fields.c @@ -0,0 +1,10 @@ +// RUN: clang -checker-cfref %s -verify && +// RUN: clang -checker-simple %s -verify + +unsigned foo(); +typedef struct bf { unsigned x:2; } bf; +void bar() { + bf y; + *(unsigned*)&y = foo(); + y.x = 1; +}