From: Douglas Gregor Date: Mon, 12 Jul 2010 18:38:41 +0000 (+0000) Subject: Add a -code-completion-timing= mode to c-index-test, so that we can X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1982c18522a4aefd57207bbd2d66d93945c41f92;p=clang Add a -code-completion-timing= mode to c-index-test, so that we can test the performance of code-completion without testing the performance of printf(). git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@108172 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/tools/c-index-test/c-index-test.c b/tools/c-index-test/c-index-test.c index 8106d20490..4ed24b15c9 100644 --- a/tools/c-index-test/c-index-test.c +++ b/tools/c-index-test/c-index-test.c @@ -799,7 +799,7 @@ void print_completion_result(CXCompletionResult *completion_result, clang_getCompletionPriority(completion_result->CompletionString)); } -int perform_code_completion(int argc, const char **argv) { +int perform_code_completion(int argc, const char **argv, int timing_only) { const char *input = argv[1]; char *filename = 0; unsigned line; @@ -810,7 +810,11 @@ int perform_code_completion(int argc, const char **argv) { int num_unsaved_files = 0; CXCodeCompleteResults *results = 0; - input += strlen("-code-completion-at="); + if (timing_only) + input += strlen("-code-completion-timing="); + else + input += strlen("-code-completion-at="); + if ((errorCode = parse_file_line_column(input, &filename, &line, &column, 0, 0))) return errorCode; @@ -827,8 +831,9 @@ int perform_code_completion(int argc, const char **argv) { if (results) { unsigned i, n = results->NumResults; - for (i = 0; i != n; ++i) - print_completion_result(results->Results + i, stdout); + if (!timing_only) + for (i = 0; i != n; ++i) + print_completion_result(results->Results + i, stdout); n = clang_codeCompleteGetNumDiagnostics(results); for (i = 0; i != n; ++i) { CXDiagnostic diag = clang_codeCompleteGetDiagnostic(results, i); @@ -1204,6 +1209,7 @@ static CXCursorVisitor GetVisitor(const char *s) { static void print_usage(void) { fprintf(stderr, "usage: c-index-test -code-completion-at= \n" + " c-index-test -code-completion-timing= \n" " c-index-test -cursor-at= \n" " c-index-test -test-file-scan " "[FileCheck prefix]\n" @@ -1211,9 +1217,9 @@ static void print_usage(void) { "[FileCheck prefix]\n" " c-index-test -test-load-tu-usrs " "[FileCheck prefix]\n" - " c-index-test -test-load-source {}*\n" - " c-index-test -test-load-source-usrs {}*\n"); + " c-index-test -test-load-source {}*\n"); fprintf(stderr, + " c-index-test -test-load-source-usrs {}*\n" " c-index-test -test-annotate-tokens= {}*\n" " c-index-test -test-inclusion-stack-source {}*\n" " c-index-test -test-inclusion-stack-tu \n" @@ -1235,7 +1241,9 @@ static void print_usage(void) { int main(int argc, const char **argv) { clang_enableStackTraces(); if (argc > 2 && strstr(argv[1], "-code-completion-at=") == argv[1]) - return perform_code_completion(argc, argv); + return perform_code_completion(argc, argv, 0); + if (argc > 2 && strstr(argv[1], "-code-completion-timing=") == argv[1]) + return perform_code_completion(argc, argv, 1); if (argc > 2 && strstr(argv[1], "-cursor-at=") == argv[1]) return inspect_cursor_at(argc, argv); else if (argc >= 4 && strncmp(argv[1], "-test-load-tu", 13) == 0) {