diff options
| author | George Marques | 2016-07-03 11:32:30 -0300 |
|---|---|---|
| committer | George Marques | 2016-07-03 11:32:30 -0300 |
| commit | 805b668d7f7a5fcddf887e25938f6ee829bd19d8 (patch) | |
| tree | 6ac256e55b10d93fd8273fa68d8dd02e14bf251c /scene/gui/text_edit.cpp | |
| parent | a28bf56ef9b9d5d93031fb8ce4209370f075f69b (diff) | |
| download | godot-805b668d7f7a5fcddf887e25938f6ee829bd19d8.tar.gz godot-805b668d7f7a5fcddf887e25938f6ee829bd19d8.tar.zst godot-805b668d7f7a5fcddf887e25938f6ee829bd19d8.zip | |
Fix code completion sorting
Diffstat (limited to 'scene/gui/text_edit.cpp')
| -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 e106f0dfc..18552c077 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); } |
