diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2013-01-22 19:05:17 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2013-01-22 19:05:17 +0000 |
commit | 3548068c22f809e5bc64b83d2c3622018469256c (patch) | |
tree | 01a1bb4b5423a37371bfc84752911d3029de6e61 /lib/Sema/SemaExprObjC.cpp | |
parent | 48f3cc2b2be1d32df14234904539b34e6e387e4a (diff) |
Small code change to improve performance
in my last patch, suggested by Argyrios.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@173182 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaExprObjC.cpp')
-rw-r--r-- | lib/Sema/SemaExprObjC.cpp | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/Sema/SemaExprObjC.cpp b/lib/Sema/SemaExprObjC.cpp index 87da440191..7f0c832575 100644 --- a/lib/Sema/SemaExprObjC.cpp +++ b/lib/Sema/SemaExprObjC.cpp @@ -2485,8 +2485,12 @@ ExprResult Sema::ActOnInstanceMessage(Scope *S, MultiExprArg Args) { if (!Receiver) return ExprError(); - IdentifierInfo *SelectorId = &Context.Idents.get("respondsToSelector"); - if (Sel == Context.Selectors.getUnarySelector(SelectorId)) + + if (RespondsToSelectorSel.isNull()) { + IdentifierInfo *SelectorId = &Context.Idents.get("respondsToSelector"); + RespondsToSelectorSel = Context.Selectors.getUnarySelector(SelectorId); + } + if (Sel == RespondsToSelectorSel) RemoveSelectorFromWarningCache(*this, Args[0]); return BuildInstanceMessage(Receiver, Receiver->getType(), |