Browse Source
This makes the other pages take less priority than the API results. It's kind of biased, but hopefully it helps out.pull/2255/head
2 changed files with 79 additions and 1 deletions
@ -0,0 +1,78 @@ |
|||||
|
var _queryBeingDone = null; |
||||
|
var _pattern = null; |
||||
|
var _escapedRegex = /[-\/\\^$*+?.()|[\]{}]/g; |
||||
|
function escapeRegex(e) { |
||||
|
return e.replace(_escapedRegex, '\\$&'); |
||||
|
} |
||||
|
|
||||
|
// for some reason Sphinx shows some entries twice
|
||||
|
// if something has been scored already I'd rather sort it to the bottom
|
||||
|
var _beenScored = new Set(); |
||||
|
|
||||
|
function __score(haystack, regex) { |
||||
|
let match = regex.exec(haystack); |
||||
|
if(match == null) { |
||||
|
return Number.MAX_VALUE; |
||||
|
} |
||||
|
let subLength = match[0].length; |
||||
|
let start = match.index; |
||||
|
return (subLength * 1000 + start) / 1000.0; |
||||
|
} |
||||
|
|
||||
|
// unused for now
|
||||
|
function __cleanNamespaces(query) { |
||||
|
return query.replace(/(discord\.(ext\.)?)?(.+)/, '$3'); |
||||
|
} |
||||
|
|
||||
|
var Scorer = { |
||||
|
// Implement the following function to further tweak the score for each result
|
||||
|
// The function takes a result array [filename, title, anchor, descr, score]
|
||||
|
// and returns the new score.
|
||||
|
|
||||
|
score: function(result) { |
||||
|
// only inflate the score of things that are actual API reference things
|
||||
|
if(_pattern !== null && result[1].startsWith('discord.')) { |
||||
|
let _score = __score(result[1], _pattern); |
||||
|
if(_score === Number.MAX_VALUE) { |
||||
|
return result[4]; |
||||
|
} |
||||
|
if(_beenScored.has(result[1])) { |
||||
|
return 0; |
||||
|
} |
||||
|
_beenScored.add(result[1]); |
||||
|
let newScore = 100 + _queryBeingDone.length - _score; |
||||
|
// console.log(`${result[1]}: ${result[4]} -> ${newScore} (${_score})`);
|
||||
|
return newScore; |
||||
|
} |
||||
|
return result[4]; |
||||
|
}, |
||||
|
|
||||
|
|
||||
|
// query matches the full name of an object
|
||||
|
objNameMatch: 15, |
||||
|
// or matches in the last dotted part of the object name
|
||||
|
objPartialMatch: 11, |
||||
|
// Additive scores depending on the priority of the object
|
||||
|
objPrio: {0: 15, // used to be importantResults
|
||||
|
1: 7, // used to be objectResults
|
||||
|
2: -5}, // used to be unimportantResults
|
||||
|
// Used when the priority is not in the mapping.
|
||||
|
objPrioDefault: 0, |
||||
|
|
||||
|
// query found in title
|
||||
|
title: 15, |
||||
|
partialTitle: 7, |
||||
|
// query found in terms
|
||||
|
term: 5, |
||||
|
partialTerm: 2 |
||||
|
}; |
||||
|
|
||||
|
|
||||
|
$(document).ready(function() { |
||||
|
let params = $.getQueryParameters(); |
||||
|
if(params.q) { |
||||
|
_queryBeingDone = params.q[0]; |
||||
|
let pattern = Array.from(_queryBeingDone).map(escapeRegex).join('.*?'); |
||||
|
_pattern = new RegExp(pattern, 'i'); |
||||
|
} |
||||
|
}); |
Loading…
Reference in new issue