//===--- XRefs.h -------------------------------------------------*- C++-*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // Features that traverse references between symbols. // //===----------------------------------------------------------------------===// #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANGD_XREFS_H #define LLVM_CLANG_TOOLS_EXTRA_CLANGD_XREFS_H #include "Protocol.h" #include "SourceCode.h" #include "index/Index.h" #include "index/SymbolID.h" #include "support/Path.h" #include "clang/AST/ASTTypeTraits.h" #include "llvm/ADT/StringRef.h" #include "llvm/Support/raw_ostream.h" #include #include namespace clang { namespace syntax { class Token; class TokenBuffer; } // namespace syntax namespace clangd { class ParsedAST; // Describes where a symbol is declared and defined (as far as clangd knows). // There are three cases: // - a declaration only, no definition is known (e.g. only header seen) // - a declaration and a distinct definition (e.g. function declared in header) // - a declaration and an equal definition (e.g. inline function, or class) // For some types of symbol, e.g. macros, definition == declaration always. struct LocatedSymbol { // The (unqualified) name of the symbol. std::string Name; // The canonical or best declaration: where most users find its interface. Location PreferredDeclaration; // Where the symbol is defined, if known. May equal PreferredDeclaration. std::optional Definition; // SymbolID of the located symbol if available. SymbolID ID; }; llvm::raw_ostream &operator<<(llvm::raw_ostream &, const LocatedSymbol &); /// Get definition of symbol at a specified \p Pos. /// Multiple locations may be returned, corresponding to distinct symbols. std::vector locateSymbolAt(ParsedAST &AST, Position Pos, const SymbolIndex *Index = nullptr); // Tries to provide a textual fallback for locating a symbol by looking up the // word under the cursor as a symbol name in the index. // The aim is to pick up references to symbols in contexts where // AST-based resolution does not work, such as comments, strings, and PP // disabled regions. // (This is for internal use by locateSymbolAt, and is exposed for testing). std::vector locateSymbolTextually(const SpelledWord &Word, ParsedAST &AST, const SymbolIndex *Index, llvm::StringRef MainFilePath, ASTNodeKind NodeKind); // Try to find a proximate occurrence of `Word` as an identifier, which can be // used to resolve it. // (This is for internal use by locateSymbolAt, and is exposed for testing). const syntax::Token *findNearbyIdentifier(const SpelledWord &Word, const syntax::TokenBuffer &TB); /// Get all document links std::vector getDocumentLinks(ParsedAST &AST); /// Returns highlights for all usages of a symbol at \p Pos. std::vector findDocumentHighlights(ParsedAST &AST, Position Pos); struct ReferencesResult { // Bitmask describing whether the occurrence is a declaration, definition etc. enum ReferenceAttributes : unsigned { Declaration = 1 << 0, Definition = 1 << 1, // The occurrence is an override of the target base method. Override = 1 << 2, }; struct Reference { ReferenceLocation Loc; unsigned Attributes = 0; }; std::vector References; bool HasMore = false; }; llvm::raw_ostream &operator<<(llvm::raw_ostream &, const ReferencesResult::Reference &); /// Returns implementations at a specified \p Pos: /// - overrides for a virtual method; /// - subclasses for a base class; std::vector findImplementations(ParsedAST &AST, Position Pos, const SymbolIndex *Index); /// Returns symbols for types referenced at \p Pos. /// /// For example, given `b^ar()` wher bar return Foo, this function returns the /// definition of class Foo. std::vector findType(ParsedAST &AST, Position Pos, const SymbolIndex *Index); /// Returns references of the symbol at a specified \p Pos. /// \p Limit limits the number of results returned (0 means no limit). ReferencesResult findReferences(ParsedAST &AST, Position Pos, uint32_t Limit, const SymbolIndex *Index = nullptr, bool AddContext = false); /// Get info about symbols at \p Pos. std::vector getSymbolInfo(ParsedAST &AST, Position Pos); /// Find the record types referenced at \p Pos. std::vector findRecordTypeAt(ParsedAST &AST, Position Pos); /// Given a record type declaration, find its base (parent) types. std::vector typeParents(const CXXRecordDecl *CXXRD); /// Get type hierarchy information at \p Pos. std::vector getTypeHierarchy( ParsedAST &AST, Position Pos, int Resolve, TypeHierarchyDirection Direction, const SymbolIndex *Index = nullptr, PathRef TUPath = PathRef{}); /// Returns direct parents of a TypeHierarchyItem using SymbolIDs stored inside /// the item. std::optional> superTypes(const TypeHierarchyItem &Item, const SymbolIndex *Index); /// Returns direct children of a TypeHierarchyItem. std::vector subTypes(const TypeHierarchyItem &Item, const SymbolIndex *Index); void resolveTypeHierarchy(TypeHierarchyItem &Item, int ResolveLevels, TypeHierarchyDirection Direction, const SymbolIndex *Index); /// Get call hierarchy information at \p Pos. std::vector prepareCallHierarchy(ParsedAST &AST, Position Pos, PathRef TUPath); std::vector incomingCalls(const CallHierarchyItem &Item, const SymbolIndex *Index); /// Returns all decls that are referenced in the \p FD except local symbols. llvm::DenseSet getNonLocalDeclRefs(ParsedAST &AST, const FunctionDecl *FD); } // namespace clangd } // namespace clang #endif // LLVM_CLANG_TOOLS_EXTRA_CLANGD_XREFS_H