remove groupid

This commit is contained in:
Jacob Dufault 2017-02-26 23:25:59 -08:00
parent aa677de886
commit 430b9ef61b
3 changed files with 13 additions and 27 deletions

View File

@ -21,7 +21,7 @@ TypeId IndexedFile::ToTypeId(const std::string& usr) {
if (it != id_cache->usr_to_type_id.end()) if (it != id_cache->usr_to_type_id.end())
return it->second; return it->second;
TypeId id(id_cache->group, types.size()); TypeId id(types.size());
types.push_back(IndexedTypeDef(id, usr)); types.push_back(IndexedTypeDef(id, usr));
id_cache->usr_to_type_id[usr] = id; id_cache->usr_to_type_id[usr] = id;
id_cache->type_id_to_usr[id] = usr; id_cache->type_id_to_usr[id] = usr;
@ -32,7 +32,7 @@ FuncId IndexedFile::ToFuncId(const std::string& usr) {
if (it != id_cache->usr_to_func_id.end()) if (it != id_cache->usr_to_func_id.end())
return it->second; return it->second;
FuncId id(id_cache->group, funcs.size()); FuncId id(funcs.size());
funcs.push_back(IndexedFuncDef(id, usr)); funcs.push_back(IndexedFuncDef(id, usr));
id_cache->usr_to_func_id[usr] = id; id_cache->usr_to_func_id[usr] = id;
id_cache->func_id_to_usr[id] = usr; id_cache->func_id_to_usr[id] = usr;
@ -43,7 +43,7 @@ VarId IndexedFile::ToVarId(const std::string& usr) {
if (it != id_cache->usr_to_var_id.end()) if (it != id_cache->usr_to_var_id.end())
return it->second; return it->second;
VarId id(id_cache->group, vars.size()); VarId id(vars.size());
vars.push_back(IndexedVarDef(id, usr)); vars.push_back(IndexedVarDef(id, usr));
id_cache->usr_to_var_id[usr] = id; id_cache->usr_to_var_id[usr] = id;
id_cache->var_id_to_usr[id] = usr; id_cache->var_id_to_usr[id] = usr;
@ -990,7 +990,7 @@ int main(int argc, char** argv) {
// Run test. // Run test.
std::cout << "[START] " << path << std::endl; std::cout << "[START] " << path << std::endl;
IdCache id_cache(1); IdCache id_cache;
IndexedFile db = Parse(&id_cache, path, {}); IndexedFile db = Parse(&id_cache, path, {});
std::string actual_output = db.ToString(); std::string actual_output = db.ToString();

View File

@ -26,23 +26,18 @@ struct IndexedVarDef;
using namespace std::experimental; using namespace std::experimental;
using GroupId = int;
template<typename T> template<typename T>
struct Id { struct Id {
GroupId group;
uint64_t id; uint64_t id;
Id() : id(0) {} // Needed for containers. Do not use directly. Id() : id(0) {} // Needed for containers. Do not use directly.
Id(GroupId group, uint64_t id) : group(group), id(id) {} Id(uint64_t id) : id(id) {}
bool operator==(const Id<T>& other) const { bool operator==(const Id<T>& other) const {
assert(group == other.group && "Cannot compare Ids from different groups");
return id == other.id; return id == other.id;
} }
bool operator<(const Id<T>& other) const { bool operator<(const Id<T>& other) const {
assert(group == other.group);
return id < other.id; return id < other.id;
} }
}; };
@ -51,7 +46,7 @@ namespace std {
template<typename T> template<typename T>
struct hash<Id<T>> { struct hash<Id<T>> {
size_t operator()(const Id<T>& k) const { size_t operator()(const Id<T>& k) const {
return ((hash<uint64_t>()(k.id) ^ (hash<int>()(k.group) << 1)) >> 1); return hash<uint64_t>()(k.id);
} }
}; };
} }
@ -71,14 +66,12 @@ using VarId = Id<IndexedVarDef>;
struct Location { struct Location {
bool interesting; bool interesting;
int raw_file_group;
int raw_file_id; int raw_file_id;
int line; int line;
int column; int column;
Location() { Location() {
interesting = false; interesting = false;
raw_file_group = -1;
raw_file_id = -1; raw_file_id = -1;
line = -1; line = -1;
column = -1; column = -1;
@ -86,14 +79,13 @@ struct Location {
Location(bool interesting, FileId file, uint32_t line, uint32_t column) { Location(bool interesting, FileId file, uint32_t line, uint32_t column) {
this->interesting = interesting; this->interesting = interesting;
this->raw_file_group = file.group;
this->raw_file_id = file.id; this->raw_file_id = file.id;
this->line = line; this->line = line;
this->column = column; this->column = column;
} }
FileId file_id() const { FileId file_id() const {
return FileId(raw_file_id, raw_file_group); return FileId(raw_file_id);
} }
std::string ToString() { std::string ToString() {
@ -123,7 +115,6 @@ struct Location {
bool IsEqualTo(const Location& o) const { bool IsEqualTo(const Location& o) const {
// When comparing, ignore the value of |interesting|. // When comparing, ignore the value of |interesting|.
return return
raw_file_group == o.raw_file_group &&
raw_file_id == o.raw_file_id && raw_file_id == o.raw_file_id &&
line == o.line && line == o.line &&
column == o.column; column == o.column;
@ -135,7 +126,6 @@ struct Location {
bool operator<(const Location& o) const { bool operator<(const Location& o) const {
return return
interesting < o.interesting && interesting < o.interesting &&
raw_file_group < o.raw_file_group &&
raw_file_id < o.raw_file_id && raw_file_id < o.raw_file_id &&
line < o.line && line < o.line &&
column < o.column; column < o.column;
@ -466,9 +456,6 @@ namespace std {
} }
struct IdCache { struct IdCache {
// NOTE: Every Id is resolved to a file_id of 0. The correct file_id needs
// to get fixed up when inserting into the real db.
GroupId group;
std::unordered_map<std::string, FileId> file_path_to_file_id; std::unordered_map<std::string, FileId> file_path_to_file_id;
std::unordered_map<std::string, TypeId> usr_to_type_id; std::unordered_map<std::string, TypeId> usr_to_type_id;
std::unordered_map<std::string, FuncId> usr_to_func_id; std::unordered_map<std::string, FuncId> usr_to_func_id;
@ -478,10 +465,10 @@ struct IdCache {
std::unordered_map<FuncId, std::string> func_id_to_usr; std::unordered_map<FuncId, std::string> func_id_to_usr;
std::unordered_map<VarId, std::string> var_id_to_usr; std::unordered_map<VarId, std::string> var_id_to_usr;
IdCache(GroupId group) : group(group) { IdCache() {
// Reserve id 0 for unfound. // Reserve id 0 for unfound.
file_path_to_file_id[""] = FileId(group, 0); file_path_to_file_id[""] = FileId(0);
file_id_to_file_path[FileId(group, 0)] = ""; file_id_to_file_path[FileId(0)] = "";
} }
Location Resolve(const CXSourceLocation& cx_loc, bool interesting) { Location Resolve(const CXSourceLocation& cx_loc, bool interesting) {
@ -489,7 +476,7 @@ struct IdCache {
unsigned int line, column, offset; unsigned int line, column, offset;
clang_getSpellingLocation(cx_loc, &file, &line, &column, &offset); clang_getSpellingLocation(cx_loc, &file, &line, &column, &offset);
FileId file_id(-1, -1); FileId file_id(-1);
if (file != nullptr) { if (file != nullptr) {
std::string path = clang::ToString(clang_getFileName(file)); std::string path = clang::ToString(clang_getFileName(file));
@ -498,7 +485,7 @@ struct IdCache {
file_id = it->second; file_id = it->second;
} }
else { else {
file_id = FileId(group, file_path_to_file_id.size()); file_id = FileId(file_path_to_file_id.size());
file_path_to_file_id[path] = file_id; file_path_to_file_id[path] = file_id;
file_id_to_file_path[file_id] = path; file_id_to_file_path[file_id] = path;
} }

View File

@ -620,8 +620,7 @@ void QueryableDatabase::ApplyIndexUpdate(IndexUpdate* update) {
int main233(int argc, char** argv) { int main233(int argc, char** argv) {
// TODO: Unify UserToIdResolver and FileDb IdCache id_cache;
IdCache id_cache(1);
IndexedFile indexed_file_a = Parse(&id_cache, "full_tests/index_delta/a_v0.cc", {}); IndexedFile indexed_file_a = Parse(&id_cache, "full_tests/index_delta/a_v0.cc", {});
std::cout << indexed_file_a.ToString() << std::endl; std::cout << indexed_file_a.ToString() << std::endl;