kadircet created this revision. kadircet added a reviewer: sammccall. Herald added subscribers: cfe-commits, usaxena95, arphaman, jkorous, MaskRay, ilya-biryukov. Herald added a project: clang. kadircet added a parent revision: D75176: [clangd] Get rid of getBeginningOfIdentifier helper.
Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D75193 Files: clang-tools-extra/clangd/AST.cpp clang-tools-extra/clangd/AST.h Index: clang-tools-extra/clangd/AST.h =================================================================== --- clang-tools-extra/clangd/AST.h +++ clang-tools-extra/clangd/AST.h @@ -109,7 +109,6 @@ QualType declaredType(const TypeDecl *D); /// Retrieves the deduced type at a given location (auto, decltype). -/// Retuns None unless Loc starts an auto/decltype token. /// It will return the underlying type. llvm::Optional<QualType> getDeducedType(ASTContext &, SourceLocation Loc); Index: clang-tools-extra/clangd/AST.cpp =================================================================== --- clang-tools-extra/clangd/AST.cpp +++ clang-tools-extra/clangd/AST.cpp @@ -25,7 +25,6 @@ #include "clang/Basic/SourceManager.h" #include "clang/Basic/Specifiers.h" #include "clang/Index/USRGeneration.h" -#include "clang/Lex/Lexer.h" #include "llvm/ADT/ArrayRef.h" #include "llvm/ADT/Optional.h" #include "llvm/ADT/STLExtras.h" @@ -417,16 +416,8 @@ llvm::Optional<QualType> getDeducedType(ASTContext &ASTCtx, SourceLocation Loc) { - Token Tok; - // Only try to find a deduced type if the token is auto or decltype. - if (!Loc.isValid() || - Lexer::getRawToken(Loc, Tok, ASTCtx.getSourceManager(), - ASTCtx.getLangOpts(), false) || - !Tok.is(tok::raw_identifier) || - !(Tok.getRawIdentifier() == "auto" || - Tok.getRawIdentifier() == "decltype")) { + if (!Loc.isValid()) return {}; - } DeducedTypeVisitor V(Loc); V.TraverseAST(ASTCtx); if (V.DeducedType.isNull())
Index: clang-tools-extra/clangd/AST.h =================================================================== --- clang-tools-extra/clangd/AST.h +++ clang-tools-extra/clangd/AST.h @@ -109,7 +109,6 @@ QualType declaredType(const TypeDecl *D); /// Retrieves the deduced type at a given location (auto, decltype). -/// Retuns None unless Loc starts an auto/decltype token. /// It will return the underlying type. llvm::Optional<QualType> getDeducedType(ASTContext &, SourceLocation Loc); Index: clang-tools-extra/clangd/AST.cpp =================================================================== --- clang-tools-extra/clangd/AST.cpp +++ clang-tools-extra/clangd/AST.cpp @@ -25,7 +25,6 @@ #include "clang/Basic/SourceManager.h" #include "clang/Basic/Specifiers.h" #include "clang/Index/USRGeneration.h" -#include "clang/Lex/Lexer.h" #include "llvm/ADT/ArrayRef.h" #include "llvm/ADT/Optional.h" #include "llvm/ADT/STLExtras.h" @@ -417,16 +416,8 @@ llvm::Optional<QualType> getDeducedType(ASTContext &ASTCtx, SourceLocation Loc) { - Token Tok; - // Only try to find a deduced type if the token is auto or decltype. - if (!Loc.isValid() || - Lexer::getRawToken(Loc, Tok, ASTCtx.getSourceManager(), - ASTCtx.getLangOpts(), false) || - !Tok.is(tok::raw_identifier) || - !(Tok.getRawIdentifier() == "auto" || - Tok.getRawIdentifier() == "decltype")) { + if (!Loc.isValid()) return {}; - } DeducedTypeVisitor V(Loc); V.TraverseAST(ASTCtx); if (V.DeducedType.isNull())
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits