aboutsummaryrefslogtreecommitdiff
path: root/main
diff options
context:
space:
mode:
authorMarvin W <git@larma.de>2025-01-02 15:58:12 +0100
committerMarvin W <git@larma.de>2025-01-03 17:44:43 +0100
commitd5c280476902d72627c863177a6adcbef4f94f3e (patch)
treef980a40aed1b338561d6d56815f9ef2a36780e11 /main
parent398c52e1b9a5c91cd99277463080819ebdedfe1d (diff)
downloaddino-d5c280476902d72627c863177a6adcbef4f94f3e.tar.gz
dino-d5c280476902d72627c863177a6adcbef4f94f3e.zip
Search: Build preview string based on chars not bytes
Diffstat (limited to 'main')
-rw-r--r--main/src/ui/global_search.vala13
1 files changed, 7 insertions, 6 deletions
diff --git a/main/src/ui/global_search.vala b/main/src/ui/global_search.vala
index a63aaed1..51e04af2 100644
--- a/main/src/ui/global_search.vala
+++ b/main/src/ui/global_search.vala
@@ -224,14 +224,15 @@ public class GlobalSearch {
grid.margin_bottom = 3;
string text = Util.unbreak_space_around_non_spacing_mark(item.message.body.replace("\n", "").replace("\r", ""));
- if (text.length > 200) {
+ if (text.char_count() > 200) {
int index = text.index_of(search);
- if (index + search.length <= 100) {
- text = text.substring(0, 150) + " … " + text.substring(text.length - 50, 50);
- } else if (index >= text.length - 100) {
- text = text.substring(0, 50) + " … " + text.substring(text.length - 150, 150);
+ int char_index = index < 0 ? 0 : text.char_count(index);
+ if (char_index + search.char_count() <= 100) {
+ text = text.substring(0, text.index_of_nth_char(150)) + " … " + text.substring(text.index_of_nth_char(text.char_count() - 50));
+ } else if (char_index >= text.char_count() - 100) {
+ text = text.substring(0, text.index_of_nth_char(50)) + " … " + text.substring(text.index_of_nth_char(text.char_count() - 150));
} else {
- text = text.substring(0, 25) + " … " + text.substring(index - 50, 50) + text.substring(index, 100) + " … " + text.substring(text.length - 25, 25);
+ text = text.substring(0, text.index_of_nth_char(25)) + " … " + text.substring(text.index_of_nth_char(char_index - 50), text.index_of_nth_char(char_index + 100)) + " … " + text.substring(text.index_of_nth_char(text.char_count() - 25));
}
}
Label label = new Label("") { use_markup=true, xalign=0, selectable=true, wrap=true, wrap_mode=Pango.WrapMode.WORD_CHAR, vexpand=true };