aboutsummaryrefslogtreecommitdiff
path: root/test/Index/complete-macros.c
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2010-08-13 22:48:40 +0000
committerDouglas Gregor <dgregor@apple.com>2010-08-13 22:48:40 +0000
commit87c08a5d6b9e1e44ae6f554df40139d3a6f60b33 (patch)
treecabd7c3f202bd39288d6caf39d63b32c0818cd0b /test/Index/complete-macros.c
parentcd2d2b7814e0104ed41a8da159a06a8ca77b70d8 (diff)
Implement caching of code-completion results for macro definitions
when the CXTranslationUnit_CacheCompletionResults option is given to clang_parseTranslationUnit(). Essentially, we compute code-completion results for macro definitions after we have parsed the file, then store an ASTContext-agnostic version of those results (completion string, cursor kind, priority, and active contexts) in the ASTUnit. When performing code completion in that ASTUnit, we splice the macro definition results into the results provided by the actual code-completion (which has had macros turned off) before libclang gets those results. We use completion context information to only splice in those results that make sense for that context. With a completion involving all of the macros from Cocoa.h and a few other system libraries (totally ~8500 macro definitions) living in a precompiled header, we get about a 9% performance improvement from code completion, since we no longer have to deserialize all of the macro definitions from the precompiled header. Note that macro definitions are merely the canary; the cache is designed to also support other top-level declarations, which should be a bigger performance win. That optimization will be next. Note also that there is no mechanism for determining when to throw away the cache and recompute its contents. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@111051 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Index/complete-macros.c')
-rw-r--r--test/Index/complete-macros.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/test/Index/complete-macros.c b/test/Index/complete-macros.c
index 9a898e152a..d0974db31f 100644
--- a/test/Index/complete-macros.c
+++ b/test/Index/complete-macros.c
@@ -16,6 +16,7 @@ void f2() {
}
// RUN: c-index-test -code-completion-at=%s:7:1 %s | FileCheck -check-prefix=CHECK-CC1 %s
+// RUN: env CINDEXTEST_EDITING=1 CINDEXTEST_COMPLETION_CACHING=1 c-index-test -code-completion-at=%s:7:1 %s | FileCheck -check-prefix=CHECK-CC1 %s
// CHECK-CC1: macro definition:{TypedText FOO}{LeftParen (}{Placeholder Arg1}{Comma , }{Placeholder Arg2}{RightParen )}
// RUN: c-index-test -code-completion-at=%s:13:13 %s | FileCheck -check-prefix=CHECK-CC2 %s
// RUN: c-index-test -code-completion-at=%s:14:8 %s | FileCheck -check-prefix=CHECK-CC2 %s