diff options
author | Anna Zaks <ganna@apple.com> | 2012-10-01 20:34:04 +0000 |
---|---|---|
committer | Anna Zaks <ganna@apple.com> | 2012-10-01 20:34:04 +0000 |
commit | bbff82f302a1dd67589f65912351978905f0c5a7 (patch) | |
tree | 32e1bef6a7e5fa080bcbcdf9a71b9d410717763e /lib/Sema/ScopeInfo.cpp | |
parent | b9733ac1a2012c3e909ac262073a6deb8533d2c7 (diff) |
Move isObjCSelf into Expr.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@164966 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/ScopeInfo.cpp')
-rw-r--r-- | lib/Sema/ScopeInfo.cpp | 22 |
1 files changed, 2 insertions, 20 deletions
diff --git a/lib/Sema/ScopeInfo.cpp b/lib/Sema/ScopeInfo.cpp index bb9420d1e7..7a9d917a02 100644 --- a/lib/Sema/ScopeInfo.cpp +++ b/lib/Sema/ScopeInfo.cpp @@ -41,24 +41,6 @@ static const NamedDecl *getBestPropertyDecl(const ObjCPropertyRefExpr *PropE) { return PropE->getImplicitPropertyGetter(); } -static bool isSelfExpr(const Expr *E) { - E = E->IgnoreParenImpCasts(); - - const DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E); - if (!DRE) - return false; - - const ImplicitParamDecl *Param = dyn_cast<ImplicitParamDecl>(DRE->getDecl()); - if (!Param) - return false; - - const ObjCMethodDecl *M = dyn_cast<ObjCMethodDecl>(Param->getDeclContext()); - if (!M) - return false; - - return M->getSelfDecl() == Param; -} - FunctionScopeInfo::WeakObjectProfileTy::BaseInfoTy FunctionScopeInfo::WeakObjectProfileTy::getBaseInfo(const Expr *E) { E = E->IgnoreParenCasts(); @@ -80,7 +62,7 @@ FunctionScopeInfo::WeakObjectProfileTy::getBaseInfo(const Expr *E) { case Stmt::ObjCIvarRefExprClass: { const ObjCIvarRefExpr *IE = cast<ObjCIvarRefExpr>(E); D = IE->getDecl(); - IsExact = isSelfExpr(IE->getBase()); + IsExact = IE->getBase()->isObjCSelfExpr(); break; } case Stmt::PseudoObjectExprClass: { @@ -94,7 +76,7 @@ FunctionScopeInfo::WeakObjectProfileTy::getBaseInfo(const Expr *E) { if (const OpaqueValueExpr *OVE = dyn_cast<OpaqueValueExpr>(DoubleBase)) DoubleBase = OVE->getSourceExpr(); - IsExact = isSelfExpr(DoubleBase); + IsExact = DoubleBase->isObjCSelfExpr(); } break; } |