do_search (gpointer data)
{
GtkSearchEngineModel *model = data;
- GtkTreeIter iter;
GList *hits = NULL;
gboolean got_results = FALSE;
- if (gtk_tree_model_get_iter_first (GTK_TREE_MODEL (model->model), &iter))
+ for (guint i = 0; i < g_list_model_get_n_items (G_LIST_MODEL (model->model)); i++)
{
- do
- {
- GFileInfo *info;
-
- info = _gtk_file_system_model_get_info (model->model, &iter);
- if (info_matches_query (model->query, info))
- {
- GFile *file;
- GtkSearchHit *hit;
-
- file = _gtk_file_system_model_get_file (model->model, &iter);
- hit = g_new (GtkSearchHit, 1);
- hit->file = g_object_ref (file);
- hit->info = g_object_ref (info);
- hits = g_list_prepend (hits, hit);
- }
- }
- while (gtk_tree_model_iter_next (GTK_TREE_MODEL (model->model), &iter));
+ GtkFileSystemItem *item;
+ GFileInfo *info;
- if (hits)
+ item = g_list_model_get_item (G_LIST_MODEL (model->model), i);
+ info = _gtk_file_system_item_get_file_info (item);
+
+ if (info_matches_query (model->query, info))
{
- _gtk_search_engine_hits_added (GTK_SEARCH_ENGINE (model), hits);
- g_list_free_full (hits, (GDestroyNotify)_gtk_search_hit_free);
- got_results = TRUE;
+ GFile *file;
+ GtkSearchHit *hit;
+
+ file = _gtk_file_system_item_get_file (item);
+ hit = g_new (GtkSearchHit, 1);
+ hit->file = g_object_ref (file);
+ hit->info = g_object_ref (info);
+ hits = g_list_prepend (hits, hit);
}
+
+ g_clear_object (&item);
+ }
+
+ if (hits)
+ {
+ _gtk_search_engine_hits_added (GTK_SEARCH_ENGINE (model), hits);
+ g_list_free_full (hits, (GDestroyNotify)_gtk_search_hit_free);
+ got_results = TRUE;
}
model->idle = 0;