diff options
author | George Marques <george@gmarqu.es> | 2016-07-03 11:32:30 -0300 |
---|---|---|
committer | George Marques <george@gmarqu.es> | 2016-07-03 11:32:30 -0300 |
commit | 805b668d7f7a5fcddf887e25938f6ee829bd19d8 (patch) | |
tree | 6ac256e55b10d93fd8273fa68d8dd02e14bf251c | |
parent | a28bf56ef9b9d5d93031fb8ce4209370f075f69b (diff) |
Fix code completion sorting
-rw-r--r-- | scene/gui/text_edit.cpp | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/scene/gui/text_edit.cpp b/scene/gui/text_edit.cpp index e106f0dfc6..18552c0776 100644 --- a/scene/gui/text_edit.cpp +++ b/scene/gui/text_edit.cpp @@ -4146,7 +4146,15 @@ void TextEdit::_update_completion_candidates() { continue; } // Calculate the similarity to keep completions in good order - float similarity = s.similarity(completion_strings[i]); + float similarity; + if (completion_strings[i].to_lower().begins_with(s.to_lower())) { + // Substrings are the best candidates + similarity = 1.1; + } else { + // Otherwise compute the similarity + similarity = s.to_lower().similarity(completion_strings[i].to_lower()); + } + int comp_size = completion_options.size(); if (comp_size == 0) { completion_options.push_back(completion_strings[i]); @@ -4156,8 +4164,8 @@ void TextEdit::_update_completion_candidates() { int pos = 0; do { comp_sim = sim_cache[pos++]; - } while(pos < comp_size && similarity <= comp_sim); - pos--; // Pos will be off by one + } while(pos < comp_size && similarity < comp_sim); + pos = similarity > comp_sim ? pos - 1 : pos; // Pos will be off by one completion_options.insert(pos, completion_strings[i]); sim_cache.insert(pos, similarity); } |