[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
//===--- Hover.cpp - Information about code at the cursor location --------===//
|
|
|
|
//
|
|
|
|
// 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
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "Hover.h"
|
|
|
|
|
|
|
|
#include "AST.h"
|
|
|
|
#include "CodeCompletionStrings.h"
|
|
|
|
#include "FindTarget.h"
|
2019-12-10 17:28:37 +08:00
|
|
|
#include "FormattedString.h"
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
#include "Logger.h"
|
2020-01-10 20:11:09 +08:00
|
|
|
#include "ParsedAST.h"
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
#include "Selection.h"
|
|
|
|
#include "SourceCode.h"
|
|
|
|
#include "index/SymbolCollector.h"
|
2019-11-17 05:15:05 +08:00
|
|
|
#include "clang/AST/ASTContext.h"
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
#include "clang/AST/ASTTypeTraits.h"
|
2019-12-16 21:22:48 +08:00
|
|
|
#include "clang/AST/Decl.h"
|
|
|
|
#include "clang/AST/DeclBase.h"
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
#include "clang/AST/DeclTemplate.h"
|
2020-01-10 20:11:09 +08:00
|
|
|
#include "clang/AST/Expr.h"
|
|
|
|
#include "clang/AST/ExprCXX.h"
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
#include "clang/AST/PrettyPrinter.h"
|
2020-01-07 22:15:00 +08:00
|
|
|
#include "clang/AST/Type.h"
|
[clangd] Store index::SymbolKind in HoverInfo
Summary:
LSP's SymbolKind has some shortcomings when it comes to C++ types,
index::SymbolKind has more detailed info like Destructor, Parameter, MACRO etc.
We are planning to make use of that information in our new Hover response, and
it would be nice to display the Symbol type in full detail, rather than some
approximation.
Reviewers: sammccall
Subscribers: ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70723
2019-11-27 01:06:17 +08:00
|
|
|
#include "clang/Index/IndexSymbol.h"
|
2020-01-10 20:11:09 +08:00
|
|
|
#include "llvm/ADT/None.h"
|
|
|
|
#include "llvm/ADT/Optional.h"
|
2019-12-16 21:22:48 +08:00
|
|
|
#include "llvm/ADT/STLExtras.h"
|
2019-12-13 16:34:59 +08:00
|
|
|
#include "llvm/ADT/SmallVector.h"
|
|
|
|
#include "llvm/ADT/StringExtras.h"
|
|
|
|
#include "llvm/ADT/StringRef.h"
|
2020-01-10 20:11:09 +08:00
|
|
|
#include "llvm/Support/Casting.h"
|
|
|
|
#include "llvm/Support/ErrorHandling.h"
|
[clangd] Store index::SymbolKind in HoverInfo
Summary:
LSP's SymbolKind has some shortcomings when it comes to C++ types,
index::SymbolKind has more detailed info like Destructor, Parameter, MACRO etc.
We are planning to make use of that information in our new Hover response, and
it would be nice to display the Symbol type in full detail, rather than some
approximation.
Reviewers: sammccall
Subscribers: ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70723
2019-11-27 01:06:17 +08:00
|
|
|
#include "llvm/Support/raw_ostream.h"
|
2019-12-13 16:34:59 +08:00
|
|
|
#include <string>
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace clangd {
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
PrintingPolicy printingPolicyForDecls(PrintingPolicy Base) {
|
|
|
|
PrintingPolicy Policy(Base);
|
|
|
|
|
|
|
|
Policy.AnonymousTagLocations = false;
|
|
|
|
Policy.TerseOutput = true;
|
|
|
|
Policy.PolishForDeclaration = true;
|
|
|
|
Policy.ConstantsAsWritten = true;
|
|
|
|
Policy.SuppressTagKeyword = false;
|
|
|
|
|
|
|
|
return Policy;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Given a declaration \p D, return a human-readable string representing the
|
|
|
|
/// local scope in which it is declared, i.e. class(es) and method name. Returns
|
|
|
|
/// an empty string if it is not local.
|
|
|
|
std::string getLocalScope(const Decl *D) {
|
|
|
|
std::vector<std::string> Scopes;
|
|
|
|
const DeclContext *DC = D->getDeclContext();
|
|
|
|
auto GetName = [](const TypeDecl *D) {
|
|
|
|
if (!D->getDeclName().isEmpty()) {
|
|
|
|
PrintingPolicy Policy = D->getASTContext().getPrintingPolicy();
|
|
|
|
Policy.SuppressScope = true;
|
|
|
|
return declaredType(D).getAsString(Policy);
|
|
|
|
}
|
|
|
|
if (auto RD = dyn_cast<RecordDecl>(D))
|
|
|
|
return ("(anonymous " + RD->getKindName() + ")").str();
|
|
|
|
return std::string("");
|
|
|
|
};
|
|
|
|
while (DC) {
|
|
|
|
if (const TypeDecl *TD = dyn_cast<TypeDecl>(DC))
|
|
|
|
Scopes.push_back(GetName(TD));
|
|
|
|
else if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(DC))
|
|
|
|
Scopes.push_back(FD->getNameAsString());
|
|
|
|
DC = DC->getParent();
|
|
|
|
}
|
|
|
|
|
|
|
|
return llvm::join(llvm::reverse(Scopes), "::");
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Returns the human-readable representation for namespace containing the
|
|
|
|
/// declaration \p D. Returns empty if it is contained global namespace.
|
|
|
|
std::string getNamespaceScope(const Decl *D) {
|
|
|
|
const DeclContext *DC = D->getDeclContext();
|
|
|
|
|
2019-12-16 21:22:48 +08:00
|
|
|
if (const TagDecl *TD = dyn_cast<TagDecl>(DC))
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
return getNamespaceScope(TD);
|
|
|
|
if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(DC))
|
|
|
|
return getNamespaceScope(FD);
|
2019-12-16 21:22:48 +08:00
|
|
|
if (const NamespaceDecl *NSD = dyn_cast<NamespaceDecl>(DC)) {
|
|
|
|
// Skip inline/anon namespaces.
|
|
|
|
if (NSD->isInline() || NSD->isAnonymousNamespace())
|
|
|
|
return getNamespaceScope(NSD);
|
|
|
|
}
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
if (const NamedDecl *ND = dyn_cast<NamedDecl>(DC))
|
2019-12-16 21:22:48 +08:00
|
|
|
return printQualifiedName(*ND);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string printDefinition(const Decl *D) {
|
|
|
|
std::string Definition;
|
|
|
|
llvm::raw_string_ostream OS(Definition);
|
|
|
|
PrintingPolicy Policy =
|
|
|
|
printingPolicyForDecls(D->getASTContext().getPrintingPolicy());
|
|
|
|
Policy.IncludeTagDefinition = false;
|
|
|
|
Policy.SuppressTemplateArgsInCXXConstructors = true;
|
2020-01-07 22:15:00 +08:00
|
|
|
Policy.SuppressTagKeyword = true;
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
D->print(OS, Policy);
|
|
|
|
OS.flush();
|
|
|
|
return Definition;
|
|
|
|
}
|
|
|
|
|
|
|
|
void printParams(llvm::raw_ostream &OS,
|
2019-12-12 02:14:15 +08:00
|
|
|
const std::vector<HoverInfo::Param> &Params) {
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
for (size_t I = 0, E = Params.size(); I != E; ++I) {
|
|
|
|
if (I)
|
|
|
|
OS << ", ";
|
|
|
|
OS << Params.at(I);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-16 22:20:13 +08:00
|
|
|
std::string printType(QualType QT, const PrintingPolicy &Policy) {
|
|
|
|
// TypePrinter doesn't resolve decltypes, so resolve them here.
|
|
|
|
// FIXME: This doesn't handle composite types that contain a decltype in them.
|
|
|
|
// We should rather have a printing policy for that.
|
|
|
|
while (const auto *DT = QT->getAs<DecltypeType>())
|
|
|
|
QT = DT->getUnderlyingType();
|
|
|
|
return QT.getAsString(Policy);
|
|
|
|
}
|
|
|
|
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
std::vector<HoverInfo::Param>
|
|
|
|
fetchTemplateParameters(const TemplateParameterList *Params,
|
|
|
|
const PrintingPolicy &PP) {
|
|
|
|
assert(Params);
|
|
|
|
std::vector<HoverInfo::Param> TempParameters;
|
|
|
|
|
|
|
|
for (const Decl *Param : *Params) {
|
|
|
|
HoverInfo::Param P;
|
2020-01-16 22:20:13 +08:00
|
|
|
if (const auto *TTP = dyn_cast<TemplateTypeParmDecl>(Param)) {
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
P.Type = TTP->wasDeclaredWithTypename() ? "typename" : "class";
|
|
|
|
if (TTP->isParameterPack())
|
|
|
|
*P.Type += "...";
|
|
|
|
|
|
|
|
if (!TTP->getName().empty())
|
|
|
|
P.Name = TTP->getNameAsString();
|
|
|
|
if (TTP->hasDefaultArgument())
|
|
|
|
P.Default = TTP->getDefaultArgument().getAsString(PP);
|
2020-01-16 22:20:13 +08:00
|
|
|
} else if (const auto *NTTP = dyn_cast<NonTypeTemplateParmDecl>(Param)) {
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
if (IdentifierInfo *II = NTTP->getIdentifier())
|
|
|
|
P.Name = II->getName().str();
|
|
|
|
|
2020-01-16 22:20:13 +08:00
|
|
|
P.Type = printType(NTTP->getType(), PP);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
if (NTTP->isParameterPack())
|
2020-01-16 22:20:13 +08:00
|
|
|
*P.Type += "...";
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
|
|
|
|
if (NTTP->hasDefaultArgument()) {
|
|
|
|
P.Default.emplace();
|
|
|
|
llvm::raw_string_ostream Out(*P.Default);
|
|
|
|
NTTP->getDefaultArgument()->printPretty(Out, nullptr, PP);
|
|
|
|
}
|
2020-01-16 22:20:13 +08:00
|
|
|
} else if (const auto *TTPD = dyn_cast<TemplateTemplateParmDecl>(Param)) {
|
|
|
|
P.Type.emplace();
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
llvm::raw_string_ostream OS(*P.Type);
|
|
|
|
OS << "template <";
|
|
|
|
printParams(OS,
|
|
|
|
fetchTemplateParameters(TTPD->getTemplateParameters(), PP));
|
|
|
|
OS << "> class"; // FIXME: TemplateTemplateParameter doesn't store the
|
|
|
|
// info on whether this param was a "typename" or
|
|
|
|
// "class".
|
|
|
|
if (!TTPD->getName().empty())
|
|
|
|
P.Name = TTPD->getNameAsString();
|
|
|
|
if (TTPD->hasDefaultArgument()) {
|
|
|
|
P.Default.emplace();
|
|
|
|
llvm::raw_string_ostream Out(*P.Default);
|
|
|
|
TTPD->getDefaultArgument().getArgument().print(PP, Out);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
TempParameters.push_back(std::move(P));
|
|
|
|
}
|
|
|
|
|
|
|
|
return TempParameters;
|
|
|
|
}
|
|
|
|
|
|
|
|
const FunctionDecl *getUnderlyingFunction(const Decl *D) {
|
|
|
|
// Extract lambda from variables.
|
|
|
|
if (const VarDecl *VD = llvm::dyn_cast<VarDecl>(D)) {
|
|
|
|
auto QT = VD->getType();
|
|
|
|
if (!QT.isNull()) {
|
|
|
|
while (!QT->getPointeeType().isNull())
|
|
|
|
QT = QT->getPointeeType();
|
|
|
|
|
|
|
|
if (const auto *CD = QT->getAsCXXRecordDecl())
|
|
|
|
return CD->getLambdaCallOperator();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Non-lambda functions.
|
|
|
|
return D->getAsFunction();
|
|
|
|
}
|
|
|
|
|
2019-12-17 19:13:28 +08:00
|
|
|
// Returns the decl that should be used for querying comments, either from index
|
|
|
|
// or AST.
|
|
|
|
const NamedDecl *getDeclForComment(const NamedDecl *D) {
|
|
|
|
if (auto *CTSD = llvm::dyn_cast<ClassTemplateSpecializationDecl>(D))
|
|
|
|
if (!CTSD->isExplicitInstantiationOrSpecialization())
|
|
|
|
return CTSD->getTemplateInstantiationPattern();
|
|
|
|
if (auto *VTSD = llvm::dyn_cast<VarTemplateSpecializationDecl>(D))
|
|
|
|
if (!VTSD->isExplicitInstantiationOrSpecialization())
|
|
|
|
return VTSD->getTemplateInstantiationPattern();
|
|
|
|
if (auto *FD = D->getAsFunction())
|
|
|
|
if (FD->isTemplateInstantiation())
|
2019-12-27 16:11:03 +08:00
|
|
|
return FD->getTemplateInstantiationPattern();
|
2019-12-17 19:13:28 +08:00
|
|
|
return D;
|
|
|
|
}
|
|
|
|
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
// Look up information about D from the index, and add it to Hover.
|
2019-12-17 19:13:28 +08:00
|
|
|
void enhanceFromIndex(HoverInfo &Hover, const NamedDecl &ND,
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
const SymbolIndex *Index) {
|
2019-12-17 19:13:28 +08:00
|
|
|
assert(&ND == getDeclForComment(&ND));
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
// We only add documentation, so don't bother if we already have some.
|
2019-12-17 19:13:28 +08:00
|
|
|
if (!Hover.Documentation.empty() || !Index)
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
return;
|
2019-12-17 19:13:28 +08:00
|
|
|
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
// Skip querying for non-indexable symbols, there's no point.
|
|
|
|
// We're searching for symbols that might be indexed outside this main file.
|
|
|
|
if (!SymbolCollector::shouldCollectSymbol(ND, ND.getASTContext(),
|
|
|
|
SymbolCollector::Options(),
|
|
|
|
/*IsMainFileOnly=*/false))
|
|
|
|
return;
|
|
|
|
auto ID = getSymbolID(&ND);
|
|
|
|
if (!ID)
|
|
|
|
return;
|
|
|
|
LookupRequest Req;
|
|
|
|
Req.IDs.insert(*ID);
|
|
|
|
Index->lookup(
|
|
|
|
Req, [&](const Symbol &S) { Hover.Documentation = S.Documentation; });
|
|
|
|
}
|
|
|
|
|
|
|
|
// Populates Type, ReturnType, and Parameters for function-like decls.
|
|
|
|
void fillFunctionTypeAndParams(HoverInfo &HI, const Decl *D,
|
2019-12-13 16:34:59 +08:00
|
|
|
const FunctionDecl *FD,
|
|
|
|
const PrintingPolicy &Policy) {
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
HI.Parameters.emplace();
|
|
|
|
for (const ParmVarDecl *PVD : FD->parameters()) {
|
|
|
|
HI.Parameters->emplace_back();
|
|
|
|
auto &P = HI.Parameters->back();
|
|
|
|
if (!PVD->getType().isNull()) {
|
2020-01-16 22:20:13 +08:00
|
|
|
P.Type = printType(PVD->getType(), Policy);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
} else {
|
|
|
|
std::string Param;
|
|
|
|
llvm::raw_string_ostream OS(Param);
|
|
|
|
PVD->dump(OS);
|
|
|
|
OS.flush();
|
|
|
|
elog("Got param with null type: {0}", Param);
|
|
|
|
}
|
|
|
|
if (!PVD->getName().empty())
|
|
|
|
P.Name = PVD->getNameAsString();
|
|
|
|
if (PVD->hasDefaultArg()) {
|
|
|
|
P.Default.emplace();
|
|
|
|
llvm::raw_string_ostream Out(*P.Default);
|
|
|
|
PVD->getDefaultArg()->printPretty(Out, nullptr, Policy);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-21 23:49:32 +08:00
|
|
|
// We don't want any type info, if name already contains it. This is true for
|
|
|
|
// constructors/destructors and conversion operators.
|
|
|
|
const auto NK = FD->getDeclName().getNameKind();
|
|
|
|
if (NK == DeclarationName::CXXConstructorName ||
|
|
|
|
NK == DeclarationName::CXXDestructorName ||
|
|
|
|
NK == DeclarationName::CXXConversionFunctionName)
|
|
|
|
return;
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
|
2020-01-21 23:49:32 +08:00
|
|
|
HI.ReturnType = printType(FD->getReturnType(), Policy);
|
|
|
|
QualType QT = FD->getType();
|
|
|
|
if (const VarDecl *VD = llvm::dyn_cast<VarDecl>(D)) // Lambdas
|
|
|
|
QT = VD->getType().getDesugaredType(D->getASTContext());
|
|
|
|
HI.Type = printType(QT, Policy);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
// FIXME: handle variadics.
|
|
|
|
}
|
|
|
|
|
2019-12-12 17:41:27 +08:00
|
|
|
llvm::Optional<std::string> printExprValue(const Expr *E,
|
|
|
|
const ASTContext &Ctx) {
|
2019-11-17 05:15:05 +08:00
|
|
|
Expr::EvalResult Constant;
|
|
|
|
// Evaluating [[foo]]() as "&foo" isn't useful, and prevents us walking up
|
|
|
|
// to the enclosing call.
|
|
|
|
QualType T = E->getType();
|
2019-12-12 17:41:27 +08:00
|
|
|
if (T.isNull() || T->isFunctionType() || T->isFunctionPointerType() ||
|
2019-11-17 05:15:05 +08:00
|
|
|
T->isFunctionReferenceType())
|
|
|
|
return llvm::None;
|
|
|
|
// Attempt to evaluate. If expr is dependent, evaluation crashes!
|
|
|
|
if (E->isValueDependent() || !E->EvaluateAsRValue(Constant, Ctx))
|
|
|
|
return llvm::None;
|
|
|
|
|
|
|
|
// Show enums symbolically, not numerically like APValue::printPretty().
|
|
|
|
if (T->isEnumeralType() && Constant.Val.getInt().getMinSignedBits() <= 64) {
|
|
|
|
// Compare to int64_t to avoid bit-width match requirements.
|
|
|
|
int64_t Val = Constant.Val.getInt().getExtValue();
|
|
|
|
for (const EnumConstantDecl *ECD :
|
|
|
|
T->castAs<EnumType>()->getDecl()->enumerators())
|
|
|
|
if (ECD->getInitVal() == Val)
|
|
|
|
return llvm::formatv("{0} ({1})", ECD->getNameAsString(), Val).str();
|
|
|
|
}
|
|
|
|
return Constant.Val.getAsString(Ctx, E->getType());
|
|
|
|
}
|
|
|
|
|
|
|
|
llvm::Optional<std::string> printExprValue(const SelectionTree::Node *N,
|
|
|
|
const ASTContext &Ctx) {
|
|
|
|
for (; N; N = N->Parent) {
|
2020-01-04 23:28:41 +08:00
|
|
|
// Try to evaluate the first evaluatable enclosing expression.
|
2019-11-17 05:15:05 +08:00
|
|
|
if (const Expr *E = N->ASTNode.get<Expr>()) {
|
|
|
|
if (auto Val = printExprValue(E, Ctx))
|
|
|
|
return Val;
|
|
|
|
} else if (N->ASTNode.get<Decl>() || N->ASTNode.get<Stmt>()) {
|
|
|
|
// Refuse to cross certain non-exprs. (TypeLoc are OK as part of Exprs).
|
|
|
|
// This tries to ensure we're showing a value related to the cursor.
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return llvm::None;
|
|
|
|
}
|
|
|
|
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
/// Generate a \p Hover object given the declaration \p D.
|
2019-12-13 16:34:59 +08:00
|
|
|
HoverInfo getHoverContents(const NamedDecl *D, const SymbolIndex *Index) {
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
HoverInfo HI;
|
|
|
|
const ASTContext &Ctx = D->getASTContext();
|
|
|
|
|
|
|
|
HI.NamespaceScope = getNamespaceScope(D);
|
|
|
|
if (!HI.NamespaceScope->empty())
|
|
|
|
HI.NamespaceScope->append("::");
|
|
|
|
HI.LocalScope = getLocalScope(D);
|
|
|
|
if (!HI.LocalScope.empty())
|
|
|
|
HI.LocalScope.append("::");
|
|
|
|
|
|
|
|
PrintingPolicy Policy = printingPolicyForDecls(Ctx.getPrintingPolicy());
|
2019-12-13 16:34:59 +08:00
|
|
|
HI.Name = printName(Ctx, *D);
|
|
|
|
const auto *CommentD = getDeclForComment(D);
|
|
|
|
HI.Documentation = getDeclComment(Ctx, *CommentD);
|
|
|
|
enhanceFromIndex(HI, *CommentD, Index);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
|
[clangd] Store index::SymbolKind in HoverInfo
Summary:
LSP's SymbolKind has some shortcomings when it comes to C++ types,
index::SymbolKind has more detailed info like Destructor, Parameter, MACRO etc.
We are planning to make use of that information in our new Hover response, and
it would be nice to display the Symbol type in full detail, rather than some
approximation.
Reviewers: sammccall
Subscribers: ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70723
2019-11-27 01:06:17 +08:00
|
|
|
HI.Kind = index::getSymbolInfo(D).Kind;
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
|
|
|
|
// Fill in template params.
|
|
|
|
if (const TemplateDecl *TD = D->getDescribedTemplate()) {
|
|
|
|
HI.TemplateParameters =
|
|
|
|
fetchTemplateParameters(TD->getTemplateParameters(), Policy);
|
|
|
|
D = TD;
|
|
|
|
} else if (const FunctionDecl *FD = D->getAsFunction()) {
|
2020-01-16 22:20:13 +08:00
|
|
|
if (const auto *FTD = FD->getDescribedTemplate()) {
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
HI.TemplateParameters =
|
|
|
|
fetchTemplateParameters(FTD->getTemplateParameters(), Policy);
|
|
|
|
D = FTD;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fill in types and params.
|
2020-01-07 22:15:00 +08:00
|
|
|
if (const FunctionDecl *FD = getUnderlyingFunction(D))
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
fillFunctionTypeAndParams(HI, D, FD, Policy);
|
2020-01-07 22:15:00 +08:00
|
|
|
else if (const auto *VD = dyn_cast<ValueDecl>(D))
|
2020-01-16 22:20:13 +08:00
|
|
|
HI.Type = printType(VD->getType(), Policy);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
|
|
|
|
// Fill in value with evaluated initializer if possible.
|
|
|
|
if (const auto *Var = dyn_cast<VarDecl>(D)) {
|
2019-11-17 05:15:05 +08:00
|
|
|
if (const Expr *Init = Var->getInit())
|
|
|
|
HI.Value = printExprValue(Init, Ctx);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
} else if (const auto *ECD = dyn_cast<EnumConstantDecl>(D)) {
|
|
|
|
// Dependent enums (e.g. nested in template classes) don't have values yet.
|
|
|
|
if (!ECD->getType()->isDependentType())
|
|
|
|
HI.Value = ECD->getInitVal().toString(10);
|
|
|
|
}
|
|
|
|
|
|
|
|
HI.Definition = printDefinition(D);
|
|
|
|
return HI;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Generate a \p Hover object given the type \p T.
|
2019-12-17 20:00:12 +08:00
|
|
|
HoverInfo getHoverContents(QualType T, ASTContext &ASTCtx,
|
|
|
|
const SymbolIndex *Index) {
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
HoverInfo HI;
|
|
|
|
|
2019-12-17 20:00:12 +08:00
|
|
|
if (const auto *D = T->getAsTagDecl()) {
|
2019-12-16 21:22:48 +08:00
|
|
|
HI.Name = printName(ASTCtx, *D);
|
[clangd] Store index::SymbolKind in HoverInfo
Summary:
LSP's SymbolKind has some shortcomings when it comes to C++ types,
index::SymbolKind has more detailed info like Destructor, Parameter, MACRO etc.
We are planning to make use of that information in our new Hover response, and
it would be nice to display the Symbol type in full detail, rather than some
approximation.
Reviewers: sammccall
Subscribers: ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70723
2019-11-27 01:06:17 +08:00
|
|
|
HI.Kind = index::getSymbolInfo(D).Kind;
|
2019-12-16 21:22:48 +08:00
|
|
|
|
2019-12-17 19:13:28 +08:00
|
|
|
const auto *CommentD = getDeclForComment(D);
|
|
|
|
HI.Documentation = getDeclComment(ASTCtx, *CommentD);
|
|
|
|
enhanceFromIndex(HI, *CommentD, Index);
|
|
|
|
} else {
|
2019-12-16 21:22:48 +08:00
|
|
|
// Builtin types
|
2020-01-07 22:15:00 +08:00
|
|
|
auto Policy = printingPolicyForDecls(ASTCtx.getPrintingPolicy());
|
|
|
|
Policy.SuppressTagKeyword = true;
|
|
|
|
HI.Name = T.getAsString(Policy);
|
2019-12-16 21:22:48 +08:00
|
|
|
}
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
return HI;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Generate a \p Hover object given the macro \p MacroDecl.
|
|
|
|
HoverInfo getHoverContents(const DefinedMacro &Macro, ParsedAST &AST) {
|
|
|
|
HoverInfo HI;
|
|
|
|
SourceManager &SM = AST.getSourceManager();
|
|
|
|
HI.Name = Macro.Name;
|
[clangd] Store index::SymbolKind in HoverInfo
Summary:
LSP's SymbolKind has some shortcomings when it comes to C++ types,
index::SymbolKind has more detailed info like Destructor, Parameter, MACRO etc.
We are planning to make use of that information in our new Hover response, and
it would be nice to display the Symbol type in full detail, rather than some
approximation.
Reviewers: sammccall
Subscribers: ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70723
2019-11-27 01:06:17 +08:00
|
|
|
HI.Kind = index::SymbolKind::Macro;
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
// FIXME: Populate documentation
|
|
|
|
// FIXME: Pupulate parameters
|
|
|
|
|
|
|
|
// Try to get the full definition, not just the name
|
|
|
|
SourceLocation StartLoc = Macro.Info->getDefinitionLoc();
|
|
|
|
SourceLocation EndLoc = Macro.Info->getDefinitionEndLoc();
|
|
|
|
if (EndLoc.isValid()) {
|
2019-12-05 07:09:35 +08:00
|
|
|
EndLoc = Lexer::getLocForEndOfToken(EndLoc, 0, SM, AST.getLangOpts());
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
bool Invalid;
|
|
|
|
StringRef Buffer = SM.getBufferData(SM.getFileID(StartLoc), &Invalid);
|
|
|
|
if (!Invalid) {
|
|
|
|
unsigned StartOffset = SM.getFileOffset(StartLoc);
|
|
|
|
unsigned EndOffset = SM.getFileOffset(EndLoc);
|
|
|
|
if (EndOffset <= Buffer.size() && StartOffset < EndOffset)
|
|
|
|
HI.Definition =
|
|
|
|
("#define " + Buffer.substr(StartOffset, EndOffset - StartOffset))
|
|
|
|
.str();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return HI;
|
|
|
|
}
|
2020-01-10 20:11:09 +08:00
|
|
|
|
|
|
|
bool isLiteral(const Expr *E) {
|
|
|
|
// Unfortunately there's no common base Literal classes inherits from
|
|
|
|
// (apart from Expr), therefore this is a nasty blacklist.
|
|
|
|
return llvm::isa<CharacterLiteral>(E) || llvm::isa<CompoundLiteralExpr>(E) ||
|
|
|
|
llvm::isa<CXXBoolLiteralExpr>(E) ||
|
|
|
|
llvm::isa<CXXNullPtrLiteralExpr>(E) ||
|
|
|
|
llvm::isa<FixedPointLiteral>(E) || llvm::isa<FloatingLiteral>(E) ||
|
|
|
|
llvm::isa<ImaginaryLiteral>(E) || llvm::isa<IntegerLiteral>(E) ||
|
|
|
|
llvm::isa<StringLiteral>(E) || llvm::isa<UserDefinedLiteral>(E);
|
|
|
|
}
|
|
|
|
|
|
|
|
llvm::StringLiteral getNameForExpr(const Expr *E) {
|
|
|
|
// FIXME: Come up with names for `special` expressions.
|
2020-01-17 05:02:47 +08:00
|
|
|
//
|
|
|
|
// It's an known issue for GCC5, https://godbolt.org/z/Z_tbgi. Work around
|
|
|
|
// that by using explicit conversion constructor.
|
|
|
|
//
|
|
|
|
// TODO: Once GCC5 is fully retired and not the minimal requirement as stated
|
|
|
|
// in `GettingStarted`, please remove the explicit conversion constructor.
|
|
|
|
return llvm::StringLiteral("expression");
|
2020-01-10 20:11:09 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Generates hover info for evaluatable expressions.
|
|
|
|
// FIXME: Support hover for literals (esp user-defined)
|
|
|
|
llvm::Optional<HoverInfo> getHoverContents(const Expr *E, ParsedAST &AST) {
|
|
|
|
// There's not much value in hovering over "42" and getting a hover card
|
|
|
|
// saying "42 is an int", similar for other literals.
|
|
|
|
if (isLiteral(E))
|
|
|
|
return llvm::None;
|
|
|
|
|
|
|
|
HoverInfo HI;
|
|
|
|
// For expressions we currently print the type and the value, iff it is
|
|
|
|
// evaluatable.
|
|
|
|
if (auto Val = printExprValue(E, AST.getASTContext())) {
|
|
|
|
auto Policy =
|
|
|
|
printingPolicyForDecls(AST.getASTContext().getPrintingPolicy());
|
|
|
|
Policy.SuppressTagKeyword = true;
|
2020-01-16 22:20:13 +08:00
|
|
|
HI.Type = printType(E->getType(), Policy);
|
2020-01-10 20:11:09 +08:00
|
|
|
HI.Value = *Val;
|
|
|
|
HI.Name = getNameForExpr(E);
|
|
|
|
return HI;
|
|
|
|
}
|
|
|
|
return llvm::None;
|
|
|
|
}
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
} // namespace
|
|
|
|
|
|
|
|
llvm::Optional<HoverInfo> getHover(ParsedAST &AST, Position Pos,
|
|
|
|
format::FormatStyle Style,
|
|
|
|
const SymbolIndex *Index) {
|
|
|
|
const SourceManager &SM = AST.getSourceManager();
|
|
|
|
llvm::Optional<HoverInfo> HI;
|
|
|
|
SourceLocation SourceLocationBeg = SM.getMacroArgExpandedLocation(
|
2019-12-05 07:09:35 +08:00
|
|
|
getBeginningOfIdentifier(Pos, SM, AST.getLangOpts()));
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
|
|
|
|
if (auto Deduced = getDeducedType(AST.getASTContext(), SourceLocationBeg)) {
|
2019-12-17 20:00:12 +08:00
|
|
|
HI = getHoverContents(*Deduced, AST.getASTContext(), Index);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
} else if (auto M = locateMacroAt(SourceLocationBeg, AST.getPreprocessor())) {
|
|
|
|
HI = getHoverContents(*M, AST);
|
|
|
|
} else {
|
|
|
|
auto Offset = positionToOffset(SM.getBufferData(SM.getMainFileID()), Pos);
|
|
|
|
if (!Offset) {
|
|
|
|
llvm::consumeError(Offset.takeError());
|
|
|
|
return llvm::None;
|
|
|
|
}
|
2019-12-17 02:07:49 +08:00
|
|
|
SelectionTree Selection(AST.getASTContext(), AST.getTokens(), *Offset);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
std::vector<const Decl *> Result;
|
2019-12-17 02:07:49 +08:00
|
|
|
if (const SelectionTree::Node *N = Selection.commonAncestor()) {
|
2019-12-17 19:13:28 +08:00
|
|
|
auto Decls = explicitReferenceTargets(N->ASTNode, DeclRelation::Alias);
|
2019-11-17 05:15:05 +08:00
|
|
|
if (!Decls.empty()) {
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
HI = getHoverContents(Decls.front(), Index);
|
2019-11-17 05:15:05 +08:00
|
|
|
// Look for a close enclosing expression to show the value of.
|
|
|
|
if (!HI->Value)
|
|
|
|
HI->Value = printExprValue(N, AST.getASTContext());
|
2020-01-10 20:11:09 +08:00
|
|
|
} else if (const Expr *E = N->ASTNode.get<Expr>()) {
|
|
|
|
HI = getHoverContents(E, AST);
|
2019-11-17 05:15:05 +08:00
|
|
|
}
|
|
|
|
// FIXME: support hovers for other nodes?
|
|
|
|
// - built-in types
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!HI)
|
|
|
|
return llvm::None;
|
|
|
|
|
|
|
|
auto Replacements = format::reformat(
|
|
|
|
Style, HI->Definition, tooling::Range(0, HI->Definition.size()));
|
|
|
|
if (auto Formatted =
|
|
|
|
tooling::applyAllReplacements(HI->Definition, Replacements))
|
|
|
|
HI->Definition = *Formatted;
|
|
|
|
|
2019-12-13 16:34:59 +08:00
|
|
|
HI->SymRange = getTokenRange(AST.getSourceManager(), AST.getLangOpts(),
|
|
|
|
SourceLocationBeg);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
return HI;
|
|
|
|
}
|
|
|
|
|
2019-12-10 17:28:37 +08:00
|
|
|
markup::Document HoverInfo::present() const {
|
|
|
|
markup::Document Output;
|
2019-12-13 16:34:59 +08:00
|
|
|
// Header contains a text of the form:
|
2020-01-14 00:21:31 +08:00
|
|
|
// variable `var`
|
2019-12-13 16:34:59 +08:00
|
|
|
//
|
|
|
|
// class `X`
|
|
|
|
//
|
2020-01-14 00:21:31 +08:00
|
|
|
// function `foo`
|
|
|
|
//
|
|
|
|
// expression
|
2020-01-10 20:11:09 +08:00
|
|
|
//
|
2020-01-14 00:50:23 +08:00
|
|
|
// Note that we are making use of a level-3 heading because VSCode renders
|
|
|
|
// level 1 and 2 headers in a huge font, see
|
|
|
|
// https://github.com/microsoft/vscode/issues/88417 for details.
|
|
|
|
markup::Paragraph &Header = Output.addHeading(3);
|
2020-01-16 01:09:51 +08:00
|
|
|
if (Kind != index::SymbolKind::Unknown)
|
|
|
|
Header.appendText(index::getSymbolKindString(Kind));
|
2019-12-13 16:34:59 +08:00
|
|
|
assert(!Name.empty() && "hover triggered on a nameless symbol");
|
|
|
|
Header.appendCode(Name);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
|
2020-01-14 00:14:24 +08:00
|
|
|
// Put a linebreak after header to increase readability.
|
|
|
|
Output.addRuler();
|
2020-01-14 00:21:31 +08:00
|
|
|
// Print Types on their own lines to reduce chances of getting line-wrapped by
|
|
|
|
// editor, as they might be long.
|
|
|
|
if (ReturnType) {
|
|
|
|
// For functions we display signature in a list form, e.g.:
|
|
|
|
// 🡺 `x`
|
|
|
|
// Parameters:
|
|
|
|
// - `bool param1`
|
|
|
|
// - `int param2 = 5`
|
|
|
|
Output.addParagraph().appendText("🡺").appendCode(*ReturnType);
|
|
|
|
if (Parameters && !Parameters->empty()) {
|
|
|
|
Output.addParagraph().appendText("Parameters:");
|
|
|
|
markup::BulletList &L = Output.addBulletList();
|
|
|
|
for (const auto &Param : *Parameters) {
|
|
|
|
std::string Buffer;
|
|
|
|
llvm::raw_string_ostream OS(Buffer);
|
|
|
|
OS << Param;
|
|
|
|
L.addItem().addParagraph().appendCode(std::move(OS.str()));
|
|
|
|
}
|
2019-12-13 16:34:59 +08:00
|
|
|
}
|
2020-01-14 00:21:31 +08:00
|
|
|
} else if (Type) {
|
|
|
|
Output.addParagraph().appendText("Type: ").appendCode(*Type);
|
2019-12-13 16:34:59 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (Value) {
|
|
|
|
markup::Paragraph &P = Output.addParagraph();
|
|
|
|
P.appendText("Value =");
|
|
|
|
P.appendCode(*Value);
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!Documentation.empty())
|
2019-12-10 17:28:37 +08:00
|
|
|
Output.addParagraph().appendText(Documentation);
|
2019-12-13 16:34:59 +08:00
|
|
|
|
|
|
|
if (!Definition.empty()) {
|
2020-01-14 00:14:24 +08:00
|
|
|
Output.addRuler();
|
2019-12-13 16:34:59 +08:00
|
|
|
std::string ScopeComment;
|
|
|
|
// Drop trailing "::".
|
|
|
|
if (!LocalScope.empty()) {
|
|
|
|
// Container name, e.g. class, method, function.
|
|
|
|
// We might want to propogate some info about container type to print
|
|
|
|
// function foo, class X, method X::bar, etc.
|
|
|
|
ScopeComment =
|
|
|
|
"// In " + llvm::StringRef(LocalScope).rtrim(':').str() + '\n';
|
|
|
|
} else if (NamespaceScope && !NamespaceScope->empty()) {
|
|
|
|
ScopeComment = "// In namespace " +
|
|
|
|
llvm::StringRef(*NamespaceScope).rtrim(':').str() + '\n';
|
|
|
|
}
|
|
|
|
// Note that we don't print anything for global namespace, to not annoy
|
|
|
|
// non-c++ projects or projects that are not making use of namespaces.
|
|
|
|
Output.addCodeBlock(ScopeComment + Definition);
|
|
|
|
}
|
[clangd] Untangle Hover from XRefs, move into own file.
Summary:
This is mostly mechanical, with a few exceptions:
- getDeducedType moved into AST.h where it belongs. It now takes
ASTContext instead of ParsedAST, and avoids using the preprocessor.
- hover now uses SelectionTree directly rather than via
getDeclAtPosition helper
- hover on 'auto' used to find the decl that contained the 'auto' and
use that to set Kind and documentation for the hover result.
Now we use targetDecl() to find the decl matching the deduced type instead.
This changes tests, e.g. 'variable' -> class for auto on lambdas.
I think this is better, but the motivation was to avoid depending on
the internals of DeducedTypeVisitor. This functionality is removed
from the visitor.
Reviewers: kadircet
Subscribers: mgorny, ilya-biryukov, MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D70357
2019-11-17 00:00:19 +08:00
|
|
|
return Output;
|
|
|
|
}
|
|
|
|
|
|
|
|
llvm::raw_ostream &operator<<(llvm::raw_ostream &OS,
|
|
|
|
const HoverInfo::Param &P) {
|
|
|
|
std::vector<llvm::StringRef> Output;
|
|
|
|
if (P.Type)
|
|
|
|
Output.push_back(*P.Type);
|
|
|
|
if (P.Name)
|
|
|
|
Output.push_back(*P.Name);
|
|
|
|
OS << llvm::join(Output, " ");
|
|
|
|
if (P.Default)
|
|
|
|
OS << " = " << *P.Default;
|
|
|
|
return OS;
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace clangd
|
|
|
|
} // namespace clang
|