diff options
author | Benjamin Barenblat <bbaren@debian.org> | 2018-11-23 12:03:22 -0500 |
---|---|---|
committer | Benjamin Barenblat <bbaren@debian.org> | 2018-11-23 12:03:22 -0500 |
commit | ee2bf4d3011cc0aabf637566d17660db5c9b80dd (patch) | |
tree | e0e7e290b250d42b11bd41b484c3e9c5a37118f8 /src/trg-files-tree-view.c | |
parent | 1fc0912aa79da8e1c29f45af0d851834fcf91846 (diff) | |
parent | cc02e478dd5fb15c1a59db3b9cce35a336cef4ba (diff) |
Merge branch 'upstream'
Diffstat (limited to 'src/trg-files-tree-view.c')
-rw-r--r-- | src/trg-files-tree-view.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/src/trg-files-tree-view.c b/src/trg-files-tree-view.c index 70147f7..afe6073 100644 --- a/src/trg-files-tree-view.c +++ b/src/trg-files-tree-view.c @@ -180,6 +180,24 @@ view_onButtonPressed(GtkWidget * treeview, return handled; } +static gboolean +search_func (GtkTreeModel *model, gint column, + const gchar *key, GtkTreeIter *iter, + gpointer search_data) +{ + gchar *iter_string = NULL; + gchar *lowercase = NULL; + gboolean result = TRUE; + gtk_tree_model_get(model, iter, column, &iter_string, -1); + if (iter_string != NULL) { + lowercase = g_utf8_strdown(iter_string, -1); + result = g_strrstr(lowercase, key) == NULL; + } + g_free(lowercase); + g_free(iter_string); + return result; +} + static void trg_files_tree_view_init(TrgFilesTreeView * self) { TrgTreeView *ttv = TRG_TREE_VIEW(self); @@ -200,6 +218,11 @@ static void trg_files_tree_view_init(TrgFilesTreeView * self) gtk_tree_view_set_search_column(GTK_TREE_VIEW(self), FILESCOL_NAME); + gtk_tree_view_set_search_equal_func(GTK_TREE_VIEW(self), + (GtkTreeViewSearchEqualFunc) search_func, + gtk_tree_view_get_model(GTK_TREE_VIEW(self)), + NULL); + g_signal_connect(self, "button-press-event", G_CALLBACK(view_onButtonPressed), NULL); g_signal_connect(self, "popup-menu", |