From b567904d0a9e5455bc9d1df8152b2677b1b3b8d7 Mon Sep 17 00:00:00 2001 From: xinyan Date: Thu, 7 Mar 2019 23:55:40 +0800 Subject: [PATCH 1/9] Revert "Change files from set back to list" This reverts commit 6d0da87b3c451c2cce7b04f9eb055e9c63a9aa3c. --- persper/analytics/call_commit_graph.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/persper/analytics/call_commit_graph.py b/persper/analytics/call_commit_graph.py index 05af148aec3..6f13108dd9d 100644 --- a/persper/analytics/call_commit_graph.py +++ b/persper/analytics/call_commit_graph.py @@ -93,7 +93,7 @@ def _next_cindex(self): # TODO: remove the default value of files def add_node(self, node, files=[]): - self._digraph.add_node(node, size=None, history={}, files=files) + self._digraph.add_node(node, size=None, history={}, files=set(files)) # add_node must be called on source and target first def add_edge(self, source, target): @@ -120,7 +120,7 @@ def _get_node_history(self, node): return self._digraph.nodes[node]['history'] def update_node_files(self, node, new_files): - self._digraph.nodes[node]['files'] = new_files + self._digraph.nodes[node]['files'] = set(new_files) # TODO: provide other options for computing a node's size def _set_all_nodes_size(self, black_set=None): From fa0fd67cc62fd83a25adad71fe8ff82f97429399 Mon Sep 17 00:00:00 2001 From: xinyan Date: Thu, 7 Mar 2019 23:59:06 +0800 Subject: [PATCH 2/9] Correct test_feature_branch repo. Add forward decl to conform C99. --- test/test_feature_branch/C/main.c | 2 ++ test/test_feature_branch/D/main.c | 2 ++ test/test_feature_branch/E/main.c | 2 ++ test/test_feature_branch/F/main.c | 2 ++ test/test_feature_branch/G/main.c | 2 ++ test/test_feature_branch/H/main.c | 2 ++ test/test_feature_branch/I/main.c | 2 ++ test/test_feature_branch/K/main.c | 2 ++ 8 files changed, 16 insertions(+) diff --git a/test/test_feature_branch/C/main.c b/test/test_feature_branch/C/main.c index 401fb0597d6..5eaeabc97a7 100644 --- a/test/test_feature_branch/C/main.c +++ b/test/test_feature_branch/C/main.c @@ -8,6 +8,8 @@ int str_len(char *string) /* str_append is deleted in B */ +int str_equals(char *equal1, char *eqaul2); // Forward decl. + /* added in B, edited in C */ char* str_append_chr(char* string, char append) { char* newstring = ""; diff --git a/test/test_feature_branch/D/main.c b/test/test_feature_branch/D/main.c index 401fb0597d6..c5a80c50643 100644 --- a/test/test_feature_branch/D/main.c +++ b/test/test_feature_branch/D/main.c @@ -8,6 +8,8 @@ int str_len(char *string) /* str_append is deleted in B */ +int str_equals(char *equal1, char *eqaul2); // Forward decl + /* added in B, edited in C */ char* str_append_chr(char* string, char append) { char* newstring = ""; diff --git a/test/test_feature_branch/E/main.c b/test/test_feature_branch/E/main.c index 401fb0597d6..c5a80c50643 100644 --- a/test/test_feature_branch/E/main.c +++ b/test/test_feature_branch/E/main.c @@ -8,6 +8,8 @@ int str_len(char *string) /* str_append is deleted in B */ +int str_equals(char *equal1, char *eqaul2); // Forward decl + /* added in B, edited in C */ char* str_append_chr(char* string, char append) { char* newstring = ""; diff --git a/test/test_feature_branch/F/main.c b/test/test_feature_branch/F/main.c index 401fb0597d6..c5a80c50643 100644 --- a/test/test_feature_branch/F/main.c +++ b/test/test_feature_branch/F/main.c @@ -8,6 +8,8 @@ int str_len(char *string) /* str_append is deleted in B */ +int str_equals(char *equal1, char *eqaul2); // Forward decl + /* added in B, edited in C */ char* str_append_chr(char* string, char append) { char* newstring = ""; diff --git a/test/test_feature_branch/G/main.c b/test/test_feature_branch/G/main.c index 19d8834f11f..67f1d720f3a 100644 --- a/test/test_feature_branch/G/main.c +++ b/test/test_feature_branch/G/main.c @@ -8,6 +8,8 @@ int str_len(char *string) /* str_append is deleted in B */ +int str_equals(char *equal1, char *eqaul2); // Forward decl + /* added in B*/ char* str_append_chr(char* string, char append) { char* newstring = NULL; diff --git a/test/test_feature_branch/H/main.c b/test/test_feature_branch/H/main.c index 401fb0597d6..c5a80c50643 100644 --- a/test/test_feature_branch/H/main.c +++ b/test/test_feature_branch/H/main.c @@ -8,6 +8,8 @@ int str_len(char *string) /* str_append is deleted in B */ +int str_equals(char *equal1, char *eqaul2); // Forward decl + /* added in B, edited in C */ char* str_append_chr(char* string, char append) { char* newstring = ""; diff --git a/test/test_feature_branch/I/main.c b/test/test_feature_branch/I/main.c index 401fb0597d6..c5a80c50643 100644 --- a/test/test_feature_branch/I/main.c +++ b/test/test_feature_branch/I/main.c @@ -8,6 +8,8 @@ int str_len(char *string) /* str_append is deleted in B */ +int str_equals(char *equal1, char *eqaul2); // Forward decl + /* added in B, edited in C */ char* str_append_chr(char* string, char append) { char* newstring = ""; diff --git a/test/test_feature_branch/K/main.c b/test/test_feature_branch/K/main.c index 401fb0597d6..c5a80c50643 100644 --- a/test/test_feature_branch/K/main.c +++ b/test/test_feature_branch/K/main.c @@ -8,6 +8,8 @@ int str_len(char *string) /* str_append is deleted in B */ +int str_equals(char *equal1, char *eqaul2); // Forward decl + /* added in B, edited in C */ char* str_append_chr(char* string, char append) { char* newstring = ""; From b1fd1479359b361e3a08651d0f3cf011a6f78b9c Mon Sep 17 00:00:00 2001 From: xinyan Date: Fri, 8 Mar 2019 00:00:56 +0800 Subject: [PATCH 3/9] Update cpp test baseline. ccls won't count in all the function decls for now. Make sure you have ccls PR 307 patched. --- .../baseline/cpp_test_repo/A.g.json | 105 +++--------------- .../baseline/cpp_test_repo/B.g.json | 96 +++------------- .../baseline/cpp_test_repo/C.g.json | 87 ++------------- .../baseline/cpp_test_repo/D.g.json | 87 ++------------- .../baseline/feature_branch/C.g.json | 9 +- .../baseline/feature_branch/D.g.json | 9 +- .../baseline/feature_branch/E.g.json | 9 +- .../baseline/feature_branch/F.g.json | 15 +-- .../baseline/feature_branch/G.g.json | 9 +- .../baseline/feature_branch/H.g.json | 9 +- .../baseline/feature_branch/I.g.json | 9 +- .../baseline/feature_branch/J.g.json | 9 +- .../baseline/feature_branch/K.g.json | 15 +-- .../feature_branch_first_parent/C.g.json | 9 +- .../feature_branch_first_parent/D.g.json | 15 +-- .../feature_branch_first_parent/E.g.json | 15 +-- .../feature_branch_first_parent/F.g.json | 15 +-- .../feature_branch_first_parent/K.g.json | 15 +-- 18 files changed, 85 insertions(+), 452 deletions(-) diff --git a/test/test_analytics/baseline/cpp_test_repo/A.g.json b/test/test_analytics/baseline/cpp_test_repo/A.g.json index 3a503bd6209..cd6aaa90876 100644 --- a/test/test_analytics/baseline/cpp_test_repo/A.g.json +++ b/test/test_analytics/baseline/cpp_test_repo/A.g.json @@ -28,30 +28,10 @@ "addedBy": "A", "weight": null }, - "bool Confirm(const std::string &prompt)|->|bool Confirm(const std::string &prompt)": { - "addedBy": "A", - "weight": null - }, - "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)|->|bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)": { - "addedBy": "A", - "weight": null - }, "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)|->|enum class StringComparison : int {}": { "addedBy": "A", "weight": null }, - "const char *FriendlyNameOf(const ReliabilityNetworkEntry &instance)|->|const char *FriendlyNameOf()": { - "addedBy": "A", - "weight": null - }, - "const char *FriendlyNameOf(const std::type_index &type)|->|const char *FriendlyNameOf()": { - "addedBy": "A", - "weight": null - }, - "const char *FriendlyNameOf(const type_info &type)|->|const char *FriendlyNameOf()": { - "addedBy": "A", - "weight": null - }, "int main(int argc, char *argv[])|->|TStream OpenAndValidate(const TPath arg1)": { "addedBy": "A", "weight": null @@ -59,10 +39,6 @@ "int main(int argc, char *argv[])|->|bool ConfigurationParser::GetBool(const std::string &key, bool defaultValue) const": { "addedBy": "A", "weight": null - }, - "void ReportException(const std::exception &ex, int level)|->|void ReportException(const std::exception &ex, int level)": { - "addedBy": "A", - "weight": null } }, "nodes": { @@ -188,12 +164,11 @@ }, "RowReader &operator>>(RowReader &reader, bool &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 25, + "adds": 24, "dels": 0 } }, @@ -201,12 +176,11 @@ }, "RowReader &operator>>(RowReader &reader, double &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -214,12 +188,11 @@ }, "RowReader &operator>>(RowReader &reader, float &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -227,12 +200,11 @@ }, "RowReader &operator>>(RowReader &reader, int &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -240,12 +212,11 @@ }, "RowReader &operator>>(RowReader &reader, long &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -253,12 +224,11 @@ }, "RowReader &operator>>(RowReader &reader, std::string &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 17, + "adds": 16, "dels": 0 } }, @@ -398,12 +368,11 @@ }, "bool Confirm(const std::string &prompt)": { "files": [ - "Utility.cpp", - "Utility.h" + "Utility.cpp" ], "history": { "A": { - "adds": 18, + "adds": 17, "dels": 0 } }, @@ -411,12 +380,11 @@ }, "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)": { "files": [ - "Utility.cpp", - "Utility.h" + "Utility.cpp" ], "history": { "A": { - "adds": 30, + "adds": 29, "dels": 0 } }, @@ -458,42 +426,6 @@ }, "size": null }, - "const char *FriendlyNameOf(const ReliabilityNetworkEntry &instance)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, - "const char *FriendlyNameOf(const std::type_index &type)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, - "const char *FriendlyNameOf(const type_info &type)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, "double ConfigurationParser::GetDouble(const std::string &key, double defaultValue) const": { "files": [ "TextFileParsers.cpp" @@ -604,12 +536,11 @@ }, "void ReportException(const std::exception &ex, int level)": { "files": [ - "Utility.cpp", - "Utility.h" + "Utility.cpp" ], "history": { "A": { - "adds": 21, + "adds": 20, "dels": 0 } }, diff --git a/test/test_analytics/baseline/cpp_test_repo/B.g.json b/test/test_analytics/baseline/cpp_test_repo/B.g.json index aebb4ca25f3..cdcca5b1baa 100644 --- a/test/test_analytics/baseline/cpp_test_repo/B.g.json +++ b/test/test_analytics/baseline/cpp_test_repo/B.g.json @@ -28,30 +28,10 @@ "addedBy": "A", "weight": null }, - "bool Confirm(const std::string &prompt)|->|bool Confirm(const std::string &prompt)": { - "addedBy": "B", - "weight": null - }, - "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)|->|bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)": { - "addedBy": "B", - "weight": null - }, "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)|->|enum class StringComparison : int {}": { "addedBy": "B", "weight": null }, - "const char *FriendlyNameOf(const ReliabilityNetworkEntry &instance)|->|const char *FriendlyNameOf()": { - "addedBy": "A", - "weight": null - }, - "const char *FriendlyNameOf(const std::type_index &type)|->|const char *FriendlyNameOf()": { - "addedBy": "A", - "weight": null - }, - "const char *FriendlyNameOf(const type_info &type)|->|const char *FriendlyNameOf()": { - "addedBy": "A", - "weight": null - }, "int main(int argc, char *argv[])|->|TStream OpenAndValidate(const TPath arg1)": { "addedBy": "B", "weight": null @@ -71,10 +51,6 @@ "int main(int argc, char *argv[])|->|void ReportException(const std::exception &ex, int level)": { "addedBy": "B", "weight": null - }, - "void ReportException(const std::exception &ex, int level)|->|void ReportException(const std::exception &ex, int level)": { - "addedBy": "B", - "weight": null } }, "nodes": { @@ -200,12 +176,11 @@ }, "RowReader &operator>>(RowReader &reader, bool &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 25, + "adds": 24, "dels": 0 } }, @@ -213,12 +188,11 @@ }, "RowReader &operator>>(RowReader &reader, double &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -226,12 +200,11 @@ }, "RowReader &operator>>(RowReader &reader, float &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -239,12 +212,11 @@ }, "RowReader &operator>>(RowReader &reader, int &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -252,12 +224,11 @@ }, "RowReader &operator>>(RowReader &reader, long &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -265,12 +236,11 @@ }, "RowReader &operator>>(RowReader &reader, std::string &rhs)": { "files": [ - "TextFileParsers.cpp", - "TextFileParsers.h" + "TextFileParsers.cpp" ], "history": { "A": { - "adds": 17, + "adds": 16, "dels": 0 } }, @@ -414,7 +384,7 @@ ], "history": { "A": { - "adds": 18, + "adds": 17, "dels": 0 } }, @@ -426,7 +396,7 @@ ], "history": { "A": { - "adds": 30, + "adds": 29, "dels": 0 } }, @@ -468,42 +438,6 @@ }, "size": null }, - "const char *FriendlyNameOf(const ReliabilityNetworkEntry &instance)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, - "const char *FriendlyNameOf(const std::type_index &type)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, - "const char *FriendlyNameOf(const type_info &type)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, "double ConfigurationParser::GetDouble(const std::string &key, double defaultValue) const": { "files": [ "TextFileParsers.cpp" @@ -622,7 +556,7 @@ ], "history": { "A": { - "adds": 21, + "adds": 20, "dels": 0 } }, diff --git a/test/test_analytics/baseline/cpp_test_repo/C.g.json b/test/test_analytics/baseline/cpp_test_repo/C.g.json index 2e596bc9ef6..babf7d98549 100644 --- a/test/test_analytics/baseline/cpp_test_repo/C.g.json +++ b/test/test_analytics/baseline/cpp_test_repo/C.g.json @@ -28,30 +28,10 @@ "addedBy": "C", "weight": null }, - "bool Confirm(const std::string &prompt)|->|bool Confirm(const std::string &prompt)": { - "addedBy": "C", - "weight": null - }, - "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)|->|bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)": { - "addedBy": "C", - "weight": null - }, "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)|->|enum class StringComparison : int {}": { "addedBy": "C", "weight": null }, - "const char *FriendlyNameOf(const ReliabilityNetworkEntry &instance)|->|const char *FriendlyNameOf()": { - "addedBy": "C", - "weight": null - }, - "const char *FriendlyNameOf(const std::type_index &type)|->|const char *FriendlyNameOf()": { - "addedBy": "C", - "weight": null - }, - "const char *FriendlyNameOf(const type_info &type)|->|const char *FriendlyNameOf()": { - "addedBy": "C", - "weight": null - }, "int main(int argc, char *argv[])|->|TStream OpenAndValidate(const TPath arg1)": { "addedBy": "C", "weight": null @@ -71,10 +51,6 @@ "int main(int argc, char *argv[])|->|void ReportException(const std::exception &ex, int level)": { "addedBy": "B", "weight": null - }, - "void ReportException(const std::exception &ex, int level)|->|void ReportException(const std::exception &ex, int level)": { - "addedBy": "C", - "weight": null } }, "nodes": { @@ -204,7 +180,7 @@ ], "history": { "A": { - "adds": 25, + "adds": 24, "dels": 0 }, "C": { @@ -220,7 +196,7 @@ ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -232,7 +208,7 @@ ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -244,7 +220,7 @@ ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -256,7 +232,7 @@ ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -268,7 +244,7 @@ ], "history": { "A": { - "adds": 17, + "adds": 16, "dels": 0 } }, @@ -412,12 +388,11 @@ }, "bool Confirm(const std::string &prompt)": { "files": [ - "Utility.cpp", - "Utility.h" + "Utility.cpp" ], "history": { "A": { - "adds": 18, + "adds": 17, "dels": 0 } }, @@ -425,12 +400,11 @@ }, "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)": { "files": [ - "Utility.cpp", - "Utility.h" + "Utility.cpp" ], "history": { "A": { - "adds": 30, + "adds": 29, "dels": 0 }, "C": { @@ -476,42 +450,6 @@ }, "size": null }, - "const char *FriendlyNameOf(const ReliabilityNetworkEntry &instance)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, - "const char *FriendlyNameOf(const std::type_index &type)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, - "const char *FriendlyNameOf(const type_info &type)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, "double ConfigurationParser::GetDouble(const std::string &key, double defaultValue) const": { "files": [ "TextFileParsers.cpp" @@ -634,12 +572,11 @@ }, "void ReportException(const std::exception &ex, int level)": { "files": [ - "Utility.cpp", - "Utility.h" + "Utility.cpp" ], "history": { "A": { - "adds": 21, + "adds": 20, "dels": 0 } }, diff --git a/test/test_analytics/baseline/cpp_test_repo/D.g.json b/test/test_analytics/baseline/cpp_test_repo/D.g.json index 02fe0fde492..aa0ec8956b9 100644 --- a/test/test_analytics/baseline/cpp_test_repo/D.g.json +++ b/test/test_analytics/baseline/cpp_test_repo/D.g.json @@ -28,30 +28,10 @@ "addedBy": "D", "weight": null }, - "bool Confirm(const std::string &prompt)|->|bool Confirm(const std::string &prompt)": { - "addedBy": "D", - "weight": null - }, - "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)|->|bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)": { - "addedBy": "D", - "weight": null - }, "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)|->|enum class StringComparison : int {}": { "addedBy": "D", "weight": null }, - "const char *FriendlyNameOf(const ReliabilityNetworkEntry &instance)|->|const char *FriendlyNameOf()": { - "addedBy": "D", - "weight": null - }, - "const char *FriendlyNameOf(const std::type_index &type)|->|const char *FriendlyNameOf()": { - "addedBy": "D", - "weight": null - }, - "const char *FriendlyNameOf(const type_info &type)|->|const char *FriendlyNameOf()": { - "addedBy": "D", - "weight": null - }, "int main(int argc, char *argv[])|->|TStream OpenAndValidate(const TPath arg1)": { "addedBy": "C", "weight": null @@ -71,10 +51,6 @@ "int main(int argc, char *argv[])|->|void ReportException(const std::exception &ex, int level)": { "addedBy": "B", "weight": null - }, - "void ReportException(const std::exception &ex, int level)|->|void ReportException(const std::exception &ex, int level)": { - "addedBy": "D", - "weight": null } }, "nodes": { @@ -204,7 +180,7 @@ ], "history": { "A": { - "adds": 25, + "adds": 24, "dels": 0 }, "C": { @@ -224,7 +200,7 @@ ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -236,7 +212,7 @@ ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -248,7 +224,7 @@ ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -260,7 +236,7 @@ ], "history": { "A": { - "adds": 7, + "adds": 6, "dels": 0 } }, @@ -272,7 +248,7 @@ ], "history": { "A": { - "adds": 17, + "adds": 16, "dels": 0 } }, @@ -420,12 +396,11 @@ }, "bool Confirm(const std::string &prompt)": { "files": [ - "Utility.cpp", - "Utility.h" + "Utility.cpp" ], "history": { "A": { - "adds": 18, + "adds": 17, "dels": 0 } }, @@ -433,12 +408,11 @@ }, "bool Equal(const std::string &lhs, const std::string &rhs, StringComparison comparision)": { "files": [ - "Utility.cpp", - "Utility.h" + "Utility.cpp" ], "history": { "A": { - "adds": 30, + "adds": 29, "dels": 0 }, "C": { @@ -488,42 +462,6 @@ }, "size": null }, - "const char *FriendlyNameOf(const ReliabilityNetworkEntry &instance)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, - "const char *FriendlyNameOf(const std::type_index &type)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, - "const char *FriendlyNameOf(const type_info &type)": { - "files": [ - "Utility.h" - ], - "history": { - "A": { - "adds": 1, - "dels": 0 - } - }, - "size": null - }, "double ConfigurationParser::GetDouble(const std::string &key, double defaultValue) const": { "files": [ "TextFileParsers.cpp" @@ -654,12 +592,11 @@ }, "void ReportException(const std::exception &ex, int level)": { "files": [ - "Utility.cpp", - "Utility.h" + "Utility.cpp" ], "history": { "A": { - "adds": 21, + "adds": 20, "dels": 0 } }, diff --git a/test/test_analytics/baseline/feature_branch/C.g.json b/test/test_analytics/baseline/feature_branch/C.g.json index 4b791785f4e..9992cb0fd09 100644 --- a/test/test_analytics/baseline/feature_branch/C.g.json +++ b/test/test_analytics/baseline/feature_branch/C.g.json @@ -1,6 +1,6 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "C", "weight": null }, @@ -42,13 +42,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch/D.g.json b/test/test_analytics/baseline/feature_branch/D.g.json index 4b931b0a2c0..488d426a937 100644 --- a/test/test_analytics/baseline/feature_branch/D.g.json +++ b/test/test_analytics/baseline/feature_branch/D.g.json @@ -1,6 +1,6 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "D", "weight": null }, @@ -66,13 +66,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch/E.g.json b/test/test_analytics/baseline/feature_branch/E.g.json index 414ed9fd459..26ef09a68c0 100644 --- a/test/test_analytics/baseline/feature_branch/E.g.json +++ b/test/test_analytics/baseline/feature_branch/E.g.json @@ -1,6 +1,6 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "D", "weight": null }, @@ -74,13 +74,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch/F.g.json b/test/test_analytics/baseline/feature_branch/F.g.json index 31a14cda404..4c8ee3397cc 100644 --- a/test/test_analytics/baseline/feature_branch/F.g.json +++ b/test/test_analytics/baseline/feature_branch/F.g.json @@ -4,7 +4,7 @@ "addedBy": "F", "weight": null }, - "char *str_append_chr(char *string, char append)|->|int str_equals()": { + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "F", "weight": null }, @@ -16,12 +16,8 @@ "addedBy": "F", "weight": null }, - "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals()": { - "addedBy": "F", - "weight": null - }, "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals(char *equal1, char *eqaul2)": { - "addedBy": "G", + "addedBy": "F", "weight": null }, "char *str_replace(char *search, char *replace, char *subject)|->|int str_len(char *string)": { @@ -94,13 +90,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch/G.g.json b/test/test_analytics/baseline/feature_branch/G.g.json index 9be01d4cc7f..e933b06f594 100644 --- a/test/test_analytics/baseline/feature_branch/G.g.json +++ b/test/test_analytics/baseline/feature_branch/G.g.json @@ -1,6 +1,6 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "C", "weight": null }, @@ -66,13 +66,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch/H.g.json b/test/test_analytics/baseline/feature_branch/H.g.json index 8089ef9ccbf..6d72823868b 100644 --- a/test/test_analytics/baseline/feature_branch/H.g.json +++ b/test/test_analytics/baseline/feature_branch/H.g.json @@ -1,6 +1,6 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "D", "weight": null }, @@ -74,13 +74,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch/I.g.json b/test/test_analytics/baseline/feature_branch/I.g.json index 414ed9fd459..26ef09a68c0 100644 --- a/test/test_analytics/baseline/feature_branch/I.g.json +++ b/test/test_analytics/baseline/feature_branch/I.g.json @@ -1,6 +1,6 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "D", "weight": null }, @@ -74,13 +74,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch/J.g.json b/test/test_analytics/baseline/feature_branch/J.g.json index 7606ab45a52..ae29e94aeef 100644 --- a/test/test_analytics/baseline/feature_branch/J.g.json +++ b/test/test_analytics/baseline/feature_branch/J.g.json @@ -1,6 +1,6 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "D", "weight": null }, @@ -86,13 +86,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch/K.g.json b/test/test_analytics/baseline/feature_branch/K.g.json index 555bdff3d1e..c406a16e2d7 100644 --- a/test/test_analytics/baseline/feature_branch/K.g.json +++ b/test/test_analytics/baseline/feature_branch/K.g.json @@ -4,7 +4,7 @@ "addedBy": "F", "weight": null }, - "char *str_append_chr(char *string, char append)|->|int str_equals()": { + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "F", "weight": null }, @@ -16,12 +16,8 @@ "addedBy": "F", "weight": null }, - "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals()": { - "addedBy": "F", - "weight": null - }, "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals(char *equal1, char *eqaul2)": { - "addedBy": "G", + "addedBy": "F", "weight": null }, "char *str_replace(char *search, char *replace, char *subject)|->|int str_len(char *string)": { @@ -94,13 +90,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch_first_parent/C.g.json b/test/test_analytics/baseline/feature_branch_first_parent/C.g.json index 4b791785f4e..9992cb0fd09 100644 --- a/test/test_analytics/baseline/feature_branch_first_parent/C.g.json +++ b/test/test_analytics/baseline/feature_branch_first_parent/C.g.json @@ -1,6 +1,6 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "C", "weight": null }, @@ -42,13 +42,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch_first_parent/D.g.json b/test/test_analytics/baseline/feature_branch_first_parent/D.g.json index f289e724860..a1579f2d346 100644 --- a/test/test_analytics/baseline/feature_branch_first_parent/D.g.json +++ b/test/test_analytics/baseline/feature_branch_first_parent/D.g.json @@ -1,18 +1,18 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { - "addedBy": "C", + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { + "addedBy": "D", "weight": null }, "char *str_append_chr(char *string, char append)|->|int str_len(char *string)": { - "addedBy": "C", + "addedBy": "D", "weight": null }, "char *str_replace(char *search, char *replace, char *subject)|->|char *str_append_chr(char *string, char append)": { "addedBy": "D", "weight": null }, - "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals()": { + "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "D", "weight": null }, @@ -66,13 +66,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch_first_parent/E.g.json b/test/test_analytics/baseline/feature_branch_first_parent/E.g.json index 8d6ec786302..3c24ccfc482 100644 --- a/test/test_analytics/baseline/feature_branch_first_parent/E.g.json +++ b/test/test_analytics/baseline/feature_branch_first_parent/E.g.json @@ -1,18 +1,18 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { - "addedBy": "C", + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { + "addedBy": "D", "weight": null }, "char *str_append_chr(char *string, char append)|->|int str_len(char *string)": { - "addedBy": "C", + "addedBy": "D", "weight": null }, "char *str_replace(char *search, char *replace, char *subject)|->|char *str_append_chr(char *string, char append)": { "addedBy": "D", "weight": null }, - "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals()": { + "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "D", "weight": null }, @@ -66,13 +66,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch_first_parent/F.g.json b/test/test_analytics/baseline/feature_branch_first_parent/F.g.json index da60e2d5a1b..1ea3182ab6d 100644 --- a/test/test_analytics/baseline/feature_branch_first_parent/F.g.json +++ b/test/test_analytics/baseline/feature_branch_first_parent/F.g.json @@ -1,18 +1,18 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { - "addedBy": "C", + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { + "addedBy": "D", "weight": null }, "char *str_append_chr(char *string, char append)|->|int str_len(char *string)": { - "addedBy": "C", + "addedBy": "D", "weight": null }, "char *str_replace(char *search, char *replace, char *subject)|->|char *str_append_chr(char *string, char append)": { "addedBy": "D", "weight": null }, - "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals()": { + "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "D", "weight": null }, @@ -78,13 +78,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" diff --git a/test/test_analytics/baseline/feature_branch_first_parent/K.g.json b/test/test_analytics/baseline/feature_branch_first_parent/K.g.json index 1c8c8e2e3a9..32ca12c74da 100644 --- a/test/test_analytics/baseline/feature_branch_first_parent/K.g.json +++ b/test/test_analytics/baseline/feature_branch_first_parent/K.g.json @@ -1,18 +1,18 @@ { "edges": { - "char *str_append_chr(char *string, char append)|->|int str_equals()": { - "addedBy": "C", + "char *str_append_chr(char *string, char append)|->|int str_equals(char *equal1, char *eqaul2)": { + "addedBy": "D", "weight": null }, "char *str_append_chr(char *string, char append)|->|int str_len(char *string)": { - "addedBy": "C", + "addedBy": "D", "weight": null }, "char *str_replace(char *search, char *replace, char *subject)|->|char *str_append_chr(char *string, char append)": { "addedBy": "D", "weight": null }, - "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals()": { + "char *str_replace(char *search, char *replace, char *subject)|->|int str_equals(char *equal1, char *eqaul2)": { "addedBy": "D", "weight": null }, @@ -78,13 +78,6 @@ }, "size": null }, - "int str_equals()": { - "files": [ - "main.c" - ], - "history": {}, - "size": null - }, "int str_equals(char *equal1, char *eqaul2)": { "files": [ "main.c" From 7ac2a760d5ef6da7af30090f1896e919e711a5dc Mon Sep 17 00:00:00 2001 From: xinyan Date: Sun, 10 Mar 2019 18:31:26 +0800 Subject: [PATCH 4/9] Bug fix: TokenizedDocument should check the children of DocumentSymbol. Minor cleanup. --- .../analytics/lsp_graph_server/callgraph/builder.py | 11 ++++++++--- .../analytics/lsp_graph_server/callgraph/manager.py | 3 ++- .../lsp_graph_server/languageclient/lspcontract.py | 2 +- 3 files changed, 11 insertions(+), 5 deletions(-) diff --git a/persper/analytics/lsp_graph_server/callgraph/builder.py b/persper/analytics/lsp_graph_server/callgraph/builder.py index b54bd46bec6..37923c2aeb3 100644 --- a/persper/analytics/lsp_graph_server/callgraph/builder.py +++ b/persper/analytics/lsp_graph_server/callgraph/builder.py @@ -58,7 +58,7 @@ def PopulateSymbols(symbols): if filterResult == None: continue if filterResult == False: - if isinstance(s, SymbolInformation): + if isinstance(s, DocumentSymbol): PopulateSymbols(s.children) continue if isinstance(s, DocumentSymbol): @@ -66,12 +66,12 @@ def PopulateSymbols(symbols): symbolKinds[s.selectionRange.start.toTuple()] = s.kind self._scopes.append(CallGraphScope(s.detail or s.name, s.kind, fileName, s.range.start, s.range.end)) + if s.children: + PopulateSymbols(s.children) elif isinstance(s, SymbolInformation): symbolKinds[(s.location.range.start.line, s.name)] = (s.location.range.start.character, s.kind) self._scopes.append(CallGraphScope(s.containerName, s.kind, fileName, s.location.range.start, s.location.range.end)) - if s.children: - PopulateSymbols(s.children) else: _logger.error("Invalid DocumentSymbol in %s: %s", fileName, s) @@ -293,6 +293,11 @@ def filterSymbol(self, symbol: Union[DocumentSymbol, SymbolInformation]) -> bool False symbol should be excluded, while its children will pass filterSymbol None symbol and its children will be excluded """ + if symbol.kind in { + SymbolKind.Parameter, + SymbolKind.TypeParameter + }: + return None return symbol.kind in { SymbolKind.Constructor, SymbolKind.Enum, diff --git a/persper/analytics/lsp_graph_server/callgraph/manager.py b/persper/analytics/lsp_graph_server/callgraph/manager.py index b4b51a0296a..85b6cd6d00b 100644 --- a/persper/analytics/lsp_graph_server/callgraph/manager.py +++ b/persper/analytics/lsp_graph_server/callgraph/manager.py @@ -42,6 +42,7 @@ async def buildGraph(self, fileNames: Union[str, Iterable[str]] = None, globPatt branchCounter = 0 # with dups fileCounter = 0 await self._builder.waitForFileSystem() + def pushBranch(branch): nonlocal branchCounter try: @@ -64,7 +65,7 @@ def pushBranch(branch): pushBranch(b) if globPattern or not fileNames: async for b in self._builder.buildCallGraphInFiles(globPattern): - pushBranch(b) + pushBranch(b) if fileNames and not globPattern: _logger.info("Added %d branches from %d files.", branchCounter, fileCounter) else: diff --git a/persper/analytics/lsp_graph_server/languageclient/lspcontract.py b/persper/analytics/lsp_graph_server/languageclient/lspcontract.py index 930e3741e03..390f0f0da42 100644 --- a/persper/analytics/lsp_graph_server/languageclient/lspcontract.py +++ b/persper/analytics/lsp_graph_server/languageclient/lspcontract.py @@ -237,7 +237,7 @@ def getSymbolRange(self): return self.selectionRange def __str__(self): - return self.name + "[" + self.kind + "]" + return str.format("{0}({1}){2}", self.name, self.kind, self.children or "") def toDict(self): raise NotImplementedError() From 2098cb5291e78ed1da3b5892e206912292ec2ebf Mon Sep 17 00:00:00 2001 From: xinyan Date: Sun, 10 Mar 2019 18:51:11 +0800 Subject: [PATCH 5/9] Update baseline for test_analyzer_lsp_ccls. Refactor test_analyzer_lsp_ccls. --- .../baseline/cpp_test_repo/A.g.json | 292 ++++++++++++++++++ .../baseline/cpp_test_repo/B.g.json | 292 ++++++++++++++++++ .../baseline/cpp_test_repo/C.g.json | 292 ++++++++++++++++++ .../baseline/cpp_test_repo/D.g.json | 292 ++++++++++++++++++ test/test_analytics/test_analyzer_lsp_ccls.py | 27 +- test/test_analytics/utility/graph_baseline.py | 18 +- 6 files changed, 1191 insertions(+), 22 deletions(-) diff --git a/test/test_analytics/baseline/cpp_test_repo/A.g.json b/test/test_analytics/baseline/cpp_test_repo/A.g.json index cd6aaa90876..2594c7d3aa5 100644 --- a/test/test_analytics/baseline/cpp_test_repo/A.g.json +++ b/test/test_analytics/baseline/cpp_test_repo/A.g.json @@ -1,5 +1,9 @@ { "edges": { + "ArgumentException::ArgumentException(const std::string &message, const std::string &argumentName)|->|static std::string ArgumentException::BuildMessage(const std::string &message, const std::string &argumentName)": { + "addedBy": "A", + "weight": null + }, "ConfigurationParser::ConfigurationParser(std::filesystem::path filePath)|->|TStream OpenAndValidate(const TPath arg1)": { "addedBy": "A", "weight": null @@ -138,6 +142,66 @@ }, "size": null }, + "ArgumentException::ArgumentException(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 2, + "dels": 0 + } + }, + "size": null + }, + "ArgumentException::ArgumentException(const std::string &message, const std::string &argumentName)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 2, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler &BlockExitHandler::operator=(const BlockExitHandler &) = delete": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler::BlockExitHandler(const BlockExitHandler &) = delete": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler::~BlockExitHandler() noexcept": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 11, + "dels": 0 + } + }, + "size": null + }, "ConfigurationParser::ConfigurationParser(std::filesystem::path filePath)": { "files": [ "TextFileParsers.cpp" @@ -162,6 +226,42 @@ }, "size": null }, + "Exception::Exception()": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "Exception::~Exception() noexcept": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "InvalidCastException::InvalidCastException(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "RowReader &operator>>(RowReader &reader, bool &rhs)": { "files": [ "TextFileParsers.cpp" @@ -234,6 +334,18 @@ }, "size": null }, + "RowReader::operator bool() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, "TDest safe_cast(TSrc obj)": { "files": [ "Utility.h" @@ -270,6 +382,30 @@ }, "size": null }, + "TIterator _RangeToEnumerable::begin()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "TIterator _RangeToEnumerable::end()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "TStream &operator>>(TStream &s, RowReader &reader)": { "files": [ "TextFileParsers.h" @@ -330,6 +466,18 @@ }, "size": null }, + "_RangeToEnumerable::_RangeToEnumerable(const std::pair range)": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "_RangeToEnumerable RangeToEnumerable(const std::pair range)": { "files": [ "Utility.h" @@ -390,6 +538,30 @@ }, "size": null }, + "bool RowReader::operator!() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "bool _RangeToEnumerable::empty()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "bool dynamic_kind_of(const TSrc *obj)": { "files": [ "Utility.h" @@ -414,6 +586,18 @@ }, "size": null }, + "const char *Exception::what() const noexcept": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "const char *FriendlyNameOf()": { "files": [ "Utility.h" @@ -426,6 +610,30 @@ }, "size": null }, + "const std::string &ArgumentException::ArgumentName() const": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "const std::stringstream &RowReader::LineStream() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "double ConfigurationParser::GetDouble(const std::string &key, double defaultValue) const": { "files": [ "TextFileParsers.cpp" @@ -450,6 +658,54 @@ }, "size": null }, + "explicit BlockExitHandler::BlockExitHandler(const std::function &handler)": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "explicit Exception::Exception(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 6, + "dels": 0 + } + }, + "size": null + }, + "explicit OperationFailureException::OperationFailureException(int errorCode)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "explicit RowReader::RowReader(bool keepWhitespace, char delim)": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 3, + "dels": 0 + } + }, + "size": null + }, "inline std::string to_string(const std::pair &value)": { "files": [ "Utility.h" @@ -486,6 +742,30 @@ }, "size": null }, + "size_t RowReader::LineNumber() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "static std::string ArgumentException::BuildMessage(const std::string &message, const std::string &argumentName)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 5, + "dels": 0 + } + }, + "size": null + }, "std::shared_ptr safe_pointer_cast(const std::shared_ptr &obj)": { "files": [ "Utility.h" @@ -546,6 +826,18 @@ }, "size": null }, + "void RowReader::ResetLineNumber()": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "void ValidateStream(const TStream &stream)": { "files": [ "Utility.h" diff --git a/test/test_analytics/baseline/cpp_test_repo/B.g.json b/test/test_analytics/baseline/cpp_test_repo/B.g.json index cdcca5b1baa..d0db7b42971 100644 --- a/test/test_analytics/baseline/cpp_test_repo/B.g.json +++ b/test/test_analytics/baseline/cpp_test_repo/B.g.json @@ -1,5 +1,9 @@ { "edges": { + "ArgumentException::ArgumentException(const std::string &message, const std::string &argumentName)|->|static std::string ArgumentException::BuildMessage(const std::string &message, const std::string &argumentName)": { + "addedBy": "A", + "weight": null + }, "ConfigurationParser::ConfigurationParser(std::filesystem::path filePath)|->|TStream OpenAndValidate(const TPath arg1)": { "addedBy": "A", "weight": null @@ -150,6 +154,66 @@ }, "size": null }, + "ArgumentException::ArgumentException(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 2, + "dels": 0 + } + }, + "size": null + }, + "ArgumentException::ArgumentException(const std::string &message, const std::string &argumentName)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 2, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler &BlockExitHandler::operator=(const BlockExitHandler &) = delete": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler::BlockExitHandler(const BlockExitHandler &) = delete": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler::~BlockExitHandler() noexcept": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 11, + "dels": 0 + } + }, + "size": null + }, "ConfigurationParser::ConfigurationParser(std::filesystem::path filePath)": { "files": [ "TextFileParsers.cpp" @@ -174,6 +238,42 @@ }, "size": null }, + "Exception::Exception()": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "Exception::~Exception() noexcept": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "InvalidCastException::InvalidCastException(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "RowReader &operator>>(RowReader &reader, bool &rhs)": { "files": [ "TextFileParsers.cpp" @@ -246,6 +346,18 @@ }, "size": null }, + "RowReader::operator bool() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, "TDest safe_cast(TSrc obj)": { "files": [ "Utility.h" @@ -282,6 +394,30 @@ }, "size": null }, + "TIterator _RangeToEnumerable::begin()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "TIterator _RangeToEnumerable::end()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "TStream &operator>>(TStream &s, RowReader &reader)": { "files": [ "TextFileParsers.h" @@ -342,6 +478,18 @@ }, "size": null }, + "_RangeToEnumerable::_RangeToEnumerable(const std::pair range)": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "_RangeToEnumerable RangeToEnumerable(const std::pair range)": { "files": [ "Utility.h" @@ -402,6 +550,30 @@ }, "size": null }, + "bool RowReader::operator!() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "bool _RangeToEnumerable::empty()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "bool dynamic_kind_of(const TSrc *obj)": { "files": [ "Utility.h" @@ -426,6 +598,18 @@ }, "size": null }, + "const char *Exception::what() const noexcept": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "const char *FriendlyNameOf()": { "files": [ "Utility.h" @@ -438,6 +622,30 @@ }, "size": null }, + "const std::string &ArgumentException::ArgumentName() const": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "const std::stringstream &RowReader::LineStream() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "double ConfigurationParser::GetDouble(const std::string &key, double defaultValue) const": { "files": [ "TextFileParsers.cpp" @@ -462,6 +670,54 @@ }, "size": null }, + "explicit BlockExitHandler::BlockExitHandler(const std::function &handler)": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "explicit Exception::Exception(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 6, + "dels": 0 + } + }, + "size": null + }, + "explicit OperationFailureException::OperationFailureException(int errorCode)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "explicit RowReader::RowReader(bool keepWhitespace, char delim)": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 3, + "dels": 0 + } + }, + "size": null + }, "inline std::string to_string(const std::pair &value)": { "files": [ "Utility.h" @@ -502,6 +758,30 @@ }, "size": null }, + "size_t RowReader::LineNumber() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "static std::string ArgumentException::BuildMessage(const std::string &message, const std::string &argumentName)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 5, + "dels": 0 + } + }, + "size": null + }, "std::shared_ptr safe_pointer_cast(const std::shared_ptr &obj)": { "files": [ "Utility.h" @@ -562,6 +842,18 @@ }, "size": null }, + "void RowReader::ResetLineNumber()": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "void ValidateStream(const TStream &stream)": { "files": [ "Utility.h" diff --git a/test/test_analytics/baseline/cpp_test_repo/C.g.json b/test/test_analytics/baseline/cpp_test_repo/C.g.json index babf7d98549..e8db0ec0531 100644 --- a/test/test_analytics/baseline/cpp_test_repo/C.g.json +++ b/test/test_analytics/baseline/cpp_test_repo/C.g.json @@ -1,5 +1,9 @@ { "edges": { + "ArgumentException::ArgumentException(const std::string &message, const std::string &argumentName)|->|static std::string ArgumentException::BuildMessage(const std::string &message, const std::string &argumentName)": { + "addedBy": "A", + "weight": null + }, "ConfigurationParser::ConfigurationParser(std::filesystem::path filePath)|->|TStream OpenAndValidate(const TPath arg1)": { "addedBy": "C", "weight": null @@ -150,6 +154,66 @@ }, "size": null }, + "ArgumentException::ArgumentException(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 2, + "dels": 0 + } + }, + "size": null + }, + "ArgumentException::ArgumentException(const std::string &message, const std::string &argumentName)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 2, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler &BlockExitHandler::operator=(const BlockExitHandler &) = delete": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler::BlockExitHandler(const BlockExitHandler &) = delete": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler::~BlockExitHandler() noexcept": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 11, + "dels": 0 + } + }, + "size": null + }, "ConfigurationParser::ConfigurationParser(std::filesystem::path filePath)": { "files": [ "TextFileParsers.cpp" @@ -174,6 +238,42 @@ }, "size": null }, + "Exception::Exception()": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "Exception::~Exception() noexcept": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "InvalidCastException::InvalidCastException(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "RowReader &operator>>(RowReader &reader, bool &rhs)": { "files": [ "TextFileParsers.cpp" @@ -250,6 +350,18 @@ }, "size": null }, + "RowReader::operator bool() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, "TDest safe_cast(TSrc obj)": { "files": [ "Utility.h" @@ -286,6 +398,30 @@ }, "size": null }, + "TIterator _RangeToEnumerable::begin()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "TIterator _RangeToEnumerable::end()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "TStream &operator>>(TStream &s, RowReader &reader)": { "files": [ "TextFileParsers.h" @@ -346,6 +482,18 @@ }, "size": null }, + "_RangeToEnumerable::_RangeToEnumerable(const std::pair range)": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "_RangeToEnumerable RangeToEnumerable(const std::pair range)": { "files": [ "Utility.h" @@ -414,6 +562,30 @@ }, "size": null }, + "bool RowReader::operator!() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "bool _RangeToEnumerable::empty()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "bool dynamic_kind_of(const TSrc *obj)": { "files": [ "Utility.h" @@ -438,6 +610,18 @@ }, "size": null }, + "const char *Exception::what() const noexcept": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "const char *FriendlyNameOf()": { "files": [ "Utility.h" @@ -450,6 +634,30 @@ }, "size": null }, + "const std::string &ArgumentException::ArgumentName() const": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "const std::stringstream &RowReader::LineStream() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "double ConfigurationParser::GetDouble(const std::string &key, double defaultValue) const": { "files": [ "TextFileParsers.cpp" @@ -478,6 +686,54 @@ }, "size": null }, + "explicit BlockExitHandler::BlockExitHandler(const std::function &handler)": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "explicit Exception::Exception(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 6, + "dels": 0 + } + }, + "size": null + }, + "explicit OperationFailureException::OperationFailureException(int errorCode)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "explicit RowReader::RowReader(bool keepWhitespace, char delim)": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 3, + "dels": 0 + } + }, + "size": null + }, "inline std::string to_string(const std::pair &value)": { "files": [ "Utility.h" @@ -522,6 +778,30 @@ }, "size": null }, + "size_t RowReader::LineNumber() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "static std::string ArgumentException::BuildMessage(const std::string &message, const std::string &argumentName)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 5, + "dels": 0 + } + }, + "size": null + }, "std::shared_ptr safe_pointer_cast(const std::shared_ptr &obj)": { "files": [ "Utility.h" @@ -582,6 +862,18 @@ }, "size": null }, + "void RowReader::ResetLineNumber()": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "void ValidateStream(const TStream &stream)": { "files": [ "Utility.h" diff --git a/test/test_analytics/baseline/cpp_test_repo/D.g.json b/test/test_analytics/baseline/cpp_test_repo/D.g.json index aa0ec8956b9..e5eb44a4f6d 100644 --- a/test/test_analytics/baseline/cpp_test_repo/D.g.json +++ b/test/test_analytics/baseline/cpp_test_repo/D.g.json @@ -1,5 +1,9 @@ { "edges": { + "ArgumentException::ArgumentException(const std::string &message, const std::string &argumentName)|->|static std::string ArgumentException::BuildMessage(const std::string &message, const std::string &argumentName)": { + "addedBy": "A", + "weight": null + }, "ConfigurationParser::ConfigurationParser(std::filesystem::path filePath)|->|TStream OpenAndValidate(const TPath arg1)": { "addedBy": "D", "weight": null @@ -150,6 +154,66 @@ }, "size": null }, + "ArgumentException::ArgumentException(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 2, + "dels": 0 + } + }, + "size": null + }, + "ArgumentException::ArgumentException(const std::string &message, const std::string &argumentName)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 2, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler &BlockExitHandler::operator=(const BlockExitHandler &) = delete": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler::BlockExitHandler(const BlockExitHandler &) = delete": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "BlockExitHandler::~BlockExitHandler() noexcept": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 11, + "dels": 0 + } + }, + "size": null + }, "ConfigurationParser::ConfigurationParser(std::filesystem::path filePath)": { "files": [ "TextFileParsers.cpp" @@ -174,6 +238,42 @@ }, "size": null }, + "Exception::Exception()": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "Exception::~Exception() noexcept": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "InvalidCastException::InvalidCastException(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "RowReader &operator>>(RowReader &reader, bool &rhs)": { "files": [ "TextFileParsers.cpp" @@ -254,6 +354,18 @@ }, "size": null }, + "RowReader::operator bool() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, "TDest safe_cast(TSrc obj)": { "files": [ "Utility.h" @@ -290,6 +402,30 @@ }, "size": null }, + "TIterator _RangeToEnumerable::begin()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "TIterator _RangeToEnumerable::end()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "TStream &operator>>(TStream &s, RowReader &reader)": { "files": [ "TextFileParsers.h" @@ -350,6 +486,18 @@ }, "size": null }, + "_RangeToEnumerable::_RangeToEnumerable(const std::pair range)": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "_RangeToEnumerable RangeToEnumerable(const std::pair range)": { "files": [ "Utility.h" @@ -426,6 +574,30 @@ }, "size": null }, + "bool RowReader::operator!() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "bool _RangeToEnumerable::empty()": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "bool dynamic_kind_of(const TSrc *obj)": { "files": [ "Utility.h" @@ -450,6 +622,18 @@ }, "size": null }, + "const char *Exception::what() const noexcept": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "const char *FriendlyNameOf()": { "files": [ "Utility.h" @@ -462,6 +646,30 @@ }, "size": null }, + "const std::string &ArgumentException::ArgumentName() const": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "const std::stringstream &RowReader::LineStream() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "double ConfigurationParser::GetDouble(const std::string &key, double defaultValue) const": { "files": [ "TextFileParsers.cpp" @@ -494,6 +702,54 @@ }, "size": null }, + "explicit BlockExitHandler::BlockExitHandler(const std::function &handler)": { + "files": [ + "Utility.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "explicit Exception::Exception(const std::string &message)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 6, + "dels": 0 + } + }, + "size": null + }, + "explicit OperationFailureException::OperationFailureException(int errorCode)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 4, + "dels": 0 + } + }, + "size": null + }, + "explicit RowReader::RowReader(bool keepWhitespace, char delim)": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 3, + "dels": 0 + } + }, + "size": null + }, "inline std::string to_string(const std::pair &value)": { "files": [ "Utility.h" @@ -542,6 +798,30 @@ }, "size": null }, + "size_t RowReader::LineNumber() const": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, + "static std::string ArgumentException::BuildMessage(const std::string &message, const std::string &argumentName)": { + "files": [ + "Exceptions.h" + ], + "history": { + "A": { + "adds": 5, + "dels": 0 + } + }, + "size": null + }, "std::shared_ptr safe_pointer_cast(const std::shared_ptr &obj)": { "files": [ "Utility.h" @@ -602,6 +882,18 @@ }, "size": null }, + "void RowReader::ResetLineNumber()": { + "files": [ + "TextFileParsers.h" + ], + "history": { + "A": { + "adds": 1, + "dels": 0 + } + }, + "size": null + }, "void ValidateStream(const TStream &stream)": { "files": [ "Utility.h" diff --git a/test/test_analytics/test_analyzer_lsp_ccls.py b/test/test_analytics/test_analyzer_lsp_ccls.py index 0b903fb9e2e..420de70a369 100644 --- a/test/test_analytics/test_analyzer_lsp_ccls.py +++ b/test/test_analytics/test_analyzer_lsp_ccls.py @@ -4,7 +4,6 @@ import subprocess from pathlib import Path from tempfile import mkdtemp -from .utility.graph_baseline import GraphDumpAnalyzerObserver import networkx.readwrite.json_graph import pytest @@ -17,6 +16,11 @@ from persper.analytics.lsp_graph_server.ccls import CclsGraphServer from persper.util.path import root_path +from .utility.graph_baseline import GraphDumpAnalyzerObserver + +# Whether we are generating graph dump baseline, rather than testing for regression. +IS_GENERATING_BASELINE = True + _logger = logging.getLogger() testDataRoot = os.path.dirname(os.path.abspath(__file__)) @@ -49,6 +53,14 @@ def createCclsGraphServer(): return graphServer +def createGraphDumpAnalyzerObserver(testName: str): + return GraphDumpAnalyzerObserver( + None if IS_GENERATING_BASELINE else + os.path.join(testDataRoot, "baseline/" + testName), + os.path.join(testDataRoot, "actualdump/" + testName), + dumpNaming=CommitIdGenerators.fromComment) + + @pytest.mark.asyncio async def testFeatureBranchFirstParent(): """ @@ -58,9 +70,8 @@ async def testFeatureBranchFirstParent(): graphServer = createCclsGraphServer() analyzer = Analyzer(repoPath, graphServer, firstParentOnly=True) async with graphServer: - analyzer.observer = GraphDumpAnalyzerObserver( - os.path.join(testDataRoot, "baseline/feature_branch_first_parent"), - os.path.join(testDataRoot, "actualdump/feature_branch_first_parent")) + analyzer.observer = createGraphDumpAnalyzerObserver( + "feature_branch_first_parent") await analyzer.analyze() @@ -73,9 +84,7 @@ async def testFeatureBranch(): graphServer = createCclsGraphServer() analyzer = Analyzer(repoPath, graphServer, firstParentOnly=False) async with graphServer: - analyzer.observer = GraphDumpAnalyzerObserver( - os.path.join(testDataRoot, "baseline/feature_branch"), - os.path.join(testDataRoot, "actualdump/feature_branch")) + analyzer.observer = createGraphDumpAnalyzerObserver("feature_branch") await analyzer.analyze() @@ -85,7 +94,5 @@ async def testCppTestRepo(): graphServer = createCclsGraphServer() analyzer = Analyzer(repoPath, graphServer) async with graphServer: - analyzer.observer = GraphDumpAnalyzerObserver( - os.path.join(testDataRoot, "baseline/cpp_test_repo"), - os.path.join(testDataRoot, "actualdump/cpp_test_repo")) + analyzer.observer = createGraphDumpAnalyzerObserver("cpp_test_repo") await analyzer.analyze() diff --git a/test/test_analytics/utility/graph_baseline.py b/test/test_analytics/utility/graph_baseline.py index 8323f5455a5..96527e86e8b 100644 --- a/test/test_analytics/utility/graph_baseline.py +++ b/test/test_analytics/utility/graph_baseline.py @@ -11,7 +11,7 @@ from networkx import Graph from persper.analytics.analyzer2 import Analyzer, AnalyzerObserver -from persper.analytics.call_commit_graph import CallCommitGraph +from persper.analytics.call_commit_graph import CallCommitGraph, CommitIdGenerators from persper.analytics.graph_server import CommitSeekingMode _logger = logging.getLogger() @@ -66,12 +66,6 @@ def assertGraphMatches(baseline: dict, ccg: CallCommitGraph): assert not baselineEdgeIds, str.format( "Branch(es) missing: {0}.", baselineEdgeIds) - -class GraphDumpNamingRule(Enum): - CommitMessage = 0, - CommitHexSha = 1 - - class GraphDumpAnalyzerObserver(AnalyzerObserver): """ An implementation of AnalyzerObserver that generates graph dump after each commit, @@ -79,7 +73,7 @@ class GraphDumpAnalyzerObserver(AnalyzerObserver): """ def __init__(self, graphBaselineDumpPath: str = None, graphTestDumpPath: str = None, - dumpOnlyOnError: bool = None, dumpNaming: GraphDumpNamingRule = GraphDumpNamingRule.CommitHexSha): + dumpOnlyOnError: bool = None, dumpNaming = CommitIdGenerators.fromHexsha): """ Params: graphBaselineDumpPath: root folder of the baseline graph dump files. Set to values other than `None` @@ -105,11 +99,13 @@ def __init__(self, graphBaselineDumpPath: str = None, graphTestDumpPath: str = N else: self._dumpPath = None self._dumpOnlyOnError = graphBaselineDumpPath != None if dumpOnlyOnError == None else dumpOnlyOnError + self._dumpNaming = dumpNaming def onAfterCommit(self, analyzer: Analyzer, commit: Commit, seeking_mode: CommitSeekingMode): if seeking_mode == CommitSeekingMode.Rewind: return graph: CallCommitGraph = analyzer.graph + graphDumpLocalName = self._dumpNaming(-1, commit.hexsha, commit.message) + ".g.json" def dumpGraph(warnIfNotAvailable: bool): if not self._dumpPath: @@ -118,16 +114,14 @@ def dumpGraph(warnIfNotAvailable: bool): "Cannot dump call commit graph because no dump path has been specified. Commit %s: %s.", commit.hexsha, commit.message) return False data = graphToDict(graph) - graphPath = self._dumpPath.joinpath( - commit.message.strip() + ".g.json") + graphPath = self._dumpPath.joinpath(graphDumpLocalName) with open(graphPath, "wt") as f: json.dump(data, f, sort_keys=True, indent=4) return True # check baseline for regression if self._baselinePath: try: - graphPath = self._baselinePath.joinpath( - commit.message.strip() + ".g.json") + graphPath = self._baselinePath.joinpath(graphDumpLocalName) baselineData: dict = None with open(graphPath, "rt") as f: baselineData = fixGraphDict(json.load(f)) From 87781b23f341d125f0fc7565272156d6c672de73 Mon Sep 17 00:00:00 2001 From: xinyan Date: Mon, 11 Mar 2019 23:36:03 +0800 Subject: [PATCH 6/9] Add pickle test. Bug fix: analyzer2.Analyzer didn't populate _visitedCommits. --- persper/analytics/analyzer2.py | 7 ++++- test/test_analytics/test_analyzer_lsp_ccls.py | 26 +++++++++++++++++++ 2 files changed, 32 insertions(+), 1 deletion(-) diff --git a/persper/analytics/analyzer2.py b/persper/analytics/analyzer2.py index 4db0b058e67..cbea197c685 100644 --- a/persper/analytics/analyzer2.py +++ b/persper/analytics/analyzer2.py @@ -39,6 +39,10 @@ def __setstate__(self, state): self.terminalCommit = state["_terminalCommit"] self._s_visitedCommits = _ReadOnlySet(self._visitedCommits) + @property + def graphServer(self): + return self._graphServer + @property def observer(self): """ @@ -97,7 +101,7 @@ def visitedCommits(self) -> Set[str]: return self._s_visitedCommits async def analyze(self, maxAnalyzedCommits=1000): - graphServerLastCommit:str = None + graphServerLastCommit: str = None commitSpec = self._terminalCommit if self._originCommit: commitSpec = self._originCommit.hexsha + ".." + self._terminalCommit.hexsha @@ -138,6 +142,7 @@ def printCommitStatus(status: str): # then go on with current commit printCommitStatus("Going forward.") await self._analyzeCommit(commit, parent, CommitSeekingMode.NormalForward) + self._visitedCommits.add(commit.hexsha) graphServerLastCommit = commit.hexsha analyzedCommits += 1 diff --git a/test/test_analytics/test_analyzer_lsp_ccls.py b/test/test_analytics/test_analyzer_lsp_ccls.py index 420de70a369..33d17e06f32 100644 --- a/test/test_analytics/test_analyzer_lsp_ccls.py +++ b/test/test_analytics/test_analyzer_lsp_ccls.py @@ -1,6 +1,7 @@ import json import logging import os +import pickle import subprocess from pathlib import Path from tempfile import mkdtemp @@ -96,3 +97,28 @@ async def testCppTestRepo(): async with graphServer: analyzer.observer = createGraphDumpAnalyzerObserver("cpp_test_repo") await analyzer.analyze() + + +@pytest.mark.asyncio +async def testAnalyzerWithPickle(): + repoPath = prepareRepo("test_feature_branch") + graphServer = createCclsGraphServer() + analyzer = Analyzer(repoPath, graphServer) + pickleContent = None + async with graphServer: + analyzer.observer = createGraphDumpAnalyzerObserver( + "analyzer_pickling") + assert len(analyzer.visitedCommits) == 0 + await analyzer.analyze(2) + assert len(analyzer.visitedCommits) == 2 + await analyzer.analyze(2) + assert len(analyzer.visitedCommits) == 4 + pickleContent = pickle.dumps(analyzer) + + analyzer1: Analyzer = pickle.loads(pickleContent) + # Perhaps we need to set another temp folder for this. + graphServer1 = analyzer1.graphServer + analyzer1.observer = analyzer.observer + async with graphServer1: + assert analyzer1.visitedCommits == analyzer.visitedCommits + await analyzer1.analyze() From e87f8eec82d96a0086fbd909bb91239955cc0294 Mon Sep 17 00:00:00 2001 From: xinyan Date: Mon, 11 Mar 2019 23:46:46 +0800 Subject: [PATCH 7/9] Code cleanup. --- persper/analytics/analyzer2.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/persper/analytics/analyzer2.py b/persper/analytics/analyzer2.py index a2aef476bd8..c670ed74bd5 100644 --- a/persper/analytics/analyzer2.py +++ b/persper/analytics/analyzer2.py @@ -1,13 +1,13 @@ import asyncio -from abc import ABC import collections.abc -from typing import Union, Set, Optional, List +from abc import ABC +from typing import List, Optional, Set, Union from git import Commit, Diff, DiffIndex, Repo -from persper.analytics.git_tools import (diff_with_commit, get_contents) -from persper.analytics.graph_server import CommitSeekingMode, GraphServer from persper.analytics.commit_classifier import CommitClassifier +from persper.analytics.git_tools import diff_with_commit, get_contents +from persper.analytics.graph_server import CommitSeekingMode, GraphServer from persper.analytics.score import commit_overall_scores From 2c9bd1875dcdd934f691db730632198a7d7374df Mon Sep 17 00:00:00 2001 From: Hezheng Yin Date: Mon, 11 Mar 2019 13:51:48 -0700 Subject: [PATCH 8/9] Encapsulate files attribute of function nodes --- persper/analytics/call_commit_graph.py | 11 ++++++++--- persper/analytics/call_graph/c.py | 6 ++++-- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/persper/analytics/call_commit_graph.py b/persper/analytics/call_commit_graph.py index 3b2627b53f5..ec5a3a2b3b0 100644 --- a/persper/analytics/call_commit_graph.py +++ b/persper/analytics/call_commit_graph.py @@ -7,6 +7,7 @@ from networkx.readwrite import json_graph from persper.analytics.devrank import devrank from persper.analytics.score import normalize +from typing import Union, Set, List, Dict class CommitIdGenerators: @@ -59,6 +60,10 @@ def commits(self): # https://networkx.github.io/documentation/stable/tutorial.html#graph-attributes return self._digraph.graph['commits'] + def files(self, node: str) -> Set[str]: + """Provide read-only access to `files` attribute of a node""" + return self.nodes()[node]['files'] + def __contains__(self, node): """Implement membership check""" return node in self._digraph @@ -82,7 +87,7 @@ def _next_cindex(self): return self._cur_cindex() + 1 # TODO: remove the default value of files - def add_node(self, node, files=[]): + def add_node(self, node: str, files: Union[Set[str], List[str]] = []): self._digraph.add_node(node, size=None, history={}, files=set(files)) # add_node must be called on source and target first @@ -106,10 +111,10 @@ def update_node_history(self, node, num_adds, num_dels): node_history[self._current_commit_id] = {'adds': num_adds, 'dels': num_dels} # read/write access to node history are thourgh this function - def _get_node_history(self, node): + def _get_node_history(self, node: str) -> Dict[str, Dict[str, int]]: return self._digraph.nodes[node]['history'] - def update_node_files(self, node, new_files): + def update_node_files(self, node: str, new_files: Union[Set[str], List[str]]): self._digraph.nodes[node]['files'] = set(new_files) # TODO: provide other options for computing a node's size diff --git a/persper/analytics/call_graph/c.py b/persper/analytics/call_graph/c.py index 961f147d755..18d84449ede 100644 --- a/persper/analytics/call_graph/c.py +++ b/persper/analytics/call_graph/c.py @@ -1,4 +1,5 @@ from persper.analytics.call_graph.utils import ns, line_attr +from typing import Set class NotFunctionCallError(Exception): @@ -83,9 +84,10 @@ def update_graph(ccgraph, ast_list, change_stats): if caller_name not in ccgraph: ccgraph.add_node(caller_name, [filename]) else: - files = ccgraph.nodes()[caller_name]['files'] + files: Set[str] = ccgraph.files(caller_name) if filename not in files: - ccgraph.update_node_files(caller_name, files + [filename]) + files.add(filename) + ccgraph.update_node_files(caller_name, files) for call in function.xpath('.//srcml:call', namespaces=ns): try: From 8e1e55bed9fd5dfbc4b87e54ec96d75a0cb11ba2 Mon Sep 17 00:00:00 2001 From: Hezheng Yin Date: Mon, 11 Mar 2019 16:11:42 -0700 Subject: [PATCH 9/9] Fix transforming graph_data to networkx's node link format --- persper/analytics/call_commit_graph.py | 17 +++++++++++++---- persper/analytics/go.py | 5 +---- 2 files changed, 14 insertions(+), 8 deletions(-) diff --git a/persper/analytics/call_commit_graph.py b/persper/analytics/call_commit_graph.py index ec5a3a2b3b0..6d3db3bb0f1 100644 --- a/persper/analytics/call_commit_graph.py +++ b/persper/analytics/call_commit_graph.py @@ -7,7 +7,7 @@ from networkx.readwrite import json_graph from persper.analytics.devrank import devrank from persper.analytics.score import normalize -from typing import Union, Set, List, Dict +from typing import Union, Set, List, Dict, Optional class CommitIdGenerators: @@ -30,14 +30,23 @@ class CallCommitGraph: and edit histories across commits. """ - def __init__(self, node_link_data=None, commit_id_generator=CommitIdGenerators.fromHexsha): - if node_link_data: - self._digraph = json_graph.node_link_graph(node_link_data) + def __init__(self, graph_data: Optional[Dict] = None, commit_id_generator=CommitIdGenerators.fromHexsha): + if graph_data: + self._digraph = json_graph.node_link_graph( + CallCommitGraph._to_networkx_format(graph_data)) else: self._digraph = self._new_graph() self._commit_id_generator = commit_id_generator self._current_commit_id = None + @staticmethod + def _to_networkx_format(graph_data: Dict) -> Dict: + graph_data['multigraph'] = False + graph_data['directed'] = True + for node in graph_data['nodes']: + node['files'] = set(node['files']) + return graph_data + def reset(self): """Reset all internal states""" self._digraph = self._new_graph() diff --git a/persper/analytics/go.py b/persper/analytics/go.py index 284ab5cf6d0..e4a39fb178d 100644 --- a/persper/analytics/go.py +++ b/persper/analytics/go.py @@ -40,10 +40,7 @@ def update_graph(self, old_filename, old_src, def get_graph(self): graph_url = self.server_addr + '/callgraph' r = requests.get(graph_url) - graph_data = r.json() - graph_data['directed'] = True - graph_data['multigraph'] = False - return CallCommitGraph(graph_data) + return CallCommitGraph(graph_data=r.json()) def reset_graph(self): reset_url = urllib.parse.urljoin(self.server_addr, '/reset')