//===--- HeuristicResolver.h - Resolution of dependent names -----*- 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 // //===----------------------------------------------------------------------===// #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANGD_HEURISTICRESOLVER_H #define LLVM_CLANG_TOOLS_EXTRA_CLANGD_HEURISTICRESOLVER_H #include "clang/AST/Decl.h" #include <vector> namespace clang { class ASTContext; class CallExpr; class CXXBasePath; class CXXDependentScopeMemberExpr; class DeclarationName; class DependentScopeDeclRefExpr; class NamedDecl; class Type; class UnresolvedUsingValueDecl; namespace clangd { // This class heuristic resolution of declarations and types in template code. // // As a compiler, clang only needs to perform certain types of processing on // template code (such as resolving dependent names to declarations, or // resolving the type of a dependent expression) after instantiation. Indeed, // C++ language features such as template specialization mean such resolution // cannot be done accurately before instantiation // // However, template code is written and read in uninstantiated form, and clangd // would like to provide editor features like go-to-definition in template code // where possible. To this end, clangd attempts to resolve declarations and // types in uninstantiated code by using heuristics, understanding that the // results may not be fully accurate but that this is better than nothing. // // At this time, the heuristic used is a simple but effective one: assume that // template instantiations are based on the primary template definition and not // not a specialization. More advanced heuristics may be added in the future. class HeuristicResolver { … }; } // namespace clangd } // namespace clang #endif