[gnome-photos/wip/rishi/collection: 11/27] source: Support GMount-backed sources for importing



commit dc67a1c648d98b435452f75abfa165a2fd77c4c8
Author: Debarshi Ray <debarshir gnome org>
Date:   Sun Sep 3 12:13:14 2017 +0200

    source: Support GMount-backed sources for importing
    
    https://bugzilla.gnome.org/show_bug.cgi?id=751212

 src/photos-source.c | 49 +++++++++++++++++++++++++++++++++++++++++++++++++
 src/photos-source.h |  6 +++++-
 2 files changed, 54 insertions(+), 1 deletion(-)
---
diff --git a/src/photos-source.c b/src/photos-source.c
index fd75f1a6..40beeddb 100644
--- a/src/photos-source.c
+++ b/src/photos-source.c
@@ -36,6 +36,7 @@ struct _PhotosSource
   GObject parent_instance;
   GIcon *icon;
   GIcon *symbolic_icon;
+  GMount *mount;
   GoaObject *object;
   gboolean builtin;
   gchar *id;
@@ -47,6 +48,7 @@ enum
   PROP_0,
   PROP_BUILTIN,
   PROP_ID,
+  PROP_MOUNT,
   PROP_NAME,
   PROP_OBJECT
 };
@@ -110,6 +112,7 @@ photos_source_dispose (GObject *object)
   PhotosSource *self = PHOTOS_SOURCE (object);
 
   g_clear_object (&self->icon);
+  g_clear_object (&self->mount);
   g_clear_object (&self->object);
   g_clear_object (&self->symbolic_icon);
 
@@ -146,6 +149,10 @@ photos_source_get_property (GObject *object, guint prop_id, GValue *value, GPara
       g_value_set_string (value, self->id);
       break;
 
+    case PROP_MOUNT:
+      g_value_set_object (value, self->mount);
+      break;
+
     case PROP_NAME:
       g_value_set_string (value, self->name);
       break;
@@ -185,6 +192,25 @@ photos_source_set_property (GObject *object, guint prop_id, const GValue *value,
         break;
       }
 
+    case PROP_MOUNT:
+      {
+        g_autoptr (GFile) root = NULL;
+        g_autofree gchar *uri = NULL;
+
+        self->mount = G_MOUNT (g_value_dup_object (value));
+        if (self->mount == NULL)
+          break;
+
+        root = g_mount_get_root (self->mount);
+        uri = g_file_get_uri (root);
+        self->id = g_strdup_printf ("gd:g-mount:%s", uri);
+
+        self->icon = g_mount_get_icon (self->mount);
+        self->symbolic_icon = g_mount_get_symbolic_icon (self->mount);
+        self->name = g_mount_get_name (self->mount);
+        break;
+      }
+
     case PROP_NAME:
       {
         const gchar *name;
@@ -262,6 +288,14 @@ photos_source_class_init (PhotosSourceClass *class)
                                                         NULL,
                                                         G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE));
 
+  g_object_class_install_property (object_class,
+                                   PROP_MOUNT,
+                                   g_param_spec_object ("mount",
+                                                        "GMount instance",
+                                                        "A mount point representing a removable device (eg., 
camera)",
+                                                        G_TYPE_MOUNT,
+                                                        G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE));
+
   g_object_class_install_property (object_class,
                                    PROP_NAME,
                                    g_param_spec_string ("name",
@@ -304,6 +338,14 @@ photos_source_new_from_goa_object (GoaObject *object)
 }
 
 
+PhotosSource *
+photos_source_new_from_mount (GMount *mount)
+{
+  g_return_val_if_fail (G_IS_MOUNT (mount), NULL);
+  return g_object_new (PHOTOS_TYPE_SOURCE, "mount", mount, NULL);
+}
+
+
 const gchar *
 photos_source_get_name (PhotosSource *self)
 {
@@ -325,6 +367,13 @@ photos_source_get_icon (PhotosSource *self)
 }
 
 
+GMount *
+photos_source_get_mount (PhotosSource *self)
+{
+  return self->mount;
+}
+
+
 GIcon *
 photos_source_get_symbolic_icon (PhotosSource *self)
 {
diff --git a/src/photos-source.h b/src/photos-source.h
index 1067137a..b0d0dd15 100644
--- a/src/photos-source.h
+++ b/src/photos-source.h
@@ -23,7 +23,7 @@
 #ifndef PHOTOS_SOURCE_H
 #define PHOTOS_SOURCE_H
 
-#include <glib-object.h>
+#include <gio/gio.h>
 #include <goa/goa.h>
 
 G_BEGIN_DECLS
@@ -38,12 +38,16 @@ PhotosSource       *photos_source_new                    (const gchar *id, const
 
 PhotosSource       *photos_source_new_from_goa_object    (GoaObject *object);
 
+PhotosSource       *photos_source_new_from_mount         (GMount *mount);
+
 const gchar        *photos_source_get_name               (PhotosSource *self);
 
 GoaObject          *photos_source_get_goa_object         (PhotosSource *self);
 
 GIcon              *photos_source_get_icon               (PhotosSource *self);
 
+GMount             *photos_source_get_mount              (PhotosSource *self);
+
 GIcon              *photos_source_get_symbolic_icon      (PhotosSource *self);
 
 G_END_DECLS


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]