Skip to content

Commit cbcb3ee

Browse files
committed
[Tooling/Inclusion] Handle std::get symbol.
Currently, we handle it as a symbol without a header. In general, for the include-cleaner case, the std::get comes with the type header, it is safe to ignore it. Differential Revision: https://reviews.llvm.org/D144484
1 parent 219ba2f commit cbcb3ee

File tree

5 files changed

+19
-5
lines changed

5 files changed

+19
-5
lines changed

clang-tools-extra/clangd/index/CanonicalIncludes.cpp

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -717,7 +717,8 @@ llvm::StringRef CanonicalIncludes::mapSymbol(llvm::StringRef Scope,
717717
if (Scope == "std::" && Name == "move")
718718
return "<utility>";
719719
if (auto StdSym = tooling::stdlib::Symbol::named(Scope, Name, Lang))
720-
return StdSym->header().name();
720+
if (auto Header = StdSym->header())
721+
return Header->name();
721722
return "";
722723
}
723724

clang/include/clang/Tooling/Inclusions/StandardLibrary.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -81,7 +81,7 @@ class Symbol {
8181
llvm::StringRef name() const;
8282
llvm::StringRef qualifiedName() const;
8383
// The preferred header for this symbol (e.g. the suggested insertion).
84-
Header header() const;
84+
std::optional<Header> header() const;
8585
// Some symbols may be provided by multiple headers.
8686
llvm::SmallVector<Header> headers() const;
8787

clang/lib/Tooling/Inclusions/Stdlib/StandardLibrary.cpp

Lines changed: 8 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,7 @@
1414
#include "llvm/ADT/STLExtras.h"
1515
#include "llvm/ADT/StringRef.h"
1616
#include "llvm/Support/Casting.h"
17+
#include <optional>
1718

1819
namespace clang {
1920
namespace tooling {
@@ -120,7 +121,8 @@ static int initialize(Lang Language) {
120121
}
121122
Mapping->SymbolNames[SymIndex] = {
122123
QName.data(), NSLen, static_cast<unsigned int>(QName.size() - NSLen)};
123-
Mapping->SymbolHeaderIDs[SymIndex].push_back(AddHeader(HeaderName));
124+
if (!HeaderName.empty())
125+
Mapping->SymbolHeaderIDs[SymIndex].push_back(AddHeader(HeaderName));
124126

125127
NSSymbolMap &NSSymbols = AddNS(QName.take_front(NSLen));
126128
NSSymbols.try_emplace(QName.drop_front(NSLen), SymIndex);
@@ -205,8 +207,11 @@ std::optional<Symbol> Symbol::named(llvm::StringRef Scope, llvm::StringRef Name,
205207
}
206208
return std::nullopt;
207209
}
208-
Header Symbol::header() const {
209-
return Header(getMappingPerLang(Language)->SymbolHeaderIDs[ID][0], Language);
210+
std::optional<Header> Symbol::header() const {
211+
const auto& Headers = getMappingPerLang(Language)->SymbolHeaderIDs[ID];
212+
if (Headers.empty())
213+
return std::nullopt;
214+
return Header(Headers.front(), Language);
210215
}
211216
llvm::SmallVector<Header> Symbol::headers() const {
212217
llvm::SmallVector<Header> Results;

clang/lib/Tooling/Inclusions/Stdlib/StdSpecialSymbolMap.inc

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -218,3 +218,8 @@ SYMBOL(ssize, std::, <string_view>)
218218
SYMBOL(ssize, std::, <unordered_map>)
219219
SYMBOL(ssize, std::, <unordered_set>)
220220
SYMBOL(ssize, std::, <vector>)
221+
222+
// std::get has a few variants for different types (tuple, array, pair etc)
223+
// which is tricky to disambiguate without type information.
224+
// Don't set any header for it, as it comes with the type header.
225+
SYMBOL(get, std::, /*no headers*/)

clang/unittests/Tooling/StandardLibraryTest.cpp

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -58,6 +58,9 @@ TEST(StdlibTest, All) {
5858
EXPECT_EQ(Vector->header(), *VectorH);
5959
EXPECT_THAT(Vector->headers(), ElementsAre(*VectorH));
6060

61+
EXPECT_TRUE(stdlib::Symbol::named("std::", "get"));
62+
EXPECT_FALSE(stdlib::Symbol::named("std::", "get")->header());
63+
6164
EXPECT_THAT(stdlib::Symbol::named("std::", "basic_iostream")->headers(),
6265
ElementsAre(stdlib::Header::named("<istream>"),
6366
stdlib::Header::named("<iostream>"),

0 commit comments

Comments
 (0)