Skip to content

Commit

Permalink
registry: Prioritize exact matches over fuzzy
Browse files Browse the repository at this point in the history
  • Loading branch information
jkozera committed Feb 26, 2017
1 parent 89b9d91 commit 02f2fad
Showing 1 changed file with 30 additions and 15 deletions.
45 changes: 30 additions & 15 deletions src/libs/registry/docset.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -750,13 +750,8 @@ static int scoreFuzzy(const char *str, int index, int length)
}
}

static void sqliteScoreFunction(sqlite3_context *context, int argc, sqlite3_value **argv)
static inline int scoreFunction(const char* needleOrig, const char* haystackOrig)
{
Q_UNUSED(argc);

const char *needleOrig = reinterpret_cast<const char *>(sqlite3_value_text(argv[0]));
const char *haystackOrig = reinterpret_cast<const char *>(sqlite3_value_text(argv[1]));

const int needleLength = static_cast<int>(qstrlen(needleOrig));
const int haystackLength = static_cast<int>(qstrlen(haystackOrig));

Expand Down Expand Up @@ -790,18 +785,25 @@ static void sqliteScoreFunction(sqlite3_context *context, int argc, sqlite3_valu
int score = 0;
int matchIndex = -1;
int matchLength;
int exactIndex = -1;
const char* exactMatch = strstr(haystack.data(), needle.data());

matchFuzzy(needle.data(), needleLength,
haystack.data(), haystackLength,
&matchIndex, &matchLength);
if (exactMatch != nullptr) {
exactIndex = exactMatch - haystack.data();
}

if (exactIndex == -1) {
matchFuzzy(needle.data(), needleLength,
haystack.data(), haystackLength,
&matchIndex, &matchLength);
}

if (matchIndex == -1) { // no match
if (matchIndex == -1 && exactIndex == -1) { // no match
// simply return 0
sqlite3_result_int(context, 0);
return;
} else if (needleLength == matchLength) {
return 0;
} else if (exactIndex != -1) {
// +100 to make sure exact matches are always on top.
score = scoreExact(matchIndex, matchLength, haystack.data(), haystackLength) + 100;
score = scoreExact(exactIndex, haystackLength, haystack.data(), haystackLength) + 100;
} else {
score = scoreFuzzy(haystack.data(), matchIndex, matchLength);

Expand All @@ -824,5 +826,18 @@ static void sqliteScoreFunction(sqlite3_context *context, int argc, sqlite3_valu
}
}

sqlite3_result_int(context, score);
return score;
}

static void sqliteScoreFunction(sqlite3_context *context, int argc, sqlite3_value **argv)
{
Q_UNUSED(argc);

sqlite3_result_int(
context,
scoreFunction(
reinterpret_cast<const char *>(sqlite3_value_text(argv[0])),
reinterpret_cast<const char *>(sqlite3_value_text(argv[1]))
)
);
}

0 comments on commit 02f2fad

Please sign in to comment.