summaryrefslogtreecommitdiff
path: root/src/trg-files-tree-view.c
diff options
context:
space:
mode:
authorGravatar Benjamin Barenblat <bbaren@debian.org>2018-11-23 12:03:22 -0500
committerGravatar Benjamin Barenblat <bbaren@debian.org>2018-11-23 12:03:22 -0500
commitee2bf4d3011cc0aabf637566d17660db5c9b80dd (patch)
treee0e7e290b250d42b11bd41b484c3e9c5a37118f8 /src/trg-files-tree-view.c
parent1fc0912aa79da8e1c29f45af0d851834fcf91846 (diff)
parentcc02e478dd5fb15c1a59db3b9cce35a336cef4ba (diff)
Merge branch 'upstream'
Diffstat (limited to 'src/trg-files-tree-view.c')
-rw-r--r--src/trg-files-tree-view.c23
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",