diff options
| author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2011-01-11 19:45:16 +0000 |
|---|---|---|
| committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2011-01-11 19:45:16 +0000 |
| commit | 52f04650aea7cc93d96966b2bab69c2ee0c080f5 (patch) | |
| tree | a03a4d912921bca5be3050c7eced8c3dc4e72679 | |
| parent | 1790c975e76d9cb267b78b190d2aaaf62060a4c1 (diff) | |
| download | bcm5719-llvm-52f04650aea7cc93d96966b2bab69c2ee0c080f5.tar.gz bcm5719-llvm-52f04650aea7cc93d96966b2bab69c2ee0c080f5.zip | |
[analyzer] Add 'bool ignorePrefix' parameter to cocoa::deriveNamingConvention to control whether
the prefix should be ignored.
E.g. if ignorePrefix is true, "_init" and "init" selectors will both be result in InitRule, but if
ignorePrefix is false, only "init" will return InitRule.
llvm-svn: 123262
| -rw-r--r-- | clang/include/clang/Analysis/DomainSpecific/CocoaConventions.h | 2 | ||||
| -rw-r--r-- | clang/lib/Analysis/CocoaConventions.cpp | 7 |
2 files changed, 7 insertions, 2 deletions
diff --git a/clang/include/clang/Analysis/DomainSpecific/CocoaConventions.h b/clang/include/clang/Analysis/DomainSpecific/CocoaConventions.h index 18e81fed79f..7e6e3815400 100644 --- a/clang/include/clang/Analysis/DomainSpecific/CocoaConventions.h +++ b/clang/include/clang/Analysis/DomainSpecific/CocoaConventions.h @@ -22,7 +22,7 @@ namespace cocoa { enum NamingConvention { NoConvention, CreateRule, InitRule }; - NamingConvention deriveNamingConvention(Selector S); + NamingConvention deriveNamingConvention(Selector S, bool ignorePrefix = true); static inline bool followsFundamentalRule(Selector S) { return deriveNamingConvention(S) == CreateRule; diff --git a/clang/lib/Analysis/CocoaConventions.cpp b/clang/lib/Analysis/CocoaConventions.cpp index 2c263cadada..422652544d0 100644 --- a/clang/lib/Analysis/CocoaConventions.cpp +++ b/clang/lib/Analysis/CocoaConventions.cpp @@ -54,7 +54,8 @@ static const char* parseWord(const char* s) { return s; } -cocoa::NamingConvention cocoa::deriveNamingConvention(Selector S) { +cocoa::NamingConvention cocoa::deriveNamingConvention(Selector S, + bool ignorePrefix) { IdentifierInfo *II = S.getIdentifierInfoForSlot(0); if (!II) @@ -62,6 +63,7 @@ cocoa::NamingConvention cocoa::deriveNamingConvention(Selector S) { const char *s = II->getNameStart(); + const char *orig = s; // A method/function name may contain a prefix. We don't know it is there, // however, until we encounter the first '_'. while (*s != '\0') { @@ -73,6 +75,9 @@ cocoa::NamingConvention cocoa::deriveNamingConvention(Selector S) { break; } + if (!ignorePrefix && s != orig) + return NoConvention; + // Parse the first word, and look for specific keywords. const char *wordEnd = parseWord(s); assert(wordEnd > s); |

