|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 209613 | 
| | 
| 
| 
| | llvm-svn: 207896 | 
| | 
| 
| 
| 
| 
| | result to consider the completion context
llvm-svn: 174037 | 
| | 
| 
| 
| | llvm-svn: 173277 | 
| | 
| 
| 
| 
| 
| | brought into 'clang' namespace by clang/Basic/LLVM.h
llvm-svn: 172323 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | uncovered.
This required manually correcting all of the incorrect main-module
headers I could find, and running the new llvm/utils/sort_includes.py
script over the files.
I also manually added quite a few missing headers that were uncovered by
shuffling the order or moving headers up to be main-module-headers.
llvm-svn: 169237 | 
| | 
| 
| 
| 
| 
| | This is to reduce dependency to cursors for the code-completion results.
llvm-svn: 164705 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | attached to a declaration in the completion string.
Since extracting comments isn't free, a new code completion option is
introduced.
A new code completion option that enables including brief comments
into CodeCompletionString should be a, err, code completion option.
But because ASTUnit caches global declarations during parsing before
even completion consumer is created, the option is duplicated as a
translation unit option (in both libclang and ASTUnit, like the option
to cache code completion results).
llvm-svn: 159539 | 
| | 
| 
| 
| | llvm-svn: 157158 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | code-completion related strings specific to a translation unit (ASTContext and related data)
CodeCompletionAllocator does such limited caching, by caching the name assigned
to a DeclContext*, but that is not the appropriate place since that object has
a lifetime that can extend beyond that of an ASTContext.
Introduce CodeCompletionTUInfo which will be always tied to a translation unit
to do this kind of caching and move the caching of CodeCompletionAllocator into this
object, and propagate it to all the places where it will be needed.
The plan is to extend the caching where appropriate, using CodeCompletionTUInfo,
to avoid re-calculating code-completion strings.
Part of rdar://10796159.
llvm-svn: 154408 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | completion item. For example, if the code completion itself represents
a declaration in a namespace (say, std::vector), then this API
retrieves the cursor kind and name of the namespace (std). Implements
<rdar://problem/11121951>.
llvm-svn: 153545 | 
| | 
| 
| 
| 
| 
| 
| | This makes sense because chunk's ctor is also out of line and simplifies considerably
when inlined with a constant parameter. Shrinks clang on i386-linux-Release+Asserts by 65k.
llvm-svn: 153446 | 
| | 
| 
| 
| 
| 
| 
| | the availability of the enumeration type itself. Fixes
<rdar://problem/10996386>.
llvm-svn: 152977 | 
| | 
| 
| 
| 
| 
| 
| | (I was going to fix the TODO about DenseMap too, but
that would break self-host right now. See PR11922.)
llvm-svn: 149799 | 
| | 
| 
| 
| 
| 
| 
| 
| | include.
Fix all the transitive include users.
llvm-svn: 149783 | 
| | 
| 
| 
| 
| 
| | appropriate or when GCC requires it)
llvm-svn: 148292 | 
| | 
| 
| 
| 
| 
| | ObjCProtocolDecl modules forward declarations properly.
llvm-svn: 147415 | 
| | 
| 
| 
| 
| 
| 
| | covers both declarations (@class) and definitions (@interface) of an
Objective-C class.
llvm-svn: 147299 | 
| | 
| 
| 
| 
| 
| 
| 
| | of a pointer.
Passing a pointer was a bad idea as it collides with the overload for void*.
llvm-svn: 141971 | 
| | 
| 
| 
| 
| 
| | retrieve annotations from completion string.
llvm-svn: 141953 | 
| | 
| 
| 
| 
| 
| | available, but not accessible from the current code completion context.
llvm-svn: 141278 | 
| | 
| 
| 
| 
| 
| 
| 
| | already-defined and forward-declared results. Already-defined results
are fine because they could be the start of a category. Fixes
<rdar://problem/9811691>.
llvm-svn: 136559 | 
| | 
| 
| 
| 
| 
| 
| 
| | LLVM.h imports
them into the clang namespace.
llvm-svn: 135852 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | clang_codeCompleteGetContexts(), that provides the client with
information about the context in which code completion has occurred
and what kinds of entities make sense as completions at that
point. Patch by Connor Wakamo!
llvm-svn: 134615 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | which versions of an OS provide a certain facility. For example,
  void foo()
  __attribute__((availability(macosx,introduced=10.2,deprecated=10.4,obsoleted=10.6)));
says that the function "foo" was introduced in 10.2, deprecated in
10.4, and completely obsoleted in 10.6. This attribute ties in with
the deployment targets (e.g., -mmacosx-version-min=10.1 specifies that
we want to deploy back to Mac OS X 10.1). There are several concrete
behaviors that this attribute enables, as illustrated with the
function foo() above:
  - If we choose a deployment target >= Mac OS X 10.4, uses of "foo"
    will result in a deprecation warning, as if we had placed
    attribute((deprecated)) on it (but with a better diagnostic)
  - If we choose a deployment target >= Mac OS X 10.6, uses of "foo"
    will result in an "unavailable" warning (in C)/error (in C++), as
    if we had placed attribute((unavailable)) on it
  - If we choose a deployment target prior to 10.2, foo() is
    weak-imported (if it is a kind of entity that can be weak
    imported), as if we had placed the weak_import attribute on it.
Naturally, there can be multiple availability attributes on a
declaration, for different platforms; only the current platform
matters when checking availability attributes.
The only platforms this attribute currently works for are "ios" and
"macosx", since we already have -mxxxx-version-min flags for them and we
have experience there with macro tricks translating down to the
deprecated/unavailable/weak_import attributes. The end goal is to open
this up to other platforms, and even extension to other "platforms"
that are really libraries (say, through a #pragma clang
define_system), but that hasn't yet been designed and we may want to
shake out more issues with this narrower problem first.
Addresses <rdar://problem/6690412>.
As a drive-by bug-fix, if an entity is both deprecated and
unavailable, we only emit the "unavailable" diagnostic.
llvm-svn: 128127 | 
| | 
| 
| 
| 
| 
| 
| | enumeration type, prioritize the enumeration constants and don't
provide completions for any other expressions. Fixes <rdar://problem/7283668>.
llvm-svn: 125991 | 
| | 
| 
| 
| 
| 
| | (KVC) and Key-Value Observing (KVO) protocols.
llvm-svn: 125696 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | savings of 25% sounds impressive, except that this amounted to only
about 360k in our standard "large" completion result set (40,000
results). Since code completion is performance-sensitive, the 4%
slowdown due to uniquing outweighs the 360k benefit. 
llvm-svn: 124737 | 
| | 
| 
| 
| 
| 
| | speed but saves us about 25% of the memory usage for strings.
llvm-svn: 124704 | 
| | 
| 
| 
| 
| 
| 
| | the string copying goes through a single place that can have
associated state.
llvm-svn: 124698 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | BumpPtrAllocator, rather than manually new/delete'ing them. This
optimization also allows us to avoid allocating memory for and copying
constant strings (e.g., "return", "class").
This also required embedding the priority and availability of results
within the code completion string, to avoid extra memory allocation
within libclang.
llvm-svn: 124673 | 
| | 
| 
| 
| 
| 
| | libclang does not support out-of-process code completion.
llvm-svn: 116253 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | provided when the optimization is disabled. In particular, split
the completion context CCC_Other into two contexts: CCC_Other, which
means that it's an undisclosed context for which any other results are
unwelcome, and CCC_Recovery, which is used in recovery cases.
Since we're now using the completion context within the completion
results builder, make sure that it's always set to something.
Fixes <rdar://problem/8470644>.
llvm-svn: 114704 | 
| | 
| 
| 
| 
| 
| | class template) and are in a context where we can have a value.
llvm-svn: 114441 | 
| | 
| 
| 
| 
| 
| | very rarely used.
llvm-svn: 114286 | 
| | 
| 
| 
| 
| 
| | kinds. How shameful that this code was duplicated!
llvm-svn: 113033 | 
| | 
| 
| 
| | llvm-svn: 112968 | 
| | 
| 
| 
| 
| 
| | semantics slightly. No functionality change in the absence of inline namespaces. Also, change a few places where inline namespaces actually make a difference to be prepared for them.
llvm-svn: 112563 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | into the clients, e.g., the printing code-completion consumer and
c-index-test. Clients may want to re-sort the results anyway.
Provide a libclang function that sorts the results.
3rd try. How embarrassing.
llvm-svn: 112180 | 
| | 
| 
| 
| 
| 
| | path and ...", it is failing tests.
llvm-svn: 112161 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | into the clients, e.g., the printing code-completion consumer and
c-index-test. Clients may want to re-sort the results anyway.
Provide a libclang function that sorts the results.
llvm-svn: 112149 | 
| | 
| 
| 
| 
| 
| 
| | into the clients", because the C standard library sucks. Where's my
stable sort, huh?
llvm-svn: 112121 | 
| | 
| 
| 
| 
| 
| 
| | into the clients, e.g., the printing code-completion consumer and
c-index-test. Clients may want to re-sort the results anyway.
llvm-svn: 112095 | 
| | 
| 
| 
| 
| 
| 
| 
| | code-completion results cached by ASTUnit, sort the resulting result
set. This makes testing far, far easier, so this commit also includes
tests for the previous few fixes.
llvm-svn: 112070 | 
| | 
| 
| 
| | llvm-svn: 112028 | 
| | 
| 
| 
| | llvm-svn: 112026 | 
| | 
| 
| 
| | llvm-svn: 111904 | 
| | 
| 
| 
| 
| 
| 
| | of a cursor or code-completion result, e.g., whether that result
refers to an unavailable, deleted, or deprecated declaration.
llvm-svn: 111858 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | - move DeclSpec &c into the Sema library
  - move ParseAST into the Parse library
Reflect this change in a thousand different includes.
Reflect this change in the link orders.
llvm-svn: 111667 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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.
llvm-svn: 111051 |