rustdoc-search: allow :: and ::

This restriction made sense back when spaces separated function
parameters, but now that they separate path components, there's
no real ambiguity any more.

Additionally, the Rust language allows it.
This commit is contained in:
Michael Howell 2023-11-29 10:11:37 -07:00
parent abe34e9ab1
commit c28de27a73
3 changed files with 61 additions and 25 deletions

View file

@ -512,18 +512,15 @@ function initSearch(rawSearchIndex) {
bindingName, bindingName,
}; };
} }
const quadcolon = /::\s*::/.exec(path);
if (path.startsWith("::")) { if (path.startsWith("::")) {
throw ["Paths cannot start with ", "::"]; throw ["Paths cannot start with ", "::"];
} else if (path.endsWith("::")) { } else if (path.endsWith("::")) {
throw ["Paths cannot end with ", "::"]; throw ["Paths cannot end with ", "::"];
} else if (path.includes("::::")) { } else if (quadcolon !== null) {
throw ["Unexpected ", "::::"]; throw ["Unexpected ", quadcolon[0]];
} else if (path.includes(" ::")) {
throw ["Unexpected ", " ::"];
} else if (path.includes(":: ")) {
throw ["Unexpected ", ":: "];
} }
const pathSegments = path.split(/::|\s+/); const pathSegments = path.split(/(?:::\s*)|(?:\s+(?:::\s*)?)/);
// In case we only have something like `<p>`, there is no name. // In case we only have something like `<p>`, there is no name.
if (pathSegments.length === 0 || (pathSegments.length === 1 && pathSegments[0] === "")) { if (pathSegments.length === 0 || (pathSegments.length === 1 && pathSegments[0] === "")) {
if (generics.length > 0 || prevIs(parserState, ">")) { if (generics.length > 0 || prevIs(parserState, ">")) {

View file

@ -143,6 +143,15 @@ const PARSED = [
userQuery: "a::::b", userQuery: "a::::b",
error: "Unexpected `::::`", error: "Unexpected `::::`",
}, },
{
query: "a:: ::b",
elems: [],
foundElems: 0,
original: "a:: ::b",
returned: [],
userQuery: "a:: ::b",
error: "Unexpected `:: ::`",
},
{ {
query: "a::b::", query: "a::b::",
elems: [], elems: [],
@ -314,24 +323,6 @@ const PARSED = [
userQuery: 'a<->', userQuery: 'a<->',
error: 'Unexpected `-` after `<`', error: 'Unexpected `-` after `<`',
}, },
{
query: "a:: a",
elems: [],
foundElems: 0,
original: 'a:: a',
returned: [],
userQuery: 'a:: a',
error: 'Unexpected `:: `',
},
{
query: "a ::a",
elems: [],
foundElems: 0,
original: 'a ::a',
returned: [],
userQuery: 'a ::a',
error: 'Unexpected ` ::`',
},
{ {
query: "a<a>:", query: "a<a>:",
elems: [], elems: [],

View file

@ -15,6 +15,54 @@ const PARSED = [
userQuery: "a::b", userQuery: "a::b",
error: null, error: null,
}, },
{
query: "a:: a",
elems: [{
name: "a:: a",
fullPath: ["a", "a"],
pathWithoutLast: ["a"],
pathLast: "a",
generics: [],
typeFilter: -1,
}],
foundElems: 1,
original: 'a:: a',
returned: [],
userQuery: 'a:: a',
error: null,
},
{
query: "a ::a",
elems: [{
name: "a ::a",
fullPath: ["a", "a"],
pathWithoutLast: ["a"],
pathLast: "a",
generics: [],
typeFilter: -1,
}],
foundElems: 1,
original: 'a ::a',
returned: [],
userQuery: 'a ::a',
error: null,
},
{
query: "a :: a",
elems: [{
name: "a :: a",
fullPath: ["a", "a"],
pathWithoutLast: ["a"],
pathLast: "a",
generics: [],
typeFilter: -1,
}],
foundElems: 1,
original: 'a :: a',
returned: [],
userQuery: 'a :: a',
error: null,
},
{ {
query: 'A::B,C', query: 'A::B,C',
elems: [ elems: [