From: Argyrios Kyrtzidis Date: Wed, 22 Oct 2008 21:00:29 +0000 (+0000) Subject: Now that DeclRefExpr accepts a NamedDecl, use a DeclRefExpr for when a CXXFieldDecl... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=90b7bc67518a408d397f2400ff6c40e5465b45e4;p=clang Now that DeclRefExpr accepts a NamedDecl, use a DeclRefExpr for when a CXXFieldDecl is referenced inside a method. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@58000 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/AST/Expr.cpp b/lib/AST/Expr.cpp index 5c0e38cf9e..6e62d09474 100644 --- a/lib/AST/Expr.cpp +++ b/lib/AST/Expr.cpp @@ -325,7 +325,7 @@ bool Expr::hasLocalSideEffect() const { /// DeclCanBeLvalue - Determine whether the given declaration can be /// an lvalue. This is a helper routine for isLvalue. static bool DeclCanBeLvalue(const NamedDecl *Decl, ASTContext &Ctx) { - return isa(Decl) || + return isa(Decl) || isa(Decl) || // C++ 3.10p2: An lvalue refers to an object or function. (Ctx.getLangOptions().CPlusPlus && (isa(Decl) || isa(Decl))); diff --git a/lib/Sema/SemaExpr.cpp b/lib/Sema/SemaExpr.cpp index 5619eca4f0..070db2b5b9 100644 --- a/lib/Sema/SemaExpr.cpp +++ b/lib/Sema/SemaExpr.cpp @@ -402,10 +402,7 @@ Sema::ExprResult Sema::ActOnIdentifierExpr(Scope *S, SourceLocation Loc, if (FD->isInvalidDecl()) return true; - // FIXME: Use DeclRefExpr or a new Expr for a direct CXXField reference. - ExprResult ThisExpr = ActOnCXXThis(SourceLocation()); - return new MemberExpr(static_cast(ThisExpr.Val), - true, FD, Loc, FD->getType()); + return new DeclRefExpr(FD, FD->getType(), Loc); } return Diag(Loc, diag::err_invalid_non_static_member_use, FD->getName());