diff options
| -rw-r--r-- | clang/include/clang/Sema/CodeCompleteConsumer.h | 10 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaCodeComplete.cpp | 14 | ||||
| -rw-r--r-- | clang/tools/libclang/CXCursor.cpp | 18 | 
3 files changed, 25 insertions, 17 deletions
| diff --git a/clang/include/clang/Sema/CodeCompleteConsumer.h b/clang/include/clang/Sema/CodeCompleteConsumer.h index 9a06fa813e5..9e1c7e257c7 100644 --- a/clang/include/clang/Sema/CodeCompleteConsumer.h +++ b/clang/include/clang/Sema/CodeCompleteConsumer.h @@ -17,6 +17,7 @@  #include "clang-c/Index.h"  #include "clang/AST/Type.h"  #include "clang/Basic/LLVM.h" +#include "clang/Lex/MacroInfo.h"  #include "clang/Sema/CodeCompleteOptions.h"  #include "clang/Sema/DeclSpec.h"  #include "llvm/ADT/ArrayRef.h" @@ -843,6 +844,11 @@ public:    /// corresponding `using decl::qualified::name;` nearby.    const UsingShadowDecl *ShadowDecl = nullptr; +  /// If the result is RK_Macro, this can store the information about the macro +  /// definition. This should be set in most cases but can be missing when +  /// the macro has been undefined. +  const MacroInfo *MacroDefInfo = nullptr; +    /// Build a result that refers to a declaration.    CodeCompletionResult(const NamedDecl *Declaration, unsigned Priority,                         NestedNameSpecifier *Qualifier = nullptr, @@ -867,11 +873,13 @@ public:    /// Build a result that refers to a macro.    CodeCompletionResult(const IdentifierInfo *Macro, +                       const MacroInfo *MI = nullptr,                         unsigned Priority = CCP_Macro)        : Macro(Macro), Priority(Priority), Kind(RK_Macro),          CursorKind(CXCursor_MacroDefinition), Hidden(false),          QualifierIsInformative(false), StartsNestedNameSpecifier(false), -        AllParametersAreInformative(false), DeclaringEntity(false) {} +        AllParametersAreInformative(false), DeclaringEntity(false), +        MacroDefInfo(MI) {}    /// Build a result that refers to a pattern.    CodeCompletionResult(CodeCompletionString *Pattern, diff --git a/clang/lib/Sema/SemaCodeComplete.cpp b/clang/lib/Sema/SemaCodeComplete.cpp index e0adf38f93e..7ba94c6e0e2 100644 --- a/clang/lib/Sema/SemaCodeComplete.cpp +++ b/clang/lib/Sema/SemaCodeComplete.cpp @@ -3313,14 +3313,14 @@ static void AddMacroResults(Preprocessor &PP, ResultBuilder &Results,         M != MEnd; ++M) {      auto MD = PP.getMacroDefinition(M->first);      if (IncludeUndefined || MD) { -      if (MacroInfo *MI = MD.getMacroInfo()) -        if (MI->isUsedForHeaderGuard()) -          continue; +      MacroInfo *MI = MD.getMacroInfo(); +      if (MI && MI->isUsedForHeaderGuard()) +        continue; -      Results.AddResult(Result(M->first, -                             getMacroUsagePriority(M->first->getName(), -                                                   PP.getLangOpts(), -                                                   TargetTypeIsPointer))); +      Results.AddResult( +          Result(M->first, MI, +                 getMacroUsagePriority(M->first->getName(), PP.getLangOpts(), +                                       TargetTypeIsPointer)));      }    } diff --git a/clang/tools/libclang/CXCursor.cpp b/clang/tools/libclang/CXCursor.cpp index e69143cee01..890bec7b824 100644 --- a/clang/tools/libclang/CXCursor.cpp +++ b/clang/tools/libclang/CXCursor.cpp @@ -1412,16 +1412,16 @@ CXCompletionString clang_getCursorCompletionString(CXCursor cursor) {      }    } else if (kind == CXCursor_MacroDefinition) {      const MacroDefinitionRecord *definition = getCursorMacroDefinition(cursor); -    const IdentifierInfo *MacroInfo = definition->getName(); +    const IdentifierInfo *Macro = definition->getName();      ASTUnit *unit = getCursorASTUnit(cursor); -    CodeCompletionResult Result(MacroInfo); -    CodeCompletionString *String -      = Result.CreateCodeCompletionString(unit->getASTContext(), -                                          unit->getPreprocessor(), -                                          CodeCompletionContext::CCC_Other, -                                 unit->getCodeCompletionTUInfo().getAllocator(), -                                 unit->getCodeCompletionTUInfo(), -                                 false); +    CodeCompletionResult Result( +        Macro, +        unit->getPreprocessor().getMacroDefinition(Macro).getMacroInfo()); +    CodeCompletionString *String = Result.CreateCodeCompletionString( +        unit->getASTContext(), unit->getPreprocessor(), +        CodeCompletionContext::CCC_Other, +        unit->getCodeCompletionTUInfo().getAllocator(), +        unit->getCodeCompletionTUInfo(), false);      return String;    }    return nullptr; | 

