diff --git a/src/librustdoc/html/static/js/search.js b/src/librustdoc/html/static/js/search.js
index 8f68796ad26b8..a521bf66bedd8 100644
--- a/src/librustdoc/html/static/js/search.js
+++ b/src/librustdoc/html/static/js/search.js
@@ -243,7 +243,7 @@ function initSearch(rawSearchIndex) {
* Map from normalized type names to integers. Used to make type search
* more efficient.
*
- * @type {Map}
+ * @type {Map}
*/
let typeNameIdMap;
const ALIASES = new Map();
@@ -270,19 +270,22 @@ function initSearch(rawSearchIndex) {
* get the same ID.
*
* @param {string} name
+ * @param {boolean} isAssocType - True if this is an assoc type
*
* @returns {integer}
*/
- function buildTypeMapIndex(name) {
+ function buildTypeMapIndex(name, isAssocType) {
if (name === "" || name === null) {
return null;
}
if (typeNameIdMap.has(name)) {
- return typeNameIdMap.get(name);
+ const obj = typeNameIdMap.get(name);
+ obj.assocOnly = isAssocType && obj.assocOnly;
+ return obj.id;
} else {
const id = typeNameIdMap.size;
- typeNameIdMap.set(name, id);
+ typeNameIdMap.set(name, {id, assocOnly: isAssocType});
return id;
}
}
@@ -1430,7 +1433,7 @@ function initSearch(rawSearchIndex) {
return true;
}
} else if (unifyFunctionTypes(
- fnType.generics,
+ [...fnType.generics, ...Array.from(fnType.bindings.values()).flat() ],
queryElems,
whereClause,
mgens ? new Map(mgens) : null,
@@ -2129,17 +2132,20 @@ function initSearch(rawSearchIndex) {
* See `buildTypeMapIndex` for more information.
*
* @param {QueryElement} elem
+ * @param {boolean} isAssocType
*/
- function convertNameToId(elem) {
- if (typeNameIdMap.has(elem.pathLast)) {
- elem.id = typeNameIdMap.get(elem.pathLast);
+ function convertNameToId(elem, isAssocType) {
+ if (typeNameIdMap.has(elem.pathLast) &&
+ (isAssocType || !typeNameIdMap.get(elem.pathLast).assocOnly)) {
+ elem.id = typeNameIdMap.get(elem.pathLast).id;
} else if (!parsedQuery.literalSearch) {
let match = null;
let matchDist = maxEditDistance + 1;
let matchName = "";
- for (const [name, id] of typeNameIdMap) {
+ for (const [name, {id, assocOnly}] of typeNameIdMap) {
const dist = editDistance(name, elem.pathLast, maxEditDistance);
- if (dist <= matchDist && dist <= maxEditDistance) {
+ if (dist <= matchDist && dist <= maxEditDistance &&
+ (isAssocType || !assocOnly)) {
if (dist === matchDist && matchName > name) {
continue;
}
@@ -2206,12 +2212,13 @@ function initSearch(rawSearchIndex) {
name,
" does not exist",
];
+ return [null, []];
}
for (const elem2 of constraints) {
convertNameToId(elem2);
}
- return [typeNameIdMap.get(name), constraints];
+ return [typeNameIdMap.get(name).id, constraints];
})
);
}
@@ -2720,7 +2727,7 @@ ${item.displayPath}${name}\
*
* @param {RawFunctionType} type
*/
- function buildItemSearchType(type, lowercasePaths) {
+ function buildItemSearchType(type, lowercasePaths, isAssocType) {
const PATH_INDEX_DATA = 0;
const GENERICS_DATA = 1;
const BINDINGS_DATA = 2;
@@ -2749,7 +2756,7 @@ ${item.displayPath}${name}\
//
// As a result, the key should never have generics on it.
return [
- buildItemSearchType(assocType, lowercasePaths).id,
+ buildItemSearchType(assocType, lowercasePaths, true).id,
buildItemSearchTypeAll(constraints, lowercasePaths),
];
}));
@@ -2780,7 +2787,7 @@ ${item.displayPath}${name}\
}
const item = lowercasePaths[pathIndex - 1];
return {
- id: buildTypeMapIndex(item.name),
+ id: buildTypeMapIndex(item.name, isAssocType),
ty: item.ty,
path: item.path,
generics,
diff --git a/tests/rustdoc-js/assoc-type.js b/tests/rustdoc-js/assoc-type.js
index cc3afaa17c07d..47776656e32c2 100644
--- a/tests/rustdoc-js/assoc-type.js
+++ b/tests/rustdoc-js/assoc-type.js
@@ -19,6 +19,17 @@ const EXPECTED = [
{ 'path': 'assoc_type::my', 'name': 'other_fn' },
],
},
+ {
+ 'query': 'something',
+ 'correction': null,
+ 'others': [
+ { 'path': 'assoc_type', 'name': 'Something' },
+ ],
+ 'in_args': [
+ { 'path': 'assoc_type', 'name': 'my_fn' },
+ { 'path': 'assoc_type::my', 'name': 'other_fn' },
+ ],
+ },
// if I write an explicit binding, only it shows up
{
'query': 'iterator- -> u32',
diff --git a/tests/rustdoc-js/enum-variant-not-type.js b/tests/rustdoc-js/enum-variant-not-type.js
new file mode 100644
index 0000000000000..b0f1ec666583d
--- /dev/null
+++ b/tests/rustdoc-js/enum-variant-not-type.js
@@ -0,0 +1,70 @@
+const EXPECTED = [
+ {
+ 'query': 'T -> T',
+ 'correction': null,
+ 'others': [
+ {
+ 'path': 'enum_variant_not_type',
+ 'name': 'my_fn',
+ },
+ {
+ 'path': 'enum_variant_not_type::AutoCorrectConfounder',
+ 'name': 'assoc_type_acts_like_generic',
+ },
+ ],
+ },
+ {
+ 'query': 'InsertUnnecessarilyLongTypeNameHere -> InsertUnnecessarilyLongTypeNameHere',
+ 'correction': null,
+ 'others': [
+ {
+ 'path': 'enum_variant_not_type',
+ 'name': 'my_fn',
+ },
+ {
+ 'path': 'enum_variant_not_type::AutoCorrectConfounder',
+ 'name': 'assoc_type_acts_like_generic',
+ },
+ ],
+ },
+ {
+ 'query': 'InsertUnnecessarilyLongTypeNameHere',
+ 'correction': null,
+ 'others': [
+ {
+ 'path': 'enum_variant_not_type::AutoCorrectConfounder',
+ 'name': 'InsertUnnecessarilyLongTypeNameHere',
+ },
+ ],
+ },
+ {
+ 'query': 'InsertUnnecessarilyLongTypeNameHereX',
+ 'correction': null,
+ 'others': [
+ {
+ 'path': 'enum_variant_not_type::AutoCorrectConfounder',
+ 'name': 'InsertUnnecessarilyLongTypeNameHere',
+ },
+ ],
+ },
+ {
+ 'query': 'T',
+ 'correction': null,
+ 'others': [
+ {
+ 'path': 'enum_variant_not_type::MyTrait',
+ 'name': 'T',
+ },
+ ],
+ },
+ {
+ 'query': 'T',
+ 'correction': null,
+ 'others': [
+ {
+ 'path': 'enum_variant_not_type::MyTrait',
+ 'name': 'T',
+ },
+ ],
+ },
+];
diff --git a/tests/rustdoc-js/enum-variant-not-type.rs b/tests/rustdoc-js/enum-variant-not-type.rs
new file mode 100644
index 0000000000000..421bddf628946
--- /dev/null
+++ b/tests/rustdoc-js/enum-variant-not-type.rs
@@ -0,0 +1,14 @@
+pub trait MyTrait {
+ // Reduced from `arti` crate.
+ // https://tpo.pages.torproject.net/core/doc/rust/tor_config/list_builder/trait.DirectDefaultEmptyListBuilderAccessors.html#associatedtype.T
+ type T;
+ fn not_appearing(&self) -> Option<&Self::T>;
+}
+
+pub fn my_fn(t: X) -> X { t }
+
+pub trait AutoCorrectConfounder {
+ type InsertUnnecessarilyLongTypeNameHere;
+ fn assoc_type_acts_like_generic(&self, x: &Self::InsertUnnecessarilyLongTypeNameHere)
+ -> Option<&Self::InsertUnnecessarilyLongTypeNameHere>;
+}