Skip to content

Commit

Permalink
rustdoc-search: fix where clause highlight with dup generics
Browse files Browse the repository at this point in the history
Essentially, the unifier only adds generics to a parameter when
a part of its where clause is highlighted. To make that work,
the formatter can ignore the empties.
  • Loading branch information
notriddle committed Jun 8, 2024
1 parent bccb9f7 commit ee3ee04
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 2 deletions.
6 changes: 4 additions & 2 deletions src/librustdoc/html/static/js/search.js
Original file line number Diff line number Diff line change
Expand Up @@ -1572,7 +1572,9 @@ function initSearch(rawSearchIndex) {
for (const nested of fnType.generics) {
writeFn(nested, where);
}
whereClause.set(fnParamNames[-1 - fnType.id], where);
if (where.length > 0) {
whereClause.set(fnParamNames[-1 - fnType.id], where);
}
} else {
if (fnType.ty === TY_PRIMITIVE) {
if (fnType.id === typeNameIdOfArray || fnType.id === typeNameIdOfSlice ||
Expand Down Expand Up @@ -2913,7 +2915,7 @@ function initSearch(rawSearchIndex) {
sorted_returned,
sorted_others,
parsedQuery);
await handleAliases(ret, parsedQuery.original.replace(/"/g, ""),
await handleAliases(ret, parsedQuery.userQuery.replace(/"/g, ""),
filterCrates, currentCrate);
await Promise.all([ret.others, ret.returned, ret.in_args].map(async list => {
const descs = await Promise.all(list.map(result => {
Expand Down
12 changes: 12 additions & 0 deletions tests/rustdoc-js-std/vec-type-signatures.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,4 +19,16 @@ const EXPECTED = [
{ 'path': 'std::vec::IntoIter', 'name': 'next_chunk' },
],
},
{
'query': 'vec<Allocator> -> Box<[T]>',
'others': [
{
'path': 'std::boxed::Box',
'name': 'from',
'displayType': '`Vec`<T, `A`> -> `Box`<`[T]`, A>',
'displayMappedNames': `T = T`,
'displayWhereClause': 'A: `Allocator`',
},
],
},
];

0 comments on commit ee3ee04

Please sign in to comment.