|
|
|
@ -1,5 +1,6 @@ |
|
|
|
#include "Tokens.h" |
|
|
|
#include "Tokens.h" |
|
|
|
#include "Utility.h" |
|
|
|
#include "Utility.h" |
|
|
|
|
|
|
|
#include <unordered_set> |
|
|
|
|
|
|
|
|
|
|
|
clangmm::Tokens::Tokens(CXTranslationUnit &cx_tu, const SourceRange &range): cx_tu(cx_tu) { |
|
|
|
clangmm::Tokens::Tokens(CXTranslationUnit &cx_tu, const SourceRange &range): cx_tu(cx_tu) { |
|
|
|
clang_tokenize(cx_tu, range.cx_range, &cx_tokens, &num_tokens); |
|
|
|
clang_tokenize(cx_tu, range.cx_range, &cx_tokens, &num_tokens); |
|
|
|
@ -19,14 +20,36 @@ clangmm::Tokens::~Tokens() { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
//This works across TranslationUnits. Similar tokens defined as tokens with equal canonical cursors.
|
|
|
|
//This works across TranslationUnits. Similar tokens defined as tokens with equal canonical cursors.
|
|
|
|
std::vector<std::pair<clangmm::Offset, clangmm::Offset> > clangmm::Tokens::get_similar_token_offsets(const std::string &spelling, const std::string &usr) { |
|
|
|
std::vector<std::pair<clangmm::Offset, clangmm::Offset> > clangmm::Tokens::get_similar_token_offsets(Cursor::Kind kind, const std::string &spelling, |
|
|
|
|
|
|
|
const std::unordered_set<std::string> &usrs) { |
|
|
|
|
|
|
|
// Special case for virtual and override functions
|
|
|
|
|
|
|
|
if(kind==Cursor::Kind::CXXMethod) { |
|
|
|
std::vector<std::pair<Offset, Offset> > offsets; |
|
|
|
std::vector<std::pair<Offset, Offset> > offsets; |
|
|
|
for(auto &token: *this) { |
|
|
|
for(auto &token: *this) { |
|
|
|
if(token.is_identifier()) { |
|
|
|
if(token.is_identifier()) { |
|
|
|
auto referenced=token.get_cursor().get_referenced(); |
|
|
|
auto referenced=token.get_cursor().get_referenced(); |
|
|
|
if(referenced && spelling==token.get_spelling() && usr==referenced.get_usr_extended()) |
|
|
|
if(referenced && referenced.get_kind()==Cursor::Kind::CXXMethod && spelling==token.get_spelling()) { |
|
|
|
|
|
|
|
auto referenced_usrs=referenced.get_all_usr_extended(); |
|
|
|
|
|
|
|
for(auto &usr: referenced_usrs) { |
|
|
|
|
|
|
|
if(usrs.count(usr)) { |
|
|
|
offsets.emplace_back(token.offsets); |
|
|
|
offsets.emplace_back(token.offsets); |
|
|
|
|
|
|
|
break; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
return offsets; |
|
|
|
return offsets; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
else { |
|
|
|
|
|
|
|
std::vector<std::pair<Offset, Offset> > offsets; |
|
|
|
|
|
|
|
for(auto &token: *this) { |
|
|
|
|
|
|
|
if(token.is_identifier()) { |
|
|
|
|
|
|
|
auto referenced=token.get_cursor().get_referenced(); |
|
|
|
|
|
|
|
if(referenced && spelling==token.get_spelling() && usrs.count(referenced.get_usr_extended())) |
|
|
|
|
|
|
|
offsets.emplace_back(token.offsets); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
return offsets; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|