Refactor: move view_file implementations to their own subdirectory.
[geeqie.git] / src / view_file.c
index 3f424ca..d537e8a 100644 (file)
@@ -21,6 +21,7 @@
 #include "main.h"
 #include "view_file.h"
 
+#include "dupe.h"
 #include "collect.h"
 #include "collect-table.h"
 #include "editors.h"
@@ -30,8 +31,8 @@
 #include "ui_menu.h"
 #include "ui_fileops.h"
 #include "utilops.h"
-#include "view_file_list.h"
-#include "view_file_icon.h"
+#include "view_file/view_file_list.h"
+#include "view_file/view_file_icon.h"
 
 /*
  *-----------------------------------------------------------------------------
@@ -403,6 +404,24 @@ static void vf_pop_menu_enable_grouping_cb(GtkWidget *widget, gpointer data)
        file_data_disable_grouping_list(vf_pop_menu_file_list(vf), FALSE);
 }
 
+static void vf_pop_menu_duplicates_cb(GtkWidget *widget, gpointer data)
+{
+       ViewFile *vf = data;
+       DupeWindow *dw;
+
+       dw = dupe_window_new();
+       dupe_window_add_files(dw, vf_pop_menu_file_list(vf), FALSE);
+}
+
+static void vf_pop_menu_add_collection_cb(GtkWidget *widget, gpointer data)
+{
+       ViewFile *vf = data;
+       CollectWindow *w;
+
+       w = collection_window_new(NULL);
+       collection_table_add_filelist(w->table, vf_pop_menu_file_list(vf));
+}
+
 static void vf_pop_menu_disable_grouping_cb(GtkWidget *widget, gpointer data)
 {
        ViewFile *vf = data;
@@ -617,6 +636,12 @@ GtkWidget *vf_pop_menu(ViewFile *vf)
                                G_CALLBACK(vf_pop_menu_disable_grouping_cb), vf);
 
        menu_item_add_divider(menu);
+       menu_item_add_stock_sensitive(menu, _("_Find duplicates..."), GTK_STOCK_FIND, active,
+                               G_CALLBACK(vf_pop_menu_duplicates_cb), vf);
+       menu_item_add_divider(menu);
+       menu_item_add_stock_sensitive(menu, _("Add to new collection"), GTK_STOCK_INDEX, active,
+                               G_CALLBACK(vf_pop_menu_add_collection_cb), vf);
+       menu_item_add_divider(menu);
 
        submenu = submenu_add_sort(NULL, G_CALLBACK(vf_pop_menu_sort_cb), vf,
                                   FALSE, FALSE, TRUE, vf->sort_method);
@@ -1058,7 +1083,7 @@ void vf_notify_cb(FileData *fd, NotifyType type, gpointer data)
        if (!refresh)
                {
                gchar *base = remove_level_from_path(fd->path);
-               refresh = (strcmp(base, vf->dir_fd->path) == 0);
+               refresh = (g_strcmp0(base, vf->dir_fd->path) == 0);
                g_free(base);
                }
 
@@ -1067,14 +1092,14 @@ void vf_notify_cb(FileData *fd, NotifyType type, gpointer data)
                if (!refresh && fd->change->dest)
                        {
                        gchar *dest_base = remove_level_from_path(fd->change->dest);
-                       refresh = (strcmp(dest_base, vf->dir_fd->path) == 0);
+                       refresh = (g_strcmp0(dest_base, vf->dir_fd->path) == 0);
                        g_free(dest_base);
                        }
 
                if (!refresh && fd->change->source)
                        {
                        gchar *source_base = remove_level_from_path(fd->change->source);
-                       refresh = (strcmp(source_base, vf->dir_fd->path) == 0);
+                       refresh = (g_strcmp0(source_base, vf->dir_fd->path) == 0);
                        g_free(source_base);
                        }
                }