mirror of
https://github.com/freeCodeCamp/devdocs
synced 2024-11-16 19:48:10 +01:00
Improve search fuzzy matching
This commit is contained in:
parent
cca1b37ce0
commit
a677417665
1 changed files with 18 additions and 5 deletions
|
@ -13,6 +13,8 @@ fuzzyRegexp = # query fuzzy regexp
|
||||||
index = # position of the query in the string being matched
|
index = # position of the query in the string being matched
|
||||||
lastIndex = # last position of the query in the string being matched
|
lastIndex = # last position of the query in the string being matched
|
||||||
match = # regexp match data
|
match = # regexp match data
|
||||||
|
matchIndex =
|
||||||
|
matchLength =
|
||||||
score = # score for the current match
|
score = # score for the current match
|
||||||
separators = # counter
|
separators = # counter
|
||||||
i = null # cursor
|
i = null # cursor
|
||||||
|
@ -74,16 +76,27 @@ return Math.max 1, score
|
||||||
`function fuzzyMatch() {`
|
`function fuzzyMatch() {`
|
||||||
return if valueLength <= queryLength or value.indexOf(query) >= 0
|
return if valueLength <= queryLength or value.indexOf(query) >= 0
|
||||||
return unless match = fuzzyRegexp.exec(value)
|
return unless match = fuzzyRegexp.exec(value)
|
||||||
|
matchIndex = match.index
|
||||||
|
matchLength = match[0].length
|
||||||
|
score = scoreFuzzyMatch()
|
||||||
|
if match = fuzzyRegexp.exec(value.slice(i = value.lastIndexOf(SEPARATOR) + 1))
|
||||||
|
matchIndex = i + match.index
|
||||||
|
matchLength = match[0].length
|
||||||
|
return Math.max(score, scoreFuzzyMatch())
|
||||||
|
else
|
||||||
|
return score
|
||||||
|
`}`
|
||||||
|
|
||||||
|
`function scoreFuzzyMatch() {`
|
||||||
# When the match is at the beginning of the string or preceded by a dot.
|
# When the match is at the beginning of the string or preceded by a dot.
|
||||||
if match.index is 0 or value.charAt(match.index - 1) is SEPARATOR
|
if matchIndex is 0 or value.charAt(matchIndex - 1) is SEPARATOR
|
||||||
return Math.max 66, 100 - match[0].length
|
return Math.max 66, 100 - matchLength
|
||||||
# When the match is at the end of the string.
|
# When the match is at the end of the string.
|
||||||
else if match.index + match[0].length is valueLength
|
else if matchIndex + matchLength is valueLength
|
||||||
return Math.max 33, 67 - match[0].length
|
return Math.max 33, 67 - matchLength
|
||||||
# When the match is in the middle of the string.
|
# When the match is in the middle of the string.
|
||||||
else
|
else
|
||||||
return Math.max 1, 34 - match[0].length
|
return Math.max 1, 34 - matchLength
|
||||||
`}`
|
`}`
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
Loading…
Reference in a new issue