diff options
| author | Douglas Gregor <dgregor@apple.com> | 2010-08-23 23:00:57 +0000 | 
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2010-08-23 23:00:57 +0000 | 
| commit | f757a12dfc91b3ac8464ba2c9971d92e4bfafbec (patch) | |
| tree | e52d519b2d3cf34dbab08bde2054153f9eb2a5d6 /clang/tools | |
| parent | 616d3e71c24e2e724d83a2f3f4d885310e6fe479 (diff) | |
| download | bcm5719-llvm-f757a12dfc91b3ac8464ba2c9971d92e4bfafbec.tar.gz bcm5719-llvm-f757a12dfc91b3ac8464ba2c9971d92e4bfafbec.zip | |
Introduce new libclang API functions that determine the availability
of a cursor or code-completion result, e.g., whether that result
refers to an unavailable, deleted, or deprecated declaration.
llvm-svn: 111858
Diffstat (limited to 'clang/tools')
| -rw-r--r-- | clang/tools/c-index-test/c-index-test.c | 28 | ||||
| -rw-r--r-- | clang/tools/libclang/CIndex.cpp | 15 | ||||
| -rw-r--r-- | clang/tools/libclang/CIndexCodeCompletion.cpp | 25 | ||||
| -rw-r--r-- | clang/tools/libclang/libclang.darwin.exports | 2 | ||||
| -rw-r--r-- | clang/tools/libclang/libclang.exports | 2 | 
5 files changed, 67 insertions, 5 deletions
| diff --git a/clang/tools/c-index-test/c-index-test.c b/clang/tools/c-index-test/c-index-test.c index 95dbd45d8bf..330fa545f93 100644 --- a/clang/tools/c-index-test/c-index-test.c +++ b/clang/tools/c-index-test/c-index-test.c @@ -182,6 +182,19 @@ static void PrintCursor(CXCursor Cursor) {      if (clang_isCursorDefinition(Cursor))        printf(" (Definition)"); +     +    switch (clang_getCursorAvailability(Cursor)) { +      case CXAvailability_Available: +        break; +         +      case CXAvailability_Deprecated: +        printf(" (deprecated)"); +        break; +         +      case CXAvailability_NotAvailable: +        printf(" (unavailable)"); +        break; +    }    }  } @@ -865,8 +878,21 @@ void print_completion_result(CXCompletionResult *completion_result,    clang_disposeString(ks);    print_completion_string(completion_result->CompletionString, file); -  fprintf(file, " (%u)\n",  +  fprintf(file, " (%u)",             clang_getCompletionPriority(completion_result->CompletionString)); +  switch (clang_getCompletionAvailability(completion_result->CompletionString)){ +  case CXAvailability_Available: +    break; +     +  case CXAvailability_Deprecated: +    fprintf(file, " (deprecated)"); +    break; +     +  case CXAvailability_NotAvailable: +    fprintf(file, " (unavailable)"); +    break; +  } +  fprintf(file, "\n");  }  int perform_code_completion(int argc, const char **argv, int timing_only) { diff --git a/clang/tools/libclang/CIndex.cpp b/clang/tools/libclang/CIndex.cpp index a98f064e6f9..e59bdde43d5 100644 --- a/clang/tools/libclang/CIndex.cpp +++ b/clang/tools/libclang/CIndex.cpp @@ -3018,6 +3018,21 @@ static CXLanguageKind getDeclLanguage(const Decl *D) {  }  extern "C" { +   +enum CXAvailabilityKind clang_getCursorAvailability(CXCursor cursor) { +  if (clang_isDeclaration(cursor.kind)) +    if (Decl *D = cxcursor::getCursorDecl(cursor)) { +      if (D->hasAttr<UnavailableAttr>() || +          (isa<FunctionDecl>(D) && cast<FunctionDecl>(D)->isDeleted())) +        return CXAvailability_Available; +       +      if (D->hasAttr<DeprecatedAttr>()) +        return CXAvailability_Deprecated; +    } +   +  return CXAvailability_Available; +} +  CXLanguageKind clang_getCursorLanguage(CXCursor cursor) {    if (clang_isDeclaration(cursor.kind))      return getDeclLanguage(cxcursor::getCursorDecl(cursor)); diff --git a/clang/tools/libclang/CIndexCodeCompletion.cpp b/clang/tools/libclang/CIndexCodeCompletion.cpp index c2febf9b722..e99927b5b96 100644 --- a/clang/tools/libclang/CIndexCodeCompletion.cpp +++ b/clang/tools/libclang/CIndexCodeCompletion.cpp @@ -48,11 +48,15 @@ namespace {    /// This is the representation behind a CXCompletionString.    class CXStoredCodeCompletionString : public CodeCompletionString {      unsigned Priority; +    CXAvailabilityKind Availability;    public: -    CXStoredCodeCompletionString(unsigned Priority) : Priority(Priority) { } +    CXStoredCodeCompletionString(unsigned Priority, +                                 CXAvailabilityKind Availability)  +      : Priority(Priority), Availability(Availability) { }      unsigned getPriority() const { return Priority; } +    CXAvailabilityKind getAvailability() const { return Availability; }    };  } @@ -210,6 +214,13 @@ unsigned clang_getCompletionPriority(CXCompletionString completion_string) {    return CCStr? CCStr->getPriority() : unsigned(CCP_Unlikely);  } +enum CXAvailabilityKind  +clang_getCompletionAvailability(CXCompletionString completion_string) { +  CXStoredCodeCompletionString *CCStr +    = (CXStoredCodeCompletionString *)completion_string; +  return CCStr? CCStr->getAvailability() : CXAvailability_Available; +} +  static bool ReadUnsigned(const char *&Memory, const char *MemoryEnd,                           unsigned &Value) {    if (Memory + sizeof(unsigned) > MemoryEnd) @@ -433,8 +444,13 @@ CXCodeCompleteResults *clang_codeComplete(CXIndex CIdx,        if (ReadUnsigned(Str, StrEnd, Priority))          break; +      unsigned Availability; +      if (ReadUnsigned(Str, StrEnd, Availability)) +        break; +              CXStoredCodeCompletionString *CCStr -        = new CXStoredCodeCompletionString(Priority); +        = new CXStoredCodeCompletionString(Priority,  +                                           (CXAvailabilityKind)Availability);        if (!CCStr->Deserialize(Str, StrEnd)) {          delete CCStr;          continue; @@ -559,7 +575,8 @@ namespace {        AllocatedResults.NumResults = NumResults;        for (unsigned I = 0; I != NumResults; ++I) {          CXStoredCodeCompletionString *StoredCompletion -          = new CXStoredCodeCompletionString(Results[I].Priority); +          = new CXStoredCodeCompletionString(Results[I].Priority, +                                             Results[I].Availability);          (void)Results[I].CreateCodeCompletionString(S, StoredCompletion);          AllocatedResults.Results[I].CursorKind = Results[I].CursorKind;          AllocatedResults.Results[I].CompletionString = StoredCompletion; @@ -743,7 +760,7 @@ void clang_disposeCodeCompleteResults(CXCodeCompleteResults *ResultsIn) {      = static_cast<AllocatedCXCodeCompleteResults*>(ResultsIn);    delete Results;  } - +    unsigned   clang_codeCompleteGetNumDiagnostics(CXCodeCompleteResults *ResultsIn) {    AllocatedCXCodeCompleteResults *Results diff --git a/clang/tools/libclang/libclang.darwin.exports b/clang/tools/libclang/libclang.darwin.exports index 444d669e67b..f2087b73f2b 100644 --- a/clang/tools/libclang/libclang.darwin.exports +++ b/clang/tools/libclang/libclang.darwin.exports @@ -32,11 +32,13 @@ _clang_formatDiagnostic  _clang_getCString  _clang_getCanonicalType  _clang_getClangVersion +_clang_getCompletionAvailability  _clang_getCompletionChunkCompletionString  _clang_getCompletionChunkKind  _clang_getCompletionChunkText  _clang_getCompletionPriority  _clang_getCursor +_clang_getCursorAvailability  _clang_getCursorDefinition  _clang_getCursorExtent  _clang_getCursorKind diff --git a/clang/tools/libclang/libclang.exports b/clang/tools/libclang/libclang.exports index a1e114afd91..c1658f6032c 100644 --- a/clang/tools/libclang/libclang.exports +++ b/clang/tools/libclang/libclang.exports @@ -32,11 +32,13 @@ clang_formatDiagnostic  clang_getCString  clang_getCanonicalType  clang_getClangVersion +clang_getCompletionAvailability  clang_getCompletionChunkCompletionString  clang_getCompletionChunkKind  clang_getCompletionChunkText  clang_getCompletionPriority  clang_getCursor +clang_getCursorAvailability  clang_getCursorDefinition  clang_getCursorExtent  clang_getCursorKind | 

