[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
|
|
|
//===-- HoverTests.cpp ----------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// 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
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2019-12-17 19:13:28 +08:00
|
|
|
#include "AST.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 "Annotations.h"
|
|
|
|
#include "Hover.h"
|
|
|
|
#include "TestIndex.h"
|
|
|
|
#include "TestTU.h"
|
|
|
|
#include "index/MemIndex.h"
|
2019-12-03 02:34:03 +08:00
|
|
|
#include "clang/Index/IndexSymbol.h"
|
|
|
|
#include "llvm/ADT/None.h"
|
|
|
|
#include "llvm/ADT/StringRef.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 "gmock/gmock.h"
|
|
|
|
#include "gtest/gtest.h"
|
2019-12-03 02:34:03 +08:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
[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 {
|
|
|
|
|
|
|
|
TEST(Hover, Structured) {
|
|
|
|
struct {
|
|
|
|
const char *const Code;
|
|
|
|
const std::function<void(HoverInfo &)> ExpectedBuilder;
|
|
|
|
} Cases[] = {
|
|
|
|
// Global scope.
|
|
|
|
{R"cpp(
|
|
|
|
// Best foo ever.
|
|
|
|
void [[fo^o]]() {}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "foo";
|
[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::Function;
|
[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.Documentation = "Best foo ever.";
|
|
|
|
HI.Definition = "void foo()";
|
|
|
|
HI.ReturnType = "void";
|
|
|
|
HI.Type = "void ()";
|
|
|
|
HI.Parameters.emplace();
|
|
|
|
}},
|
|
|
|
// Inside namespace
|
|
|
|
{R"cpp(
|
|
|
|
namespace ns1 { namespace ns2 {
|
|
|
|
/// Best foo ever.
|
|
|
|
void [[fo^o]]() {}
|
|
|
|
}}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "ns1::ns2::";
|
|
|
|
HI.Name = "foo";
|
[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::Function;
|
[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.Documentation = "Best foo ever.";
|
|
|
|
HI.Definition = "void foo()";
|
|
|
|
HI.ReturnType = "void";
|
|
|
|
HI.Type = "void ()";
|
|
|
|
HI.Parameters.emplace();
|
|
|
|
}},
|
|
|
|
// Field
|
|
|
|
{R"cpp(
|
|
|
|
namespace ns1 { namespace ns2 {
|
|
|
|
struct Foo {
|
|
|
|
int [[b^ar]];
|
|
|
|
};
|
|
|
|
}}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "ns1::ns2::";
|
|
|
|
HI.LocalScope = "Foo::";
|
|
|
|
HI.Name = "bar";
|
[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::Field;
|
[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.Definition = "int bar";
|
|
|
|
HI.Type = "int";
|
|
|
|
}},
|
|
|
|
// Local to class method.
|
|
|
|
{R"cpp(
|
|
|
|
namespace ns1 { namespace ns2 {
|
|
|
|
struct Foo {
|
|
|
|
void foo() {
|
|
|
|
int [[b^ar]];
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "ns1::ns2::";
|
|
|
|
HI.LocalScope = "Foo::foo::";
|
|
|
|
HI.Name = "bar";
|
[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::Variable;
|
[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.Definition = "int bar";
|
|
|
|
HI.Type = "int";
|
|
|
|
}},
|
|
|
|
// Anon namespace and local scope.
|
|
|
|
{R"cpp(
|
|
|
|
namespace ns1 { namespace {
|
|
|
|
struct {
|
|
|
|
int [[b^ar]];
|
|
|
|
} T;
|
|
|
|
}}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
2019-12-16 21:22:48 +08:00
|
|
|
HI.NamespaceScope = "ns1::";
|
[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.LocalScope = "(anonymous struct)::";
|
|
|
|
HI.Name = "bar";
|
[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::Field;
|
[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.Definition = "int bar";
|
|
|
|
HI.Type = "int";
|
|
|
|
}},
|
|
|
|
// Variable with template type
|
|
|
|
{R"cpp(
|
|
|
|
template <typename T, class... Ts> class Foo { public: Foo(int); };
|
|
|
|
Foo<int, char, bool> [[fo^o]] = Foo<int, char, bool>(5);
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "foo";
|
[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::Variable;
|
[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.Definition = "Foo<int, char, bool> foo = Foo<int, char, bool>(5)";
|
|
|
|
HI.Type = "Foo<int, char, bool>";
|
|
|
|
}},
|
|
|
|
// Implicit template instantiation
|
|
|
|
{R"cpp(
|
|
|
|
template <typename T> class vector{};
|
|
|
|
[[vec^tor]]<int> foo;
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
2019-12-17 19:13:28 +08:00
|
|
|
HI.Name = "vector<int>";
|
[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::Class;
|
2019-12-17 19:13:28 +08:00
|
|
|
HI.Definition = "template <> class vector<int> {}";
|
[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
|
|
|
}},
|
|
|
|
// Class template
|
|
|
|
{R"cpp(
|
|
|
|
template <template<typename, bool...> class C,
|
|
|
|
typename = char,
|
|
|
|
int = 0,
|
|
|
|
bool Q = false,
|
|
|
|
class... Ts> class Foo {};
|
|
|
|
template <template<typename, bool...> class T>
|
|
|
|
[[F^oo]]<T> foo;
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "Foo";
|
[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::Class;
|
[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.Definition =
|
|
|
|
R"cpp(template <template <typename, bool...> class C, typename = char, int = 0,
|
|
|
|
bool Q = false, class... Ts>
|
|
|
|
class Foo {})cpp";
|
|
|
|
HI.TemplateParameters = {
|
|
|
|
{std::string("template <typename, bool...> class"),
|
|
|
|
std::string("C"), llvm::None},
|
|
|
|
{std::string("typename"), llvm::None, std::string("char")},
|
|
|
|
{std::string("int"), llvm::None, std::string("0")},
|
|
|
|
{std::string("bool"), std::string("Q"), std::string("false")},
|
|
|
|
{std::string("class..."), std::string("Ts"), llvm::None},
|
|
|
|
};
|
|
|
|
}},
|
|
|
|
// Function template
|
|
|
|
{R"cpp(
|
|
|
|
template <template<typename, bool...> class C,
|
|
|
|
typename = char,
|
|
|
|
int = 0,
|
|
|
|
bool Q = false,
|
|
|
|
class... Ts> void foo();
|
|
|
|
template<typename, bool...> class Foo;
|
|
|
|
|
|
|
|
void bar() {
|
|
|
|
[[fo^o]]<Foo>();
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "foo";
|
[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::Function;
|
2019-12-17 19:13:28 +08:00
|
|
|
HI.Definition = "template <> void foo<Foo, char, 0, false, <>>()";
|
[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.ReturnType = "void";
|
|
|
|
HI.Type = "void ()";
|
|
|
|
HI.Parameters.emplace();
|
|
|
|
}},
|
|
|
|
// Function decl
|
|
|
|
{R"cpp(
|
|
|
|
template<typename, bool...> class Foo {};
|
|
|
|
Foo<bool, true, false> foo(int, bool T = false);
|
|
|
|
|
|
|
|
void bar() {
|
|
|
|
[[fo^o]](3);
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "foo";
|
[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::Function;
|
[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.Definition = "Foo<bool, true, false> foo(int, bool T = false)";
|
|
|
|
HI.ReturnType = "Foo<bool, true, false>";
|
|
|
|
HI.Type = "Foo<bool, true, false> (int, bool)";
|
|
|
|
HI.Parameters = {
|
|
|
|
{std::string("int"), llvm::None, llvm::None},
|
|
|
|
{std::string("bool"), std::string("T"), std::string("false")},
|
|
|
|
};
|
|
|
|
}},
|
|
|
|
// Pointers to lambdas
|
|
|
|
{R"cpp(
|
|
|
|
void foo() {
|
|
|
|
auto lamb = [](int T, bool B) -> bool { return T && B; };
|
|
|
|
auto *b = &lamb;
|
|
|
|
auto *[[^c]] = &b;
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "foo::";
|
|
|
|
HI.Name = "c";
|
[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::Variable;
|
[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.Definition = "auto *c = &b";
|
|
|
|
HI.Type = "class (lambda) **";
|
|
|
|
HI.ReturnType = "bool";
|
|
|
|
HI.Parameters = {
|
|
|
|
{std::string("int"), std::string("T"), llvm::None},
|
|
|
|
{std::string("bool"), std::string("B"), llvm::None},
|
|
|
|
};
|
|
|
|
return HI;
|
|
|
|
}},
|
|
|
|
// Lambda parameter with decltype reference
|
|
|
|
{R"cpp(
|
|
|
|
auto lamb = [](int T, bool B) -> bool { return T && B; };
|
|
|
|
void foo(decltype(lamb)& bar) {
|
|
|
|
[[ba^r]](0, false);
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "foo::";
|
|
|
|
HI.Name = "bar";
|
[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::Parameter;
|
[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.Definition = "decltype(lamb) &bar";
|
|
|
|
HI.Type = "decltype(lamb) &";
|
|
|
|
HI.ReturnType = "bool";
|
|
|
|
HI.Parameters = {
|
|
|
|
{std::string("int"), std::string("T"), llvm::None},
|
|
|
|
{std::string("bool"), std::string("B"), llvm::None},
|
|
|
|
};
|
|
|
|
return HI;
|
|
|
|
}},
|
|
|
|
// Lambda parameter with decltype
|
|
|
|
{R"cpp(
|
|
|
|
auto lamb = [](int T, bool B) -> bool { return T && B; };
|
|
|
|
void foo(decltype(lamb) bar) {
|
|
|
|
[[ba^r]](0, false);
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "foo::";
|
|
|
|
HI.Name = "bar";
|
[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::Parameter;
|
[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.Definition = "decltype(lamb) bar";
|
|
|
|
HI.Type = "class (lambda)";
|
|
|
|
HI.ReturnType = "bool";
|
|
|
|
HI.Parameters = {
|
|
|
|
{std::string("int"), std::string("T"), llvm::None},
|
|
|
|
{std::string("bool"), std::string("B"), llvm::None},
|
|
|
|
};
|
2019-11-17 05:15:05 +08:00
|
|
|
HI.Value = "false";
|
[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;
|
|
|
|
}},
|
|
|
|
// Lambda variable
|
|
|
|
{R"cpp(
|
|
|
|
void foo() {
|
|
|
|
int bar = 5;
|
|
|
|
auto lamb = [&bar](int T, bool B) -> bool { return T && B && bar; };
|
|
|
|
bool res = [[lam^b]](bar, false);
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "foo::";
|
|
|
|
HI.Name = "lamb";
|
[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::Variable;
|
[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.Definition = "auto lamb = [&bar](int T, bool B) -> bool {}";
|
|
|
|
HI.Type = "class (lambda)";
|
|
|
|
HI.ReturnType = "bool";
|
|
|
|
HI.Parameters = {
|
|
|
|
{std::string("int"), std::string("T"), llvm::None},
|
|
|
|
{std::string("bool"), std::string("B"), llvm::None},
|
|
|
|
};
|
|
|
|
return HI;
|
|
|
|
}},
|
|
|
|
// Local variable in lambda
|
|
|
|
{R"cpp(
|
|
|
|
void foo() {
|
|
|
|
auto lamb = []{int [[te^st]];};
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "foo::(anonymous class)::operator()::";
|
|
|
|
HI.Name = "test";
|
[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::Variable;
|
[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.Definition = "int test";
|
|
|
|
HI.Type = "int";
|
|
|
|
}},
|
|
|
|
// Partially-specialized class template. (formerly type-parameter-0-0)
|
|
|
|
{R"cpp(
|
|
|
|
template <typename T> class X;
|
|
|
|
template <typename T> class [[^X]]<T*> {};
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "X<T *>";
|
|
|
|
HI.NamespaceScope = "";
|
[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::Class;
|
[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.Definition = "template <typename T> class X<T *> {}";
|
|
|
|
}},
|
|
|
|
// Constructor of partially-specialized class template
|
|
|
|
{R"cpp(
|
|
|
|
template<typename, typename=void> struct X;
|
|
|
|
template<typename T> struct X<T*>{ [[^X]](); };
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "X";
|
|
|
|
HI.LocalScope = "X<T *>::"; // FIXME: X<T *, void>::
|
[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::Constructor;
|
[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.Definition = "X()";
|
|
|
|
HI.Parameters.emplace();
|
|
|
|
}},
|
|
|
|
{"class X { [[^~]]X(); };", // FIXME: Should be [[~X]]()
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "~X";
|
|
|
|
HI.LocalScope = "X::";
|
[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::Destructor;
|
[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.Definition = "~X()";
|
|
|
|
HI.Parameters.emplace();
|
|
|
|
}},
|
2020-02-25 16:33:52 +08:00
|
|
|
{"class X { [[op^erator]] int(); };",
|
2020-01-21 23:49:32 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "operator int";
|
|
|
|
HI.LocalScope = "X::";
|
|
|
|
HI.Kind = index::SymbolKind::ConversionFunction;
|
|
|
|
HI.Definition = "operator int()";
|
|
|
|
HI.Parameters.emplace();
|
|
|
|
}},
|
2020-02-25 16:33:52 +08:00
|
|
|
{"class X { operator [[^X]](); };",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "X";
|
|
|
|
HI.Kind = index::SymbolKind::Class;
|
|
|
|
HI.Definition = "class X {}";
|
|
|
|
}},
|
[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
|
|
|
|
|
|
|
// auto on lambda
|
|
|
|
{R"cpp(
|
|
|
|
void foo() {
|
|
|
|
[[au^to]] lamb = []{};
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
2019-12-16 21:22:48 +08:00
|
|
|
HI.Name = "(lambda)";
|
[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::Class;
|
[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
|
|
|
}},
|
|
|
|
// auto on template instantiation
|
|
|
|
{R"cpp(
|
|
|
|
template<typename T> class Foo{};
|
|
|
|
void foo() {
|
|
|
|
[[au^to]] x = Foo<int>();
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
2019-12-16 21:22:48 +08:00
|
|
|
HI.Name = "Foo<int>";
|
[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::Class;
|
[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
|
|
|
}},
|
|
|
|
// auto on specialized template
|
|
|
|
{R"cpp(
|
|
|
|
template<typename T> class Foo{};
|
|
|
|
template<> class Foo<int>{};
|
|
|
|
void foo() {
|
|
|
|
[[au^to]] x = Foo<int>();
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
2019-12-16 21:22:48 +08:00
|
|
|
HI.Name = "Foo<int>";
|
[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::Class;
|
[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
|
|
|
}},
|
|
|
|
|
|
|
|
// macro
|
|
|
|
{R"cpp(
|
|
|
|
// Best MACRO ever.
|
|
|
|
#define MACRO(x,y,z) void foo(x, y, z);
|
|
|
|
[[MAC^RO]](int, double d, bool z = false);
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
[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.Name = "MACRO", 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
|
|
|
HI.Definition = "#define MACRO(x, y, z) void foo(x, y, z);";
|
|
|
|
}},
|
|
|
|
|
|
|
|
// constexprs
|
|
|
|
{R"cpp(
|
|
|
|
constexpr int add(int a, int b) { return a + b; }
|
|
|
|
int [[b^ar]] = add(1, 2);
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "bar";
|
|
|
|
HI.Definition = "int bar = add(1, 2)";
|
[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::Variable;
|
[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.Type = "int";
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Value = "3";
|
|
|
|
}},
|
|
|
|
{R"cpp(
|
|
|
|
int [[b^ar]] = sizeof(char);
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "bar";
|
|
|
|
HI.Definition = "int bar = sizeof(char)";
|
[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::Variable;
|
[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.Type = "int";
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Value = "1";
|
|
|
|
}},
|
|
|
|
{R"cpp(
|
|
|
|
template<int a, int b> struct Add {
|
|
|
|
static constexpr int result = a + b;
|
|
|
|
};
|
|
|
|
int [[ba^r]] = Add<1, 2>::result;
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "bar";
|
|
|
|
HI.Definition = "int bar = Add<1, 2>::result";
|
[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::Variable;
|
[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.Type = "int";
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Value = "3";
|
|
|
|
}},
|
|
|
|
{R"cpp(
|
|
|
|
enum Color { RED, GREEN, };
|
|
|
|
Color x = [[GR^EEN]];
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "GREEN";
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "Color::";
|
|
|
|
HI.Definition = "GREEN";
|
[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::EnumConstant;
|
[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.Type = "enum Color";
|
2019-11-17 05:15:05 +08:00
|
|
|
HI.Value = "1"; // Numeric when hovering on the enumerator name.
|
|
|
|
}},
|
|
|
|
{R"cpp(
|
|
|
|
enum Color { RED, GREEN, };
|
|
|
|
Color x = GREEN;
|
|
|
|
Color y = [[^x]];
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "x";
|
|
|
|
HI.NamespaceScope = "";
|
2020-01-07 22:15:00 +08:00
|
|
|
HI.Definition = "Color x = GREEN";
|
[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::Variable;
|
2019-11-17 05:15:05 +08:00
|
|
|
HI.Type = "enum Color";
|
|
|
|
HI.Value = "GREEN (1)"; // Symbolic when hovering on an expression.
|
[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
|
|
|
}},
|
|
|
|
{R"cpp(
|
|
|
|
template<int a, int b> struct Add {
|
|
|
|
static constexpr int result = a + b;
|
|
|
|
};
|
|
|
|
int bar = Add<1, 2>::[[resu^lt]];
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "result";
|
2019-12-17 19:13:28 +08:00
|
|
|
HI.Definition = "static constexpr int result = 1 + 2";
|
[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::StaticProperty;
|
[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.Type = "const int";
|
|
|
|
HI.NamespaceScope = "";
|
2019-12-17 19:13:28 +08:00
|
|
|
HI.LocalScope = "Add<1, 2>::";
|
2019-11-17 05:15:05 +08:00
|
|
|
HI.Value = "3";
|
|
|
|
}},
|
|
|
|
{R"cpp(
|
|
|
|
constexpr int answer() { return 40 + 2; }
|
|
|
|
int x = [[ans^wer]]();
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "answer";
|
|
|
|
HI.Definition = "constexpr int answer()";
|
[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::Function;
|
2019-11-17 05:15:05 +08:00
|
|
|
HI.Type = "int ()";
|
|
|
|
HI.ReturnType = "int";
|
|
|
|
HI.Parameters.emplace();
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Value = "42";
|
[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
|
|
|
}},
|
|
|
|
{R"cpp(
|
|
|
|
const char *[[ba^r]] = "1234";
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "bar";
|
|
|
|
HI.Definition = "const char *bar = \"1234\"";
|
[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::Variable;
|
[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.Type = "const char *";
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Value = "&\"1234\"[0]";
|
|
|
|
}},
|
2019-12-12 17:41:27 +08:00
|
|
|
{R"cpp(// Should not crash
|
|
|
|
template <typename T>
|
|
|
|
struct Tmpl {
|
|
|
|
Tmpl(int name);
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename A>
|
|
|
|
void boom(int name) {
|
|
|
|
new Tmpl<A>([[na^me]]);
|
|
|
|
})cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "name";
|
|
|
|
HI.Definition = "int name";
|
|
|
|
HI.Kind = index::SymbolKind::Parameter;
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "boom::";
|
|
|
|
}},
|
2019-12-16 21:22:48 +08:00
|
|
|
{
|
|
|
|
R"cpp(// Should not print inline or anon namespaces.
|
|
|
|
namespace ns {
|
|
|
|
inline namespace in_ns {
|
|
|
|
namespace a {
|
|
|
|
namespace {
|
|
|
|
namespace b {
|
|
|
|
inline namespace in_ns2 {
|
|
|
|
class Foo {};
|
|
|
|
} // in_ns2
|
|
|
|
} // b
|
|
|
|
} // anon
|
|
|
|
} // a
|
|
|
|
} // in_ns
|
|
|
|
} // ns
|
|
|
|
void foo() {
|
|
|
|
ns::a::b::[[F^oo]] x;
|
|
|
|
(void)x;
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Foo";
|
|
|
|
HI.Kind = index::SymbolKind::Class;
|
|
|
|
HI.NamespaceScope = "ns::a::b::";
|
|
|
|
HI.Definition = "class Foo {}";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(
|
|
|
|
template <typename T> class Foo {};
|
|
|
|
class X;
|
|
|
|
void foo() {
|
|
|
|
[[^auto]] x = Foo<X>();
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Foo<X>";
|
|
|
|
HI.Kind = index::SymbolKind::Class;
|
|
|
|
}},
|
2020-01-24 20:04:00 +08:00
|
|
|
{// Falls back to primary template, when the type is not instantiated.
|
|
|
|
R"cpp(
|
|
|
|
// comment from primary
|
|
|
|
template <typename T> class Foo {};
|
|
|
|
// comment from specialization
|
|
|
|
template <typename T> class Foo<T*> {};
|
|
|
|
void foo() {
|
|
|
|
[[Fo^o]]<int*> *x = nullptr;
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Foo<int *>";
|
|
|
|
HI.Kind = index::SymbolKind::Class;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Definition = "template <> class Foo<int *>";
|
|
|
|
// FIXME: Maybe force instantiation to make use of real template
|
|
|
|
// pattern.
|
|
|
|
HI.Documentation = "comment from primary";
|
|
|
|
}},
|
2020-01-30 21:07:42 +08:00
|
|
|
{// Template Type Parameter
|
|
|
|
R"cpp(
|
|
|
|
template <typename [[^T]] = int> void foo();
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "T";
|
|
|
|
HI.Kind = index::SymbolKind::TemplateTypeParm;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Definition = "typename T = int";
|
|
|
|
HI.LocalScope = "foo::";
|
|
|
|
HI.Type = "typename";
|
|
|
|
}},
|
|
|
|
{// TemplateTemplate Type Parameter
|
|
|
|
R"cpp(
|
|
|
|
template <template<typename> class [[^T]]> void foo();
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "T";
|
|
|
|
HI.Kind = index::SymbolKind::TemplateTemplateParm;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Definition = "template <typename> class T";
|
|
|
|
HI.LocalScope = "foo::";
|
|
|
|
HI.Type = "template <typename> class";
|
|
|
|
}},
|
|
|
|
{// NonType Template Parameter
|
|
|
|
R"cpp(
|
|
|
|
template <int [[^T]] = 5> void foo();
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "T";
|
|
|
|
HI.Kind = index::SymbolKind::NonTypeTemplateParm;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Definition = "int T = 5";
|
|
|
|
HI.LocalScope = "foo::";
|
|
|
|
HI.Type = "int";
|
|
|
|
}},
|
[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 (const auto &Case : Cases) {
|
|
|
|
SCOPED_TRACE(Case.Code);
|
|
|
|
|
|
|
|
Annotations T(Case.Code);
|
|
|
|
TestTU TU = TestTU::withCode(T.code());
|
|
|
|
TU.ExtraArgs.push_back("-std=c++17");
|
2020-01-29 18:17:45 +08:00
|
|
|
// Types might be different depending on the target triplet, we chose a
|
|
|
|
// fixed one to make sure tests passes on different platform.
|
|
|
|
TU.ExtraArgs.push_back("--target=x86_64-pc-linux-gnu");
|
[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
|
|
|
auto AST = TU.build();
|
|
|
|
|
|
|
|
auto H = getHover(AST, T.point(), format::getLLVMStyle(), nullptr);
|
|
|
|
ASSERT_TRUE(H);
|
|
|
|
HoverInfo Expected;
|
|
|
|
Expected.SymRange = T.range();
|
|
|
|
Case.ExpectedBuilder(Expected);
|
|
|
|
|
|
|
|
EXPECT_EQ(H->NamespaceScope, Expected.NamespaceScope);
|
|
|
|
EXPECT_EQ(H->LocalScope, Expected.LocalScope);
|
|
|
|
EXPECT_EQ(H->Name, Expected.Name);
|
|
|
|
EXPECT_EQ(H->Kind, Expected.Kind);
|
|
|
|
EXPECT_EQ(H->Documentation, Expected.Documentation);
|
|
|
|
EXPECT_EQ(H->Definition, Expected.Definition);
|
|
|
|
EXPECT_EQ(H->Type, Expected.Type);
|
|
|
|
EXPECT_EQ(H->ReturnType, Expected.ReturnType);
|
|
|
|
EXPECT_EQ(H->Parameters, Expected.Parameters);
|
|
|
|
EXPECT_EQ(H->TemplateParameters, Expected.TemplateParameters);
|
|
|
|
EXPECT_EQ(H->SymRange, Expected.SymRange);
|
|
|
|
EXPECT_EQ(H->Value, Expected.Value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-03 02:34:03 +08:00
|
|
|
TEST(Hover, NoHover) {
|
|
|
|
llvm::StringRef Tests[] = {
|
|
|
|
"^int main() {}",
|
|
|
|
"void foo() {^}",
|
|
|
|
R"cpp(// structured binding. Not supported yet
|
|
|
|
struct Bar {};
|
|
|
|
void foo() {
|
|
|
|
Bar a[2];
|
|
|
|
^auto [x,y] = a;
|
|
|
|
}
|
|
|
|
)cpp",
|
|
|
|
R"cpp(// Template auto parameter. Nothing (Not useful).
|
2020-02-24 03:03:00 +08:00
|
|
|
template<a^uto T>
|
2019-12-03 02:34:03 +08:00
|
|
|
void func() {
|
|
|
|
}
|
|
|
|
void foo() {
|
|
|
|
func<1>();
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
[clangd] targetDecl() returns only NamedDecls.
Summary:
While it's perfectly reasonable for non-named decls such as
static_assert to resolve to themselves:
- nothing else ever resolves to them
- features based on references (hover, highlight, find refs etc) tend
to be uninteresting where only trivial references are possible
- returning NamedDecl is a more convenient API (we cast to it in many places)
- this aligns closer to findExplicitReferences/explicitReferenceTargets
This fixes a crash in explicitReferenceTargets: if the target is a
non-named decl then there's an invalid unchecked cast to NamedDecl.
In practice this means when hovering over e.g. a static_assert:
- before ac3f9e4842, we would show a (boring) hover card
- after ac3f9e4842, we would crash
- after this patch, we will show nothing
Reviewers: kadircet, ilya-biryukov
Subscribers: MaskRay, jkorous, arphaman, usaxena95, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D72163
2020-01-04 00:26:33 +08:00
|
|
|
R"cpp(// non-named decls don't get hover. Don't crash!
|
|
|
|
^static_assert(1, "");
|
|
|
|
)cpp",
|
2020-01-10 20:11:09 +08:00
|
|
|
R"cpp(// non-evaluatable expr
|
|
|
|
template <typename T> void foo() {
|
|
|
|
(void)[[size^of]](T);
|
|
|
|
})cpp",
|
|
|
|
// literals
|
|
|
|
"auto x = t^rue;",
|
|
|
|
"auto x = '^A';",
|
|
|
|
"auto x = ^(int){42};",
|
|
|
|
"auto x = ^42.;",
|
|
|
|
"auto x = ^42.0i;",
|
|
|
|
"auto x = ^42;",
|
|
|
|
"auto x = ^nullptr;",
|
|
|
|
"auto x = ^\"asdf\";",
|
2019-12-03 02:34:03 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
for (const auto &Test : Tests) {
|
|
|
|
SCOPED_TRACE(Test);
|
|
|
|
|
|
|
|
Annotations T(Test);
|
|
|
|
TestTU TU = TestTU::withCode(T.code());
|
|
|
|
TU.ExtraArgs.push_back("-std=c++17");
|
|
|
|
auto AST = TU.build();
|
|
|
|
auto H = getHover(AST, T.point(), format::getLLVMStyle(), nullptr);
|
|
|
|
ASSERT_FALSE(H);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Hover, All) {
|
|
|
|
struct {
|
|
|
|
const char *const Code;
|
|
|
|
const std::function<void(HoverInfo &)> ExpectedBuilder;
|
|
|
|
} Cases[] = {
|
2019-12-27 16:26:39 +08:00
|
|
|
{
|
|
|
|
R"cpp(// Local variable
|
[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
|
|
|
int main() {
|
|
|
|
int bonjour;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[bonjour]] = 2;
|
[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
|
|
|
int test1 = bonjour;
|
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "bonjour";
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "main::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "int bonjour";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Local variable in method
|
[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
|
|
|
struct s {
|
|
|
|
void method() {
|
|
|
|
int bonjour;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[bonjour]] = 2;
|
[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
|
|
|
}
|
|
|
|
};
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "bonjour";
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "s::method::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "int bonjour";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Struct
|
[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 ns1 {
|
|
|
|
struct MyClass {};
|
|
|
|
} // namespace ns1
|
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
ns1::[[My^Class]]* 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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "MyClass";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.NamespaceScope = "ns1::";
|
|
|
|
HI.Definition = "struct MyClass {}";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Class
|
[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 ns1 {
|
|
|
|
class MyClass {};
|
|
|
|
} // namespace ns1
|
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
ns1::[[My^Class]]* 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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "MyClass";
|
|
|
|
HI.Kind = index::SymbolKind::Class;
|
|
|
|
HI.NamespaceScope = "ns1::";
|
|
|
|
HI.Definition = "class MyClass {}";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Union
|
[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 ns1 {
|
|
|
|
union MyUnion { int x; int y; };
|
|
|
|
} // namespace ns1
|
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
ns1::[[My^Union]] 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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "MyUnion";
|
|
|
|
HI.Kind = index::SymbolKind::Union;
|
|
|
|
HI.NamespaceScope = "ns1::";
|
|
|
|
HI.Definition = "union MyUnion {}";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Function definition via pointer
|
2019-12-03 02:34:03 +08:00
|
|
|
void foo(int) {}
|
[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
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
auto *X = &^[[foo]];
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.Kind = index::SymbolKind::Function;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Type = "void (int)";
|
|
|
|
HI.Definition = "void foo(int)";
|
|
|
|
HI.Documentation = "Function definition via pointer";
|
|
|
|
HI.ReturnType = "void";
|
|
|
|
HI.Parameters = {
|
|
|
|
{std::string("int"), llvm::None, llvm::None},
|
|
|
|
};
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Function declaration via call
|
[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
|
|
|
int foo(int);
|
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
return ^[[foo]](42);
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.Kind = index::SymbolKind::Function;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Type = "int (int)";
|
|
|
|
HI.Definition = "int foo(int)";
|
|
|
|
HI.Documentation = "Function declaration via call";
|
|
|
|
HI.ReturnType = "int";
|
|
|
|
HI.Parameters = {
|
|
|
|
{std::string("int"), llvm::None, llvm::None},
|
|
|
|
};
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Field
|
[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
|
|
|
struct Foo { int x; };
|
|
|
|
int main() {
|
|
|
|
Foo bar;
|
2019-12-03 02:34:03 +08:00
|
|
|
(void)bar.^[[x]];
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "x";
|
|
|
|
HI.Kind = index::SymbolKind::Field;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "Foo::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "int x";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Field with initialization
|
[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
|
|
|
struct Foo { int x = 5; };
|
|
|
|
int main() {
|
|
|
|
Foo bar;
|
2019-12-03 02:34:03 +08:00
|
|
|
(void)bar.^[[x]];
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "x";
|
|
|
|
HI.Kind = index::SymbolKind::Field;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "Foo::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "int x = 5";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Static field
|
[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
|
|
|
struct Foo { static int x; };
|
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
(void)Foo::^[[x]];
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "x";
|
|
|
|
HI.Kind = index::SymbolKind::StaticProperty;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "Foo::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "static int x";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Field, member initializer
|
[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
|
|
|
struct Foo {
|
|
|
|
int x;
|
2019-12-03 02:34:03 +08:00
|
|
|
Foo() : ^[[x]](0) {}
|
[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
|
|
|
};
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "x";
|
|
|
|
HI.Kind = index::SymbolKind::Field;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "Foo::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "int x";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Field, GNU old-style field designator
|
[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
|
|
|
struct Foo { int x; };
|
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
Foo bar = { ^[[x]] : 1 };
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "x";
|
|
|
|
HI.Kind = index::SymbolKind::Field;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "Foo::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "int x";
|
|
|
|
HI.Value = "{1}";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Field, field designator
|
[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
|
|
|
struct Foo { int x; };
|
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
Foo bar = { .^[[x]] = 2 };
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "x";
|
|
|
|
HI.Kind = index::SymbolKind::Field;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "Foo::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "int x";
|
|
|
|
HI.Value = "{2}";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Method call
|
[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
|
|
|
struct Foo { int x(); };
|
|
|
|
int main() {
|
|
|
|
Foo bar;
|
2019-12-03 02:34:03 +08:00
|
|
|
bar.^[[x]]();
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "x";
|
|
|
|
HI.Kind = index::SymbolKind::InstanceMethod;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "Foo::";
|
|
|
|
HI.Type = "int ()";
|
|
|
|
HI.Definition = "int x()";
|
|
|
|
HI.ReturnType = "int";
|
|
|
|
HI.Parameters = std::vector<HoverInfo::Param>{};
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Static method call
|
[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
|
|
|
struct Foo { static int x(); };
|
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
Foo::^[[x]]();
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "x";
|
|
|
|
HI.Kind = index::SymbolKind::StaticMethod;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "Foo::";
|
|
|
|
HI.Type = "int ()";
|
|
|
|
HI.Definition = "static int x()";
|
|
|
|
HI.ReturnType = "int";
|
|
|
|
HI.Parameters = std::vector<HoverInfo::Param>{};
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Typedef
|
[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
|
|
|
typedef int Foo;
|
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[Foo]] bar;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Foo";
|
|
|
|
HI.Kind = index::SymbolKind::TypeAlias;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Definition = "typedef int Foo";
|
|
|
|
HI.Documentation = "Typedef";
|
|
|
|
// FIXME: Maybe put underlying type into HI.Type for aliases?
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Typedef with embedded 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
|
|
|
typedef struct Bar {} Foo;
|
|
|
|
int main() {
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[Foo]] bar;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Foo";
|
|
|
|
HI.Kind = index::SymbolKind::TypeAlias;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Definition = "typedef struct Bar Foo";
|
|
|
|
HI.Documentation = "Typedef with embedded definition";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Namespace
|
[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 ns {
|
2019-12-03 02:34:03 +08:00
|
|
|
struct Foo { static void bar(); };
|
[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 ns
|
2019-12-03 02:34:03 +08:00
|
|
|
int main() { ^[[ns]]::Foo::bar(); }
|
[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
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "ns";
|
|
|
|
HI.Kind = index::SymbolKind::Namespace;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Definition = "namespace ns {}";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Anonymous namespace
|
[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 ns {
|
|
|
|
namespace {
|
|
|
|
int foo;
|
|
|
|
} // anonymous namespace
|
|
|
|
} // namespace ns
|
2019-12-03 02:34:03 +08:00
|
|
|
int main() { ns::[[f^oo]]++; }
|
[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
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.NamespaceScope = "ns::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "int foo";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// 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
|
|
|
#define MACRO 0
|
2019-12-03 02:34:03 +08:00
|
|
|
int main() { return ^[[MACRO]]; }
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "MACRO";
|
|
|
|
HI.Kind = index::SymbolKind::Macro;
|
|
|
|
HI.Definition = "#define MACRO 0";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// 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
|
|
|
#define MACRO 0
|
2019-12-03 02:34:03 +08:00
|
|
|
#define MACRO2 ^[[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
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "MACRO";
|
|
|
|
HI.Kind = index::SymbolKind::Macro;
|
|
|
|
HI.Definition = "#define MACRO 0";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// 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
|
|
|
#define MACRO {\
|
|
|
|
return 0;\
|
|
|
|
}
|
2019-12-03 02:34:03 +08:00
|
|
|
int main() ^[[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
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "MACRO";
|
|
|
|
HI.Kind = index::SymbolKind::Macro;
|
|
|
|
HI.Definition =
|
|
|
|
R"cpp(#define MACRO \
|
2019-12-03 02:34:03 +08:00
|
|
|
{ return 0; })cpp";
|
2019-12-27 16:26:39 +08:00
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Forward class declaration
|
[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
|
|
|
class Foo;
|
|
|
|
class Foo {};
|
2019-12-03 02:34:03 +08:00
|
|
|
[[F^oo]]* foo();
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Foo";
|
|
|
|
HI.Kind = index::SymbolKind::Class;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Definition = "class Foo {}";
|
|
|
|
HI.Documentation = "Forward class declaration";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Function declaration
|
[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
|
|
|
void foo();
|
2019-12-03 02:34:03 +08:00
|
|
|
void g() { [[f^oo]](); }
|
[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
|
|
|
void foo() {}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.Kind = index::SymbolKind::Function;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Type = "void ()";
|
|
|
|
HI.Definition = "void foo()";
|
|
|
|
HI.Documentation = "Function declaration";
|
|
|
|
HI.ReturnType = "void";
|
|
|
|
HI.Parameters = std::vector<HoverInfo::Param>{};
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Enum declaration
|
[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
|
|
|
enum Hello {
|
|
|
|
ONE, TWO, THREE,
|
|
|
|
};
|
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
[[Hel^lo]] hello = ONE;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Hello";
|
|
|
|
HI.Kind = index::SymbolKind::Enum;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Definition = "enum Hello {}";
|
|
|
|
HI.Documentation = "Enum declaration";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Enumerator
|
[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
|
|
|
enum Hello {
|
|
|
|
ONE, TWO, THREE,
|
|
|
|
};
|
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
Hello hello = [[O^NE]];
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "ONE";
|
|
|
|
HI.Kind = index::SymbolKind::EnumConstant;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "Hello::";
|
|
|
|
HI.Type = "enum Hello";
|
|
|
|
HI.Definition = "ONE";
|
|
|
|
HI.Value = "0";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Enumerator in anonymous enum
|
[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
|
|
|
enum {
|
|
|
|
ONE, TWO, THREE,
|
|
|
|
};
|
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
int hello = [[O^NE]];
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "ONE";
|
|
|
|
HI.Kind = index::SymbolKind::EnumConstant;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
// FIXME: This should be `(anon enum)::`
|
|
|
|
HI.LocalScope = "";
|
|
|
|
HI.Type = "enum (anonymous)";
|
|
|
|
HI.Definition = "ONE";
|
|
|
|
HI.Value = "0";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Global variable
|
[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
|
|
|
static int hey = 10;
|
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
[[he^y]]++;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "hey";
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "static int hey = 10";
|
|
|
|
HI.Documentation = "Global variable";
|
|
|
|
// FIXME: Value shouldn't be set in this case
|
|
|
|
HI.Value = "10";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Global variable in namespace
|
[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 ns1 {
|
|
|
|
static int hey = 10;
|
|
|
|
}
|
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
ns1::[[he^y]]++;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "hey";
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.NamespaceScope = "ns1::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "static int hey = 10";
|
|
|
|
HI.Value = "10";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Field in anonymous struct
|
[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
|
|
|
static struct {
|
|
|
|
int hello;
|
|
|
|
} s;
|
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
s.[[he^llo]]++;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "hello";
|
|
|
|
HI.Kind = index::SymbolKind::Field;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "(anonymous struct)::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "int hello";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Templated function
|
[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
|
|
|
template <typename T>
|
|
|
|
T foo() {
|
|
|
|
return 17;
|
|
|
|
}
|
2019-12-03 02:34:03 +08:00
|
|
|
void g() { auto x = [[f^oo]]<int>(); }
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.Kind = index::SymbolKind::Function;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Type = "int ()";
|
|
|
|
HI.Definition = "template <> int foo<int>()";
|
|
|
|
HI.Documentation = "Templated function";
|
|
|
|
HI.ReturnType = "int";
|
|
|
|
HI.Parameters = std::vector<HoverInfo::Param>{};
|
|
|
|
// FIXME: We should populate template parameters with arguments in
|
|
|
|
// case of instantiations.
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Anonymous union
|
[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
|
|
|
struct outer {
|
|
|
|
union {
|
|
|
|
int abc, def;
|
|
|
|
} v;
|
|
|
|
};
|
2019-12-03 02:34:03 +08:00
|
|
|
void g() { struct outer o; o.v.[[d^ef]]++; }
|
[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
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "def";
|
|
|
|
HI.Kind = index::SymbolKind::Field;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "outer::(anonymous union)::";
|
|
|
|
HI.Type = "int";
|
|
|
|
HI.Definition = "int def";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// documentation from 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
|
|
|
int nextSymbolIsAForwardDeclFromIndexWithNoLocalDocs;
|
|
|
|
void indexSymbol();
|
2019-12-03 02:34:03 +08:00
|
|
|
void g() { [[ind^exSymbol]](); }
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "indexSymbol";
|
|
|
|
HI.Kind = index::SymbolKind::Function;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Type = "void ()";
|
|
|
|
HI.Definition = "void indexSymbol()";
|
|
|
|
HI.ReturnType = "void";
|
|
|
|
HI.Parameters = std::vector<HoverInfo::Param>{};
|
|
|
|
HI.Documentation = "comment from index";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Simple initialization with auto
|
[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
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[auto]] i = 1;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "int";
|
|
|
|
// FIXME: Should be Builtin/Integral.
|
|
|
|
HI.Kind = index::SymbolKind::Unknown;
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// Simple initialization with const auto
|
[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
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
const ^[[auto]] i = 1;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// Simple initialization with const auto&
|
[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
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
const ^[[auto]]& i = 1;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// Simple initialization with auto&
|
[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
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
int x;
|
|
|
|
^[[auto]]& i = x;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// Simple initialization with auto*
|
[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
|
|
|
void foo() {
|
|
|
|
int a = 1;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[auto]]* i = &a;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// Auto with initializer list.
|
[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 std
|
|
|
|
{
|
|
|
|
template<class _E>
|
|
|
|
class initializer_list {};
|
|
|
|
}
|
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[auto]] i = {1,2};
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "initializer_list<int>";
|
|
|
|
HI.Kind = index::SymbolKind::Class;
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// User defined conversion to auto
|
[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
|
|
|
struct Bar {
|
2019-12-03 02:34:03 +08:00
|
|
|
operator ^[[auto]]() const { return 10; }
|
[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
|
|
|
};
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// Simple initialization with decltype(auto)
|
[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
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](auto) i = 1;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// Simple initialization with const decltype(auto)
|
[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
|
|
|
void foo() {
|
|
|
|
const int j = 0;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](auto) i = j;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "const int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// Simple initialization with const& decltype(auto)
|
[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
|
|
|
void foo() {
|
|
|
|
int k = 0;
|
|
|
|
const int& j = k;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](auto) i = j;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "const int &"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// Simple initialization with & decltype(auto)
|
[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
|
|
|
void foo() {
|
|
|
|
int k = 0;
|
|
|
|
int& j = k;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](auto) i = j;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int &"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// simple trailing return type
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[auto]] main() -> int {
|
[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 0;
|
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// auto function return with trailing 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
|
|
|
struct Bar {};
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[auto]] test() -> decltype(Bar()) {
|
[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 Bar();
|
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Bar";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.Documentation = "auto function return with trailing type";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// trailing return 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
|
|
|
struct Bar {};
|
2019-12-03 02:34:03 +08:00
|
|
|
auto test() -> ^[[decltype]](Bar()) {
|
[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 Bar();
|
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Bar";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.Documentation = "trailing return type";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// auto in function 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
|
|
|
struct Bar {};
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[auto]] test() {
|
[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 Bar();
|
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Bar";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.Documentation = "auto in function return";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// auto& in function 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
|
|
|
struct Bar {};
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[auto]]& test() {
|
|
|
|
static Bar x;
|
|
|
|
return x;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Bar";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.Documentation = "auto& in function return";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// auto* in function 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
|
|
|
struct Bar {};
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[auto]]* test() {
|
[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
|
|
|
Bar* bar;
|
|
|
|
return bar;
|
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Bar";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.Documentation = "auto* in function return";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// const auto& in function 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
|
|
|
struct Bar {};
|
2019-12-03 02:34:03 +08:00
|
|
|
const ^[[auto]]& test() {
|
|
|
|
static Bar x;
|
|
|
|
return x;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Bar";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.Documentation = "const auto& in function return";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// decltype(auto) in function 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
|
|
|
struct Bar {};
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](auto) test() {
|
[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 Bar();
|
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Bar";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.Documentation = "decltype(auto) in function return";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// decltype(auto) reference in function return
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](auto) test() {
|
|
|
|
static int a;
|
[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 (a);
|
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int &"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// decltype lvalue reference
|
[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
|
|
|
void foo() {
|
|
|
|
int I = 0;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](I) J = I;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// decltype lvalue reference
|
[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
|
|
|
void foo() {
|
|
|
|
int I= 0;
|
|
|
|
int &K = I;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](K) J = I;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int &"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// decltype lvalue reference parenthesis
|
[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
|
|
|
void foo() {
|
|
|
|
int I = 0;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]]((I)) J = I;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int &"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// decltype rvalue reference
|
[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
|
|
|
void foo() {
|
|
|
|
int I = 0;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](static_cast<int&&>(I)) J = static_cast<int&&>(I);
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int &&"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// decltype rvalue reference function call
|
[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
|
|
|
int && bar();
|
|
|
|
void foo() {
|
|
|
|
int I = 0;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](bar()) J = bar();
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int &&"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// decltype of function with trailing return 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
|
|
|
struct Bar {};
|
|
|
|
auto test() -> decltype(Bar()) {
|
|
|
|
return Bar();
|
|
|
|
}
|
|
|
|
void foo() {
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](test()) i = test();
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "Bar";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.Documentation =
|
|
|
|
"decltype of function with trailing return type.";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// decltype of var with decltype.
|
[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
|
|
|
void foo() {
|
|
|
|
int I = 0;
|
|
|
|
decltype(I) J = I;
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[decltype]](J) K = J;
|
[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
|
|
|
}
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
2020-01-04 23:28:41 +08:00
|
|
|
R"cpp(// More complicated structured 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
|
|
|
int bar();
|
2019-12-03 02:34:03 +08:00
|
|
|
^[[auto]] (*foo)() = bar;
|
[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
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// Should not crash when evaluating the initializer.
|
[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
|
|
|
struct Test {};
|
2019-12-03 02:34:03 +08:00
|
|
|
void test() { Test && [[te^st]] = {}; }
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "test";
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "test::";
|
|
|
|
HI.Type = "struct Test &&";
|
2020-01-07 22:15:00 +08:00
|
|
|
HI.Definition = "Test &&test = {}";
|
2019-12-27 16:26:39 +08:00
|
|
|
HI.Value = "{}";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// auto on alias
|
2019-12-17 20:00:12 +08:00
|
|
|
typedef int int_type;
|
|
|
|
^[[auto]] x = int_type();
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) { HI.Name = "int"; }},
|
|
|
|
{
|
|
|
|
R"cpp(// auto on alias
|
2019-12-17 20:00:12 +08:00
|
|
|
struct cls {};
|
|
|
|
typedef cls cls_type;
|
|
|
|
^[[auto]] y = cls_type();
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "cls";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.Documentation = "auto on alias";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// auto on alias
|
2019-12-17 20:00:12 +08:00
|
|
|
template <class>
|
|
|
|
struct templ {};
|
|
|
|
^[[auto]] z = templ<int>();
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "templ<int>";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.Documentation = "auto on alias";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// should not crash.
|
2019-12-27 16:11:03 +08:00
|
|
|
template <class T> struct cls {
|
|
|
|
int method();
|
|
|
|
};
|
|
|
|
|
|
|
|
auto test = cls<int>().[[m^ethod]]();
|
|
|
|
)cpp",
|
2019-12-27 16:26:39 +08:00
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Definition = "int method()";
|
|
|
|
HI.Kind = index::SymbolKind::InstanceMethod;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.LocalScope = "cls<int>::";
|
|
|
|
HI.Name = "method";
|
|
|
|
HI.Parameters.emplace();
|
|
|
|
HI.ReturnType = "int";
|
|
|
|
HI.Type = "int ()";
|
|
|
|
}},
|
2020-01-07 22:15:00 +08:00
|
|
|
{
|
|
|
|
R"cpp(// type of nested templates.
|
|
|
|
template <class T> struct cls {};
|
|
|
|
cls<cls<cls<int>>> [[fo^o]];
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Definition = "cls<cls<cls<int>>> foo";
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.Type = "cls<cls<cls<int> > >";
|
|
|
|
HI.Value = "{}";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// type of nested templates.
|
|
|
|
template <class T> struct cls {};
|
|
|
|
[[cl^s]]<cls<cls<int>>> foo;
|
|
|
|
)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Definition = "template <> struct cls<cls<cls<int>>> {}";
|
|
|
|
HI.Kind = index::SymbolKind::Struct;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "cls<cls<cls<int> > >";
|
|
|
|
HI.Documentation = "type of nested templates.";
|
|
|
|
}},
|
2020-01-16 22:20:13 +08:00
|
|
|
{
|
|
|
|
R"cpp(// type with decltype
|
|
|
|
int a;
|
|
|
|
decltype(a) [[b^]] = a;)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Definition = "decltype(a) b = a";
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "b";
|
|
|
|
HI.Type = "int";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// type with decltype
|
|
|
|
int a;
|
|
|
|
decltype(a) c;
|
|
|
|
decltype(c) [[b^]] = a;)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Definition = "decltype(c) b = a";
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "b";
|
|
|
|
HI.Type = "int";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// type with decltype
|
|
|
|
int a;
|
|
|
|
const decltype(a) [[b^]] = a;)cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Definition = "const decltype(a) b = a";
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "b";
|
|
|
|
HI.Type = "int";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// type with decltype
|
|
|
|
int a;
|
|
|
|
auto [[f^oo]](decltype(a) x) -> decltype(a) { return 0; })cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Definition = "auto foo(decltype(a) x) -> decltype(a)";
|
|
|
|
HI.Kind = index::SymbolKind::Function;
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
HI.Name = "foo";
|
|
|
|
// FIXME: Handle composite types with decltype with a printing
|
|
|
|
// policy.
|
|
|
|
HI.Type = "auto (decltype(a)) -> decltype(a)";
|
|
|
|
HI.ReturnType = "int";
|
|
|
|
HI.Parameters = {
|
|
|
|
{std::string("int"), std::string("x"), llvm::None}};
|
|
|
|
}},
|
2020-01-29 18:17:45 +08:00
|
|
|
{
|
|
|
|
R"cpp(// sizeof expr
|
|
|
|
void foo() {
|
|
|
|
(void)[[size^of]](char);
|
|
|
|
})cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "expression";
|
|
|
|
HI.Type = "unsigned long";
|
|
|
|
HI.Value = "1";
|
|
|
|
}},
|
|
|
|
{
|
|
|
|
R"cpp(// alignof expr
|
|
|
|
void foo() {
|
|
|
|
(void)[[align^of]](char);
|
|
|
|
})cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "expression";
|
|
|
|
HI.Type = "unsigned long";
|
|
|
|
HI.Value = "1";
|
|
|
|
}},
|
2020-01-31 01:42:01 +08:00
|
|
|
{
|
|
|
|
R"cpp(
|
|
|
|
template <typename T = int>
|
|
|
|
void foo(const T& = T()) {
|
|
|
|
[[f^oo]]<>(3);
|
|
|
|
})cpp",
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.Kind = index::SymbolKind::Function;
|
|
|
|
HI.Type = "void (const int &)";
|
|
|
|
HI.ReturnType = "void";
|
|
|
|
HI.Parameters = {
|
|
|
|
{std::string("const int &"), llvm::None, std::string("T()")}};
|
|
|
|
HI.Definition = "template <> void foo<int>(const int &)";
|
|
|
|
HI.NamespaceScope = "";
|
|
|
|
}},
|
[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
|
|
|
};
|
|
|
|
|
|
|
|
// Create a tiny index, so tests above can verify documentation is fetched.
|
|
|
|
Symbol IndexSym = func("indexSymbol");
|
|
|
|
IndexSym.Documentation = "comment from index";
|
|
|
|
SymbolSlab::Builder Symbols;
|
|
|
|
Symbols.insert(IndexSym);
|
|
|
|
auto Index =
|
|
|
|
MemIndex::build(std::move(Symbols).build(), RefSlab(), RelationSlab());
|
|
|
|
|
2019-12-03 02:34:03 +08:00
|
|
|
for (const auto &Case : Cases) {
|
|
|
|
SCOPED_TRACE(Case.Code);
|
|
|
|
|
|
|
|
Annotations T(Case.Code);
|
[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
|
|
|
TestTU TU = TestTU::withCode(T.code());
|
|
|
|
TU.ExtraArgs.push_back("-std=c++17");
|
2019-12-03 02:34:03 +08:00
|
|
|
TU.ExtraArgs.push_back("-Wno-gnu-designator");
|
2020-01-29 18:17:45 +08:00
|
|
|
// Types might be different depending on the target triplet, we chose a
|
|
|
|
// fixed one to make sure tests passes on different platform.
|
|
|
|
TU.ExtraArgs.push_back("--target=x86_64-pc-linux-gnu");
|
[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
|
|
|
auto AST = TU.build();
|
2019-12-03 02:34:03 +08:00
|
|
|
|
|
|
|
auto H = getHover(AST, T.point(), format::getLLVMStyle(), Index.get());
|
|
|
|
ASSERT_TRUE(H);
|
|
|
|
HoverInfo Expected;
|
|
|
|
Expected.SymRange = T.range();
|
|
|
|
Case.ExpectedBuilder(Expected);
|
|
|
|
|
2020-01-16 22:20:13 +08:00
|
|
|
SCOPED_TRACE(H->present().asPlainText());
|
2019-12-03 02:34:03 +08:00
|
|
|
EXPECT_EQ(H->NamespaceScope, Expected.NamespaceScope);
|
|
|
|
EXPECT_EQ(H->LocalScope, Expected.LocalScope);
|
|
|
|
EXPECT_EQ(H->Name, Expected.Name);
|
|
|
|
EXPECT_EQ(H->Kind, Expected.Kind);
|
|
|
|
EXPECT_EQ(H->Documentation, Expected.Documentation);
|
|
|
|
EXPECT_EQ(H->Definition, Expected.Definition);
|
|
|
|
EXPECT_EQ(H->Type, Expected.Type);
|
|
|
|
EXPECT_EQ(H->ReturnType, Expected.ReturnType);
|
|
|
|
EXPECT_EQ(H->Parameters, Expected.Parameters);
|
|
|
|
EXPECT_EQ(H->TemplateParameters, Expected.TemplateParameters);
|
|
|
|
EXPECT_EQ(H->SymRange, Expected.SymRange);
|
|
|
|
EXPECT_EQ(H->Value, Expected.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
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-17 19:13:28 +08:00
|
|
|
TEST(Hover, DocsFromIndex) {
|
|
|
|
Annotations T(R"cpp(
|
|
|
|
template <typename T> class X {};
|
|
|
|
void foo() {
|
|
|
|
au^to t = X<int>();
|
|
|
|
X^<int> w;
|
|
|
|
(void)w;
|
|
|
|
})cpp");
|
|
|
|
|
|
|
|
TestTU TU = TestTU::withCode(T.code());
|
|
|
|
auto AST = TU.build();
|
|
|
|
Symbol IndexSym;
|
|
|
|
IndexSym.ID = *getSymbolID(&findDecl(AST, "X"));
|
|
|
|
IndexSym.Documentation = "comment from index";
|
|
|
|
SymbolSlab::Builder Symbols;
|
|
|
|
Symbols.insert(IndexSym);
|
|
|
|
auto Index =
|
|
|
|
MemIndex::build(std::move(Symbols).build(), RefSlab(), RelationSlab());
|
|
|
|
|
|
|
|
for (const auto &P : T.points()) {
|
|
|
|
auto H = getHover(AST, P, format::getLLVMStyle(), Index.get());
|
|
|
|
ASSERT_TRUE(H);
|
|
|
|
EXPECT_EQ(H->Documentation, IndexSym.Documentation);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Hover, DocsFromAST) {
|
|
|
|
Annotations T(R"cpp(
|
|
|
|
// doc
|
|
|
|
template <typename T> class X {};
|
|
|
|
// doc
|
|
|
|
template <typename T> void bar() {}
|
|
|
|
// doc
|
|
|
|
template <typename T> T baz;
|
|
|
|
void foo() {
|
|
|
|
au^to t = X<int>();
|
|
|
|
X^<int>();
|
|
|
|
b^ar<int>();
|
|
|
|
au^to T = ba^z<X<int>>;
|
|
|
|
ba^z<int> = 0;
|
|
|
|
})cpp");
|
|
|
|
|
|
|
|
TestTU TU = TestTU::withCode(T.code());
|
|
|
|
auto AST = TU.build();
|
|
|
|
for (const auto &P : T.points()) {
|
|
|
|
auto H = getHover(AST, P, format::getLLVMStyle(), nullptr);
|
|
|
|
ASSERT_TRUE(H);
|
|
|
|
EXPECT_EQ(H->Documentation, "doc");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Hover, DocsFromMostSpecial) {
|
|
|
|
Annotations T(R"cpp(
|
|
|
|
// doc1
|
|
|
|
template <typename T> class $doc1^X {};
|
|
|
|
// doc2
|
|
|
|
template <> class $doc2^X<int> {};
|
|
|
|
// doc3
|
|
|
|
template <typename T> class $doc3^X<T*> {};
|
|
|
|
void foo() {
|
|
|
|
X$doc1^<char>();
|
|
|
|
X$doc2^<int>();
|
|
|
|
X$doc3^<int*>();
|
|
|
|
})cpp");
|
|
|
|
|
|
|
|
TestTU TU = TestTU::withCode(T.code());
|
|
|
|
auto AST = TU.build();
|
|
|
|
for (auto Comment : {"doc1", "doc2", "doc3"}) {
|
|
|
|
for (const auto &P : T.points(Comment)) {
|
|
|
|
auto H = getHover(AST, P, format::getLLVMStyle(), nullptr);
|
|
|
|
ASSERT_TRUE(H);
|
|
|
|
EXPECT_EQ(H->Documentation, Comment);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-01-14 00:50:23 +08:00
|
|
|
|
2019-12-13 16:34:59 +08:00
|
|
|
TEST(Hover, Present) {
|
|
|
|
struct {
|
|
|
|
const std::function<void(HoverInfo &)> Builder;
|
|
|
|
llvm::StringRef ExpectedRender;
|
|
|
|
} Cases[] = {
|
|
|
|
{
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Kind = index::SymbolKind::Unknown;
|
|
|
|
HI.Name = "X";
|
|
|
|
},
|
2020-01-16 01:09:51 +08:00
|
|
|
R"(X)",
|
2019-12-13 16:34:59 +08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Kind = index::SymbolKind::NamespaceAlias;
|
|
|
|
HI.Name = "foo";
|
|
|
|
},
|
|
|
|
R"(namespace-alias foo)",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Kind = index::SymbolKind::Class;
|
|
|
|
HI.TemplateParameters = {
|
|
|
|
{std::string("typename"), std::string("T"), llvm::None},
|
|
|
|
{std::string("typename"), std::string("C"),
|
|
|
|
std::string("bool")},
|
|
|
|
};
|
|
|
|
HI.Documentation = "documentation";
|
|
|
|
HI.Definition =
|
|
|
|
"template <typename T, typename C = bool> class Foo {}";
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.NamespaceScope.emplace();
|
|
|
|
},
|
|
|
|
R"(class foo
|
2020-01-14 00:14:24 +08:00
|
|
|
|
2019-12-13 16:34:59 +08:00
|
|
|
documentation
|
|
|
|
|
|
|
|
template <typename T, typename C = bool> class Foo {})",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Kind = index::SymbolKind::Function;
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.Type = "type";
|
|
|
|
HI.ReturnType = "ret_type";
|
|
|
|
HI.Parameters.emplace();
|
|
|
|
HoverInfo::Param P;
|
|
|
|
HI.Parameters->push_back(P);
|
|
|
|
P.Type = "type";
|
|
|
|
HI.Parameters->push_back(P);
|
|
|
|
P.Name = "foo";
|
|
|
|
HI.Parameters->push_back(P);
|
|
|
|
P.Default = "default";
|
|
|
|
HI.Parameters->push_back(P);
|
|
|
|
HI.NamespaceScope = "ns::";
|
|
|
|
HI.Definition = "ret_type foo(params) {}";
|
|
|
|
},
|
2020-01-14 00:21:31 +08:00
|
|
|
R"(function foo
|
2020-01-14 00:14:24 +08:00
|
|
|
|
2020-01-24 18:35:24 +08:00
|
|
|
→ ret_type
|
2020-01-14 00:21:31 +08:00
|
|
|
Parameters:
|
2019-12-13 16:34:59 +08:00
|
|
|
-
|
|
|
|
- type
|
|
|
|
- type foo
|
|
|
|
- type foo = default
|
|
|
|
|
|
|
|
// In namespace ns
|
|
|
|
ret_type foo(params) {})",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
[](HoverInfo &HI) {
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.LocalScope = "test::bar::";
|
|
|
|
HI.Value = "value";
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.Type = "type";
|
|
|
|
HI.Definition = "def";
|
|
|
|
},
|
2020-01-14 00:21:31 +08:00
|
|
|
R"(variable foo
|
2020-01-14 00:14:24 +08:00
|
|
|
|
2020-01-14 00:21:31 +08:00
|
|
|
Type: type
|
2019-12-13 16:34:59 +08:00
|
|
|
Value = value
|
|
|
|
|
|
|
|
// In test::bar
|
|
|
|
def)",
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
for (const auto &C : Cases) {
|
|
|
|
HoverInfo HI;
|
|
|
|
C.Builder(HI);
|
|
|
|
EXPECT_EQ(HI.present().asPlainText(), C.ExpectedRender);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-14 00:50:23 +08:00
|
|
|
// This is a separate test as headings don't create any differences in plaintext
|
|
|
|
// mode.
|
|
|
|
TEST(Hover, PresentHeadings) {
|
|
|
|
HoverInfo HI;
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.Name = "foo";
|
|
|
|
|
2020-01-14 00:21:31 +08:00
|
|
|
EXPECT_EQ(HI.present().asMarkdown(), "### variable `foo`");
|
2020-01-14 00:50:23 +08:00
|
|
|
}
|
|
|
|
|
2020-01-14 00:14:24 +08:00
|
|
|
// This is a separate test as rulers behave differently in markdown vs
|
|
|
|
// plaintext.
|
|
|
|
TEST(Hover, PresentRulers) {
|
|
|
|
HoverInfo HI;
|
|
|
|
HI.Kind = index::SymbolKind::Variable;
|
|
|
|
HI.Name = "foo";
|
|
|
|
HI.Value = "val";
|
|
|
|
HI.Definition = "def";
|
|
|
|
|
2020-01-16 00:59:02 +08:00
|
|
|
llvm::StringRef ExpectedMarkdown = R"md(### variable `foo`
|
2020-01-14 00:14:24 +08:00
|
|
|
|
|
|
|
---
|
2020-03-06 00:44:28 +08:00
|
|
|
Value = `val`
|
2020-01-14 00:14:24 +08:00
|
|
|
|
|
|
|
---
|
|
|
|
```cpp
|
|
|
|
def
|
2020-01-16 00:59:02 +08:00
|
|
|
```)md";
|
|
|
|
EXPECT_EQ(HI.present().asMarkdown(), ExpectedMarkdown);
|
|
|
|
|
|
|
|
llvm::StringRef ExpectedPlaintext = R"pt(variable foo
|
2020-01-14 00:14:24 +08:00
|
|
|
|
|
|
|
Value = val
|
|
|
|
|
2020-01-16 00:59:02 +08:00
|
|
|
def)pt";
|
|
|
|
EXPECT_EQ(HI.present().asPlainText(), ExpectedPlaintext);
|
2020-01-14 00:14:24 +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
|
|
|
} // namespace
|
|
|
|
} // namespace clangd
|
|
|
|
} // namespace clang
|