]> Pileus Git - ~andy/gtk/blobdiff - gtk/gtkfilechooserutils.c
label: Fix memleak
[~andy/gtk] / gtk / gtkfilechooserutils.c
index 91275db9b2f8f4b59902531811735945b88bab71..43148aa9c34654a9f33749f6b70978e18d213d51 100644 (file)
  * Lesser General Public License for more details.
  *
  * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
  */
 
-#include <config.h>
+#include "config.h"
 #include "gtkfilechooserutils.h"
 #include "gtkfilechooser.h"
 #include "gtkfilesystem.h"
 #include "gtktypebuiltins.h"
-#include "gtkalias.h"
+#include "gtkintl.h"
+
 
 static gboolean       delegate_set_current_folder     (GtkFileChooser    *chooser,
-                                                      const GtkFilePath *path,
+                                                      GFile             *file,
                                                       GError           **error);
-static GtkFilePath *  delegate_get_current_folder     (GtkFileChooser    *chooser);
+static GFile *        delegate_get_current_folder     (GtkFileChooser    *chooser);
 static void           delegate_set_current_name       (GtkFileChooser    *chooser,
                                                       const gchar       *name);
-static gboolean       delegate_select_path            (GtkFileChooser    *chooser,
-                                                      const GtkFilePath *path,
+static gboolean       delegate_select_file            (GtkFileChooser    *chooser,
+                                                      GFile             *file,
                                                       GError           **error);
-static void           delegate_unselect_path          (GtkFileChooser    *chooser,
-                                                      const GtkFilePath *path);
+static void           delegate_unselect_file          (GtkFileChooser    *chooser,
+                                                      GFile             *file);
 static void           delegate_select_all             (GtkFileChooser    *chooser);
 static void           delegate_unselect_all           (GtkFileChooser    *chooser);
-static GSList *       delegate_get_paths              (GtkFileChooser    *chooser);
-static GtkFilePath *  delegate_get_preview_path       (GtkFileChooser    *chooser);
+static GSList *       delegate_get_files              (GtkFileChooser    *chooser);
+static GFile *        delegate_get_preview_file       (GtkFileChooser    *chooser);
 static GtkFileSystem *delegate_get_file_system        (GtkFileChooser    *chooser);
 static void           delegate_add_filter             (GtkFileChooser    *chooser,
                                                       GtkFileFilter     *filter);
@@ -48,10 +47,10 @@ static void           delegate_remove_filter          (GtkFileChooser    *choose
                                                       GtkFileFilter     *filter);
 static GSList *       delegate_list_filters           (GtkFileChooser    *chooser);
 static gboolean       delegate_add_shortcut_folder    (GtkFileChooser    *chooser,
-                                                      const GtkFilePath *path,
+                                                      GFile             *file,
                                                       GError           **error);
 static gboolean       delegate_remove_shortcut_folder (GtkFileChooser    *chooser,
-                                                      const GtkFilePath *path,
+                                                      GFile             *file,
                                                       GError           **error);
 static GSList *       delegate_list_shortcut_folders  (GtkFileChooser    *chooser);
 static void           delegate_notify                 (GObject           *object,
@@ -66,6 +65,9 @@ static void           delegate_update_preview         (GtkFileChooser    *choose
 static void           delegate_file_activated         (GtkFileChooser    *chooser,
                                                       gpointer           data);
 
+static GtkFileChooserConfirmation delegate_confirm_overwrite (GtkFileChooser    *chooser,
+                                                             gpointer           data);
+
 /**
  * _gtk_file_chooser_install_properties:
  * @klass: the class structure for a type deriving from #GObject
@@ -86,9 +88,6 @@ _gtk_file_chooser_install_properties (GObjectClass *klass)
   g_object_class_override_property (klass,
                                    GTK_FILE_CHOOSER_PROP_EXTRA_WIDGET,
                                    "extra-widget");
-  g_object_class_override_property (klass,
-                                   GTK_FILE_CHOOSER_PROP_FILE_SYSTEM_BACKEND,
-                                   "file-system-backend");
   g_object_class_override_property (klass,
                                    GTK_FILE_CHOOSER_PROP_FILTER,
                                    "filter");
@@ -110,6 +109,12 @@ _gtk_file_chooser_install_properties (GObjectClass *klass)
   g_object_class_override_property (klass,
                                    GTK_FILE_CHOOSER_PROP_SHOW_HIDDEN,
                                    "show-hidden");
+  g_object_class_override_property (klass,
+                                   GTK_FILE_CHOOSER_PROP_DO_OVERWRITE_CONFIRMATION,
+                                   "do-overwrite-confirmation");
+  g_object_class_override_property (klass,
+                                   GTK_FILE_CHOOSER_PROP_CREATE_FOLDERS,
+                                   "create-folders");
 }
 
 /**
@@ -129,12 +134,12 @@ _gtk_file_chooser_delegate_iface_init (GtkFileChooserIface *iface)
   iface->set_current_folder = delegate_set_current_folder;
   iface->get_current_folder = delegate_get_current_folder;
   iface->set_current_name = delegate_set_current_name;
-  iface->select_path = delegate_select_path;
-  iface->unselect_path = delegate_unselect_path;
+  iface->select_file = delegate_select_file;
+  iface->unselect_file = delegate_unselect_file;
   iface->select_all = delegate_select_all;
   iface->unselect_all = delegate_unselect_all;
-  iface->get_paths = delegate_get_paths;
-  iface->get_preview_path = delegate_get_preview_path;
+  iface->get_files = delegate_get_files;
+  iface->get_preview_file = delegate_get_preview_file;
   iface->get_file_system = delegate_get_file_system;
   iface->add_filter = delegate_add_filter;
   iface->remove_filter = delegate_remove_filter;
@@ -162,7 +167,7 @@ _gtk_file_chooser_set_delegate (GtkFileChooser *receiver,
   g_return_if_fail (GTK_IS_FILE_CHOOSER (receiver));
   g_return_if_fail (GTK_IS_FILE_CHOOSER (delegate));
 
-  g_object_set_data (G_OBJECT (receiver), "gtk-file-chooser-delegate", delegate);
+  g_object_set_data (G_OBJECT (receiver), I_("gtk-file-chooser-delegate"), delegate);
   g_signal_connect (delegate, "notify",
                    G_CALLBACK (delegate_notify), receiver);
   g_signal_connect (delegate, "current-folder-changed",
@@ -173,6 +178,8 @@ _gtk_file_chooser_set_delegate (GtkFileChooser *receiver,
                    G_CALLBACK (delegate_update_preview), receiver);
   g_signal_connect (delegate, "file-activated",
                    G_CALLBACK (delegate_file_activated), receiver);
+  g_signal_connect (delegate, "confirm-overwrite",
+                   G_CALLBACK (delegate_confirm_overwrite), receiver);
 }
 
 GQuark
@@ -194,18 +201,18 @@ get_delegate (GtkFileChooser *receiver)
 }
 
 static gboolean
-delegate_select_path (GtkFileChooser    *chooser,
-                     const GtkFilePath *path,
+delegate_select_file (GtkFileChooser    *chooser,
+                     GFile             *file,
                      GError           **error)
 {
-  return _gtk_file_chooser_select_path (get_delegate (chooser), path, error);
+  return gtk_file_chooser_select_file (get_delegate (chooser), file, error);
 }
 
 static void
-delegate_unselect_path (GtkFileChooser    *chooser,
-                       const GtkFilePath *path)
+delegate_unselect_file (GtkFileChooser *chooser,
+                       GFile          *file)
 {
-  _gtk_file_chooser_unselect_path (get_delegate (chooser), path);
+  gtk_file_chooser_unselect_file (get_delegate (chooser), file);
 }
 
 static void
@@ -221,15 +228,15 @@ delegate_unselect_all (GtkFileChooser *chooser)
 }
 
 static GSList *
-delegate_get_paths (GtkFileChooser *chooser)
+delegate_get_files (GtkFileChooser *chooser)
 {
-  return _gtk_file_chooser_get_paths (get_delegate (chooser));
+  return gtk_file_chooser_get_files (get_delegate (chooser));
 }
 
-static GtkFilePath *
-delegate_get_preview_path (GtkFileChooser *chooser)
+static GFile *
+delegate_get_preview_file (GtkFileChooser *chooser)
 {
-  return _gtk_file_chooser_get_preview_path (get_delegate (chooser));
+  return gtk_file_chooser_get_preview_file (get_delegate (chooser));
 }
 
 static GtkFileSystem *
@@ -259,39 +266,39 @@ delegate_list_filters (GtkFileChooser *chooser)
 }
 
 static gboolean
-delegate_add_shortcut_folder (GtkFileChooser    *chooser,
-                             const GtkFilePath *path,
-                             GError           **error)
+delegate_add_shortcut_folder (GtkFileChooser  *chooser,
+                             GFile           *file,
+                             GError         **error)
 {
-  return _gtk_file_chooser_add_shortcut_folder (get_delegate (chooser), path, error);
+  return _gtk_file_chooser_add_shortcut_folder (get_delegate (chooser), file, error);
 }
 
 static gboolean
-delegate_remove_shortcut_folder (GtkFileChooser    *chooser,
-                                const GtkFilePath *path,
-                                GError           **error)
+delegate_remove_shortcut_folder (GtkFileChooser  *chooser,
+                                GFile           *file,
+                                GError         **error)
 {
-  return _gtk_file_chooser_remove_shortcut_folder (get_delegate (chooser), path, error);
+  return _gtk_file_chooser_remove_shortcut_folder (get_delegate (chooser), file, error);
 }
 
 static GSList *
 delegate_list_shortcut_folders (GtkFileChooser *chooser)
 {
-  return gtk_file_chooser_list_shortcut_folders (get_delegate (chooser));
+  return _gtk_file_chooser_list_shortcut_folder_files (get_delegate (chooser));
 }
 
 static gboolean
-delegate_set_current_folder (GtkFileChooser    *chooser,
-                            const GtkFilePath *path,
-                            GError           **error)
+delegate_set_current_folder (GtkFileChooser  *chooser,
+                            GFile           *file,
+                            GError         **error)
 {
-  return _gtk_file_chooser_set_current_folder_path (get_delegate (chooser), path, error);
+  return gtk_file_chooser_set_current_folder_file (get_delegate (chooser), file, error);
 }
 
-static GtkFilePath *
+static GFile *
 delegate_get_current_folder (GtkFileChooser *chooser)
 {
-  return _gtk_file_chooser_get_current_folder_path (get_delegate (chooser));
+  return gtk_file_chooser_get_current_folder_file (get_delegate (chooser));
 }
 
 static void
@@ -342,5 +349,95 @@ delegate_file_activated (GtkFileChooser    *chooser,
   g_signal_emit_by_name (data, "file-activated");
 }
 
-#define __GTK_FILE_CHOOSER_UTILS_C__
-#include "gtkaliasdef.c"
+static GtkFileChooserConfirmation
+delegate_confirm_overwrite (GtkFileChooser    *chooser,
+                           gpointer           data)
+{
+  GtkFileChooserConfirmation conf;
+
+  g_signal_emit_by_name (data, "confirm-overwrite", &conf);
+  return conf;
+}
+
+static GFile *
+get_parent_for_uri (const char *uri)
+{
+  GFile *file;
+  GFile *parent;
+
+  file = g_file_new_for_uri (uri);
+  parent = g_file_get_parent (file);
+
+  g_object_unref (file);
+  return parent;
+       
+}
+
+/* Extracts the parent folders out of the supplied list of GtkRecentInfo* items, and returns
+ * a list of GFile* for those unique parents.
+ */
+GList *
+_gtk_file_chooser_extract_recent_folders (GList *infos)
+{
+  GList *l;
+  GList *result;
+  GHashTable *folders;
+
+  result = NULL;
+
+  folders = g_hash_table_new (g_file_hash, (GEqualFunc) g_file_equal);
+
+  for (l = infos; l; l = l->next)
+    {
+      GtkRecentInfo *info = l->data;
+      const char *uri;
+      GFile *parent;
+
+      uri = gtk_recent_info_get_uri (info);
+      parent = get_parent_for_uri (uri);
+
+      if (parent)
+       {
+         if (!g_hash_table_lookup (folders, parent))
+           {
+             g_hash_table_insert (folders, parent, (gpointer) 1);
+             result = g_list_prepend (result, g_object_ref (parent));
+           }
+
+         g_object_unref (parent);
+       }
+    }
+
+  result = g_list_reverse (result);
+
+  g_hash_table_destroy (folders);
+
+  return result;
+}
+
+GSettings *
+_gtk_file_chooser_get_settings_for_widget (GtkWidget *widget)
+{
+  static GQuark file_chooser_settings_quark = 0;
+  GtkSettings *gtksettings;
+  GSettings *settings;
+
+  if (G_UNLIKELY (file_chooser_settings_quark == 0))
+    file_chooser_settings_quark = g_quark_from_static_string ("-gtk-file-chooser-settings");
+
+  gtksettings = gtk_widget_get_settings (widget);
+  settings = g_object_get_qdata (G_OBJECT (gtksettings), file_chooser_settings_quark);
+
+  if (G_UNLIKELY (settings == NULL))
+    {
+      settings = g_settings_new ("org.gtk.Settings.FileChooser");
+      g_settings_delay (settings);
+
+      g_object_set_qdata_full (G_OBJECT (gtksettings),
+                               file_chooser_settings_quark,
+                               settings,
+                               g_object_unref);
+    }
+
+  return settings;
+}