forked from OSchip/llvm-project
[clangd] Remove FilterText from the index.
Summary: It's almost always identical to Name, and in fact we never used it (we used name instead). The only case where they differ is objc method selectors (foo: vs foo:bar:). We can live with the latter for both name and filterText, so I've made that change too. Reviewers: ioeric Subscribers: ilya-biryukov, MaskRay, jkorous, cfe-commits Differential Revision: https://reviews.llvm.org/D48375 llvm-svn: 335321
This commit is contained in:
parent
aa5f4d2e23
commit
032db94ac9
|
@ -249,7 +249,8 @@ struct CompletionCandidate {
|
||||||
I.kind = toCompletionItemKind(SemaResult->Kind, SemaResult->Declaration);
|
I.kind = toCompletionItemKind(SemaResult->Kind, SemaResult->Declaration);
|
||||||
getLabelAndInsertText(*SemaCCS, &I.label, &I.insertText,
|
getLabelAndInsertText(*SemaCCS, &I.label, &I.insertText,
|
||||||
Opts.EnableSnippets);
|
Opts.EnableSnippets);
|
||||||
I.filterText = getFilterText(*SemaCCS);
|
if (const char* Text = SemaCCS->getTypedText())
|
||||||
|
I.filterText = Text;
|
||||||
I.documentation = formatDocumentation(*SemaCCS, SemaDocComment);
|
I.documentation = formatDocumentation(*SemaCCS, SemaDocComment);
|
||||||
I.detail = getDetail(*SemaCCS);
|
I.detail = getDetail(*SemaCCS);
|
||||||
}
|
}
|
||||||
|
|
|
@ -249,18 +249,5 @@ std::string getDetail(const CodeCompletionString &CCS) {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string getFilterText(const CodeCompletionString &CCS) {
|
|
||||||
for (const auto &Chunk : CCS) {
|
|
||||||
switch (Chunk.Kind) {
|
|
||||||
case CodeCompletionString::CK_TypedText:
|
|
||||||
// There's always exactly one CK_TypedText chunk.
|
|
||||||
return Chunk.Text;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace clangd
|
} // namespace clangd
|
||||||
} // namespace clang
|
} // namespace clang
|
||||||
|
|
|
@ -65,11 +65,6 @@ std::string formatDocumentation(const CodeCompletionString &CCS,
|
||||||
/// is usually the return type of a function.
|
/// is usually the return type of a function.
|
||||||
std::string getDetail(const CodeCompletionString &CCS);
|
std::string getDetail(const CodeCompletionString &CCS);
|
||||||
|
|
||||||
/// Gets the piece of text that the user is expected to type to match the
|
|
||||||
/// code-completion string, typically a keyword or the name of a declarator or
|
|
||||||
/// macro.
|
|
||||||
std::string getFilterText(const CodeCompletionString &CCS);
|
|
||||||
|
|
||||||
} // namespace clangd
|
} // namespace clangd
|
||||||
} // namespace clang
|
} // namespace clang
|
||||||
|
|
||||||
|
|
|
@ -85,7 +85,6 @@ static void own(Symbol &S, DenseSet<StringRef> &Strings,
|
||||||
Intern(S.Definition.FileURI);
|
Intern(S.Definition.FileURI);
|
||||||
|
|
||||||
Intern(S.CompletionLabel);
|
Intern(S.CompletionLabel);
|
||||||
Intern(S.CompletionFilterText);
|
|
||||||
Intern(S.CompletionPlainInsertText);
|
Intern(S.CompletionPlainInsertText);
|
||||||
Intern(S.CompletionSnippetInsertText);
|
Intern(S.CompletionSnippetInsertText);
|
||||||
|
|
||||||
|
|
|
@ -156,10 +156,6 @@ struct Symbol {
|
||||||
/// candidate list. For example, "Foo(X x, Y y) const" is a label for a
|
/// candidate list. For example, "Foo(X x, Y y) const" is a label for a
|
||||||
/// function.
|
/// function.
|
||||||
llvm::StringRef CompletionLabel;
|
llvm::StringRef CompletionLabel;
|
||||||
/// The piece of text that the user is expected to type to match the
|
|
||||||
/// code-completion string, typically a keyword or the name of a declarator or
|
|
||||||
/// macro.
|
|
||||||
llvm::StringRef CompletionFilterText;
|
|
||||||
/// What to insert when completing this symbol (plain text version).
|
/// What to insert when completing this symbol (plain text version).
|
||||||
llvm::StringRef CompletionPlainInsertText;
|
llvm::StringRef CompletionPlainInsertText;
|
||||||
/// What to insert when completing this symbol (snippet version). This is
|
/// What to insert when completing this symbol (snippet version). This is
|
||||||
|
|
|
@ -98,8 +98,6 @@ mergeSymbol(const Symbol &L, const Symbol &R, Symbol::Details *Scratch) {
|
||||||
S.References += O.References;
|
S.References += O.References;
|
||||||
if (S.CompletionLabel == "")
|
if (S.CompletionLabel == "")
|
||||||
S.CompletionLabel = O.CompletionLabel;
|
S.CompletionLabel = O.CompletionLabel;
|
||||||
if (S.CompletionFilterText == "")
|
|
||||||
S.CompletionFilterText = O.CompletionFilterText;
|
|
||||||
if (S.CompletionPlainInsertText == "")
|
if (S.CompletionPlainInsertText == "")
|
||||||
S.CompletionPlainInsertText = O.CompletionPlainInsertText;
|
S.CompletionPlainInsertText = O.CompletionPlainInsertText;
|
||||||
if (S.CompletionSnippetInsertText == "")
|
if (S.CompletionSnippetInsertText == "")
|
||||||
|
|
|
@ -378,6 +378,8 @@ const Symbol *SymbolCollector::addDeclaration(const NamedDecl &ND,
|
||||||
Symbol S;
|
Symbol S;
|
||||||
S.ID = std::move(ID);
|
S.ID = std::move(ID);
|
||||||
std::tie(S.Scope, S.Name) = splitQualifiedName(QName);
|
std::tie(S.Scope, S.Name) = splitQualifiedName(QName);
|
||||||
|
// FIXME: this returns foo:bar: for objective-C methods, we prefer only foo:
|
||||||
|
// for consistency with CodeCompletionString and a clean name/signature split.
|
||||||
|
|
||||||
S.IsIndexedForCodeCompletion = isIndexedForCodeCompletion(ND, Ctx);
|
S.IsIndexedForCodeCompletion = isIndexedForCodeCompletion(ND, Ctx);
|
||||||
S.SymInfo = index::getSymbolInfo(&ND);
|
S.SymInfo = index::getSymbolInfo(&ND);
|
||||||
|
@ -403,7 +405,6 @@ const Symbol *SymbolCollector::addDeclaration(const NamedDecl &ND,
|
||||||
/*EnableSnippets=*/true);
|
/*EnableSnippets=*/true);
|
||||||
getLabelAndInsertText(*CCS, &IgnoredLabel, &PlainInsertText,
|
getLabelAndInsertText(*CCS, &IgnoredLabel, &PlainInsertText,
|
||||||
/*EnableSnippets=*/false);
|
/*EnableSnippets=*/false);
|
||||||
std::string FilterText = getFilterText(*CCS);
|
|
||||||
std::string Documentation =
|
std::string Documentation =
|
||||||
formatDocumentation(*CCS, getDocComment(Ctx, SymbolCompletion,
|
formatDocumentation(*CCS, getDocComment(Ctx, SymbolCompletion,
|
||||||
/*CommentsFromHeaders=*/true));
|
/*CommentsFromHeaders=*/true));
|
||||||
|
@ -417,7 +418,6 @@ const Symbol *SymbolCollector::addDeclaration(const NamedDecl &ND,
|
||||||
QName, SM, SM.getExpansionLoc(ND.getLocation()), Opts))
|
QName, SM, SM.getExpansionLoc(ND.getLocation()), Opts))
|
||||||
Include = std::move(*Header);
|
Include = std::move(*Header);
|
||||||
}
|
}
|
||||||
S.CompletionFilterText = FilterText;
|
|
||||||
S.CompletionLabel = Label;
|
S.CompletionLabel = Label;
|
||||||
S.CompletionPlainInsertText = PlainInsertText;
|
S.CompletionPlainInsertText = PlainInsertText;
|
||||||
S.CompletionSnippetInsertText = SnippetInsertText;
|
S.CompletionSnippetInsertText = SnippetInsertText;
|
||||||
|
|
|
@ -111,7 +111,6 @@ template <> struct MappingTraits<Symbol> {
|
||||||
IO.mapOptional("IsIndexedForCodeCompletion", Sym.IsIndexedForCodeCompletion,
|
IO.mapOptional("IsIndexedForCodeCompletion", Sym.IsIndexedForCodeCompletion,
|
||||||
false);
|
false);
|
||||||
IO.mapRequired("CompletionLabel", Sym.CompletionLabel);
|
IO.mapRequired("CompletionLabel", Sym.CompletionLabel);
|
||||||
IO.mapRequired("CompletionFilterText", Sym.CompletionFilterText);
|
|
||||||
IO.mapRequired("CompletionPlainInsertText", Sym.CompletionPlainInsertText);
|
IO.mapRequired("CompletionPlainInsertText", Sym.CompletionPlainInsertText);
|
||||||
|
|
||||||
IO.mapOptional("CompletionSnippetInsertText",
|
IO.mapOptional("CompletionSnippetInsertText",
|
||||||
|
|
|
@ -43,13 +43,6 @@ TEST_F(CompletionStringTest, Detail) {
|
||||||
EXPECT_EQ(getDetail(*Builder.TakeString()), "result");
|
EXPECT_EQ(getDetail(*Builder.TakeString()), "result");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(CompletionStringTest, FilterText) {
|
|
||||||
Builder.AddTypedTextChunk("typed");
|
|
||||||
Builder.AddTypedTextChunk("redundant typed no no");
|
|
||||||
auto *S = Builder.TakeString();
|
|
||||||
EXPECT_EQ(getFilterText(*S), "typed");
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(CompletionStringTest, Documentation) {
|
TEST_F(CompletionStringTest, Documentation) {
|
||||||
Builder.addBriefComment("This is ignored");
|
Builder.addBriefComment("This is ignored");
|
||||||
EXPECT_EQ(formatDocumentation(*Builder.TakeString(), "Is this brief?"),
|
EXPECT_EQ(formatDocumentation(*Builder.TakeString(), "Is this brief?"),
|
||||||
|
@ -115,7 +108,6 @@ TEST_F(CompletionStringTest, FunctionSnippet) {
|
||||||
EXPECT_EQ(Label, "Foo(p1, p2)");
|
EXPECT_EQ(Label, "Foo(p1, p2)");
|
||||||
EXPECT_EQ(InsertText, "Foo(${1:p1}, ${2:p2})");
|
EXPECT_EQ(InsertText, "Foo(${1:p1}, ${2:p2})");
|
||||||
EXPECT_EQ(formatDocumentation(*CCS, "Foo's comment"), "Foo's comment");
|
EXPECT_EQ(formatDocumentation(*CCS, "Foo's comment"), "Foo's comment");
|
||||||
EXPECT_EQ(getFilterText(*CCS), "Foo");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(CompletionStringTest, EscapeSnippet) {
|
TEST_F(CompletionStringTest, EscapeSnippet) {
|
||||||
|
|
Loading…
Reference in New Issue