diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2015-12-30 13:34:49 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2015-12-30 13:34:49 +0000 | 
| commit | 0623d7483df5fc17b32ba7bc5cb9c7beebf6db9c (patch) | |
| tree | 28726ef2038e86121e353aabf52297b35a48efa2 /contrib/llvm/tools/clang/lib/Sema/SemaCodeComplete.cpp | |
| parent | 7d523365ff1a3cc95bc058b33102500f61e8166d (diff) | |
| parent | 45b533945f0851ec234ca846e1af5ee1e4df0b6e (diff) | |
Notes
Diffstat (limited to 'contrib/llvm/tools/clang/lib/Sema/SemaCodeComplete.cpp')
| -rw-r--r-- | contrib/llvm/tools/clang/lib/Sema/SemaCodeComplete.cpp | 49 | 
1 files changed, 25 insertions, 24 deletions
| diff --git a/contrib/llvm/tools/clang/lib/Sema/SemaCodeComplete.cpp b/contrib/llvm/tools/clang/lib/Sema/SemaCodeComplete.cpp index 86265275d05e..21cf62585142 100644 --- a/contrib/llvm/tools/clang/lib/Sema/SemaCodeComplete.cpp +++ b/contrib/llvm/tools/clang/lib/Sema/SemaCodeComplete.cpp @@ -494,6 +494,7 @@ bool ResultBuilder::isInterestingDecl(const NamedDecl *ND,                                        bool &AsNestedNameSpecifier) const {    AsNestedNameSpecifier = false; +  auto *Named = ND;    ND = ND->getUnderlyingDecl();    // Skip unnamed entities. @@ -526,14 +527,14 @@ bool ResultBuilder::isInterestingDecl(const NamedDecl *ND,          return false;    if (Filter == &ResultBuilder::IsNestedNameSpecifier || -      ((isa<NamespaceDecl>(ND) || isa<NamespaceAliasDecl>(ND)) && +      (isa<NamespaceDecl>(ND) &&         Filter != &ResultBuilder::IsNamespace &&         Filter != &ResultBuilder::IsNamespaceOrAlias &&         Filter != nullptr))      AsNestedNameSpecifier = true;    // Filter out any unwanted results. -  if (Filter && !(this->*Filter)(ND)) { +  if (Filter && !(this->*Filter)(Named)) {      // Check whether it is interesting as a nested-name-specifier.      if (AllowNestedNameSpecifiers && SemaRef.getLangOpts().CPlusPlus &&           IsNestedNameSpecifier(ND) && @@ -1142,14 +1143,12 @@ bool ResultBuilder::IsNamespace(const NamedDecl *ND) const {  /// \brief Determines whether the given declaration is a namespace or   /// namespace alias.  bool ResultBuilder::IsNamespaceOrAlias(const NamedDecl *ND) const { -  return isa<NamespaceDecl>(ND) || isa<NamespaceAliasDecl>(ND); +  return isa<NamespaceDecl>(ND->getUnderlyingDecl());  }  /// \brief Determines whether the given declaration is a type.  bool ResultBuilder::IsType(const NamedDecl *ND) const { -  if (const UsingShadowDecl *Using = dyn_cast<UsingShadowDecl>(ND)) -    ND = Using->getTargetDecl(); -   +  ND = ND->getUnderlyingDecl();    return isa<TypeDecl>(ND) || isa<ObjCInterfaceDecl>(ND);  } @@ -1157,11 +1156,9 @@ bool ResultBuilder::IsType(const NamedDecl *ND) const {  /// "." or "->".  Only value declarations, nested name specifiers, and  /// using declarations thereof should show up.  bool ResultBuilder::IsMember(const NamedDecl *ND) const { -  if (const UsingShadowDecl *Using = dyn_cast<UsingShadowDecl>(ND)) -    ND = Using->getTargetDecl(); - +  ND = ND->getUnderlyingDecl();    return isa<ValueDecl>(ND) || isa<FunctionTemplateDecl>(ND) || -    isa<ObjCPropertyDecl>(ND); +         isa<ObjCPropertyDecl>(ND);  }  static bool isObjCReceiverType(ASTContext &C, QualType T) { @@ -3036,6 +3033,7 @@ CXCursorKind clang::getCursorKindForDecl(const Decl *D) {      case Decl::ParmVar:            return CXCursor_ParmDecl;      case Decl::Typedef:            return CXCursor_TypedefDecl;      case Decl::TypeAlias:          return CXCursor_TypeAliasDecl; +    case Decl::TypeAliasTemplate:  return CXCursor_TypeAliasTemplateDecl;      case Decl::Var:                return CXCursor_VarDecl;      case Decl::Namespace:          return CXCursor_Namespace;      case Decl::NamespaceAlias:     return CXCursor_NamespaceAlias; @@ -3376,7 +3374,7 @@ void Sema::CodeCompleteOrdinaryName(Scope *S,    case PCC_Statement:    case PCC_RecoveryInFunction:      if (S->getFnParent()) -      AddPrettyFunctionResults(PP.getLangOpts(), Results);         +      AddPrettyFunctionResults(getLangOpts(), Results);      break;    case PCC_Namespace: @@ -3520,7 +3518,7 @@ void Sema::CodeCompleteExpression(Scope *S,    if (S->getFnParent() &&         !Data.ObjCCollection &&         !Data.IntegralConstantExpression) -    AddPrettyFunctionResults(PP.getLangOpts(), Results);         +    AddPrettyFunctionResults(getLangOpts(), Results);    if (CodeCompleter->includeMacros())      AddMacroResults(PP, Results, false, PreferredTypeIsPointer); @@ -4051,7 +4049,7 @@ void Sema::CodeCompleteCall(Scope *S, Expr *Fn, ArrayRef<Expr *> Args) {        // If expression's type is CXXRecordDecl, it may overload the function        // call operator, so we check if it does and add them as candidates.        // A complete type is needed to lookup for member function call operators. -      if (!RequireCompleteType(Loc, NakedFn->getType(), 0)) { +      if (isCompleteType(Loc, NakedFn->getType())) {          DeclarationName OpName = Context.DeclarationNames                                   .getCXXOperatorName(OO_Call);          LookupResult R(*this, OpName, Loc, LookupOrdinaryName); @@ -4093,7 +4091,7 @@ void Sema::CodeCompleteConstructor(Scope *S, QualType Type, SourceLocation Loc,      return;    // A complete type is needed to lookup for constructors. -  if (RequireCompleteType(Loc, Type, 0)) +  if (!isCompleteType(Loc, Type))      return;    CXXRecordDecl *RD = Type->getAsCXXRecordDecl(); @@ -4205,7 +4203,7 @@ void Sema::CodeCompleteAfterIf(Scope *S) {    Results.ExitScope();    if (S->getFnParent()) -    AddPrettyFunctionResults(PP.getLangOpts(), Results);         +    AddPrettyFunctionResults(getLangOpts(), Results);    if (CodeCompleter->includeMacros())      AddMacroResults(PP, Results, false); @@ -4912,7 +4910,7 @@ void Sema::CodeCompleteObjCPropertyFlags(Scope *S, ObjCDeclSpec &ODS) {      Results.AddResult(CodeCompletionResult("atomic"));    // Only suggest "weak" if we're compiling for ARC-with-weak-references or GC. -  if (getLangOpts().ObjCARCWeak || getLangOpts().getGC() != LangOptions::NonGC) +  if (getLangOpts().ObjCWeak || getLangOpts().getGC() != LangOptions::NonGC)      if (!ObjCPropertyFlagConflicts(Attributes, ObjCDeclSpec::DQ_PR_weak))        Results.AddResult(CodeCompletionResult("weak")); @@ -5925,8 +5923,8 @@ static void AddProtocolResults(DeclContext *Ctx, DeclContext *CurContext,    }  } -void Sema::CodeCompleteObjCProtocolReferences(IdentifierLocPair *Protocols, -                                              unsigned NumProtocols) { +void Sema::CodeCompleteObjCProtocolReferences( +                                        ArrayRef<IdentifierLocPair> Protocols) {    ResultBuilder Results(*this, CodeCompleter->getAllocator(),                          CodeCompleter->getCodeCompletionTUInfo(),                          CodeCompletionContext::CCC_ObjCProtocolName); @@ -5937,9 +5935,9 @@ void Sema::CodeCompleteObjCProtocolReferences(IdentifierLocPair *Protocols,      // Tell the result set to ignore all of the protocols we have      // already seen.      // FIXME: This doesn't work when caching code-completion results. -    for (unsigned I = 0; I != NumProtocols; ++I) -      if (ObjCProtocolDecl *Protocol = LookupProtocol(Protocols[I].first, -                                                      Protocols[I].second)) +    for (const IdentifierLocPair &Pair : Protocols) +      if (ObjCProtocolDecl *Protocol = LookupProtocol(Pair.first, +                                                      Pair.second))          Results.Ignore(Protocol);      // Add all protocols. @@ -7079,11 +7077,13 @@ void Sema::CodeCompleteObjCMethodDecl(Scope *S,      // If the result type was not already provided, add it to the      // pattern as (type). -    if (ReturnType.isNull()) -      AddObjCPassingTypeChunk(Method->getSendResultType() -                                  .stripObjCKindOfType(Context), +    if (ReturnType.isNull()) { +      QualType ResTy = Method->getSendResultType().stripObjCKindOfType(Context); +      AttributedType::stripOuterNullability(ResTy); +      AddObjCPassingTypeChunk(ResTy,                                Method->getObjCDeclQualifier(), Context, Policy,                                Builder); +    }      Selector Sel = Method->getSelector(); @@ -7114,6 +7114,7 @@ void Sema::CodeCompleteObjCMethodDecl(Scope *S,          ParamType = (*P)->getOriginalType();        ParamType = ParamType.substObjCTypeArgs(Context, {},                                              ObjCSubstitutionContext::Parameter); +      AttributedType::stripOuterNullability(ParamType);        AddObjCPassingTypeChunk(ParamType,                                (*P)->getObjCDeclQualifier(),                                Context, Policy, | 
