diff --git a/0001-Add-AFC-backend.patch b/0001-Add-AFC-backend.patch index b425449..144ee50 100644 --- a/0001-Add-AFC-backend.patch +++ b/0001-Add-AFC-backend.patch @@ -1,4 +1,4 @@ -From 1ba08909cdc395c14116d7cdf0f8f3442ba5e4c0 Mon Sep 17 00:00:00 2001 +From 8675a60e030fc91292d19cfd2cd9a6d74dd1776f Mon Sep 17 00:00:00 2001 From: Bastien Nocera Date: Thu, 6 Aug 2009 22:55:47 +0100 Subject: [PATCH] Add AFC backend @@ -15,18 +15,18 @@ Bastien Nocera configure.ac | 26 +- daemon/Makefile.am | 23 + daemon/afc.mount.in | 7 + - daemon/gvfsbackendafc.c | 1226 ++++++++++++++++++++ + daemon/gvfsbackendafc.c | 1228 ++++++++++++++++++++ daemon/gvfsbackendafc.h | 37 + monitor/Makefile.am | 6 +- monitor/afc/Makefile.am | 49 + monitor/afc/afc.monitor | 5 + - monitor/afc/afcvolume.c | 336 ++++++ + monitor/afc/afcvolume.c | 353 ++++++ monitor/afc/afcvolume.h | 44 + - monitor/afc/afcvolumemonitor.c | 215 ++++ + monitor/afc/afcvolumemonitor.c | 224 ++++ monitor/afc/afcvolumemonitor.h | 39 + monitor/afc/afcvolumemonitordaemon.c | 31 + .../org.gtk.Private.AfcVolumeMonitor.service.in | 4 + - 14 files changed, 2046 insertions(+), 2 deletions(-) + 14 files changed, 2074 insertions(+), 2 deletions(-) create mode 100644 daemon/afc.mount.in create mode 100644 daemon/gvfsbackendafc.c create mode 100644 daemon/gvfsbackendafc.h @@ -40,7 +40,7 @@ Bastien Nocera create mode 100644 monitor/afc/org.gtk.Private.AfcVolumeMonitor.service.in diff --git a/configure.ac b/configure.ac -index 7f1ec16..4675ae9 100644 +index 9bfb8ad..6b3838c 100644 --- a/configure.ac +++ b/configure.ac @@ -324,6 +324,28 @@ AC_SUBST(CDDA_CFLAGS) @@ -91,7 +91,7 @@ index 7f1ec16..4675ae9 100644 DNS-SD support: $msg_avahi Build HAL volume monitor: $msg_hal (with fast init path: $have_hal_fast_init) diff --git a/daemon/Makefile.am b/daemon/Makefile.am -index 733fa41..4c9e4af 100644 +index a03eba1..cf68391 100644 --- a/daemon/Makefile.am +++ b/daemon/Makefile.am @@ -101,6 +101,12 @@ mount_DATA += archive.mount @@ -107,7 +107,7 @@ index 733fa41..4c9e4af 100644 EXTRA_DIST = gvfs-daemon.service.in $(mount_in_files) obexftp-marshal.list DISTCLEANFILES = gvfs-daemon.service $(mount_DATA) -@@ -433,3 +439,20 @@ gvfsd_dav_LDADD = $(libraries) $(HTTP_LIBS) +@@ -442,3 +448,20 @@ gvfsd_dav_LDADD = $(libraries) $(HTTP_LIBS) if HAVE_AVAHI gvfsd_dav_LDADD += $(top_builddir)/common/libgvfscommon-dnssd.la endif @@ -143,10 +143,10 @@ index 0000000..727d833 + diff --git a/daemon/gvfsbackendafc.c b/daemon/gvfsbackendafc.c new file mode 100644 -index 0000000..97d0a22 +index 0000000..d30ede8 --- /dev/null +++ b/daemon/gvfsbackendafc.c -@@ -0,0 +1,1226 @@ +@@ -0,0 +1,1228 @@ +/* + * gvfs/daemon/gvfsbackendafc.c + * @@ -165,7 +165,6 @@ index 0000000..97d0a22 +#include +#include + -+#define G_UDEV_API_IS_SUBJECT_TO_CHANGE +#include + +#include @@ -239,7 +238,7 @@ index 0000000..97d0a22 + { -1 } +}; + -+/** ++/** + * Tries to convert the AFC error value into a GIOError. + * + * @param client AFC client to retrieve status value from. @@ -414,7 +413,7 @@ index 0000000..97d0a22 + int retries; + iphone_error_t err; + lockdownd_client_t lockdown_cli = NULL; -+ const gchar * const subsystems[] = { "usb_endpoint", NULL }; ++ const gchar * const subsystems[] = { "usb", NULL }; + + self = G_VFS_BACKEND_AFC(backend); + self->connected = FALSE; @@ -505,7 +504,7 @@ index 0000000..97d0a22 + /* translators: + * This is the device name, with the service being browsed in brackets, eg.: + * Alan Smithee's iPhone (Service 2 on Apple Mobile Device */ -+ g_vfs_backend_set_display_name (G_VFS_BACKEND(self), ++ g_vfs_backend_set_display_name (G_VFS_BACKEND(self), + g_strdup_printf (_("%s (%s)"), display_name, self->service)); + } + else @@ -566,10 +565,13 @@ index 0000000..97d0a22 + +static void +g_vfs_backend_afc_unmount (GVfsBackend *backend, -+ GVfsJobUnmount * job) ++ GVfsJobUnmount *job, ++ GMountUnmountFlags flags, ++ GMountSource *mount_source) +{ + GVfsBackendAfc *self; + ++ /* FIXME: check on G_MOUNT_UNMOUNT_FORCE flag */ + self = G_VFS_BACKEND_AFC (backend); + g_vfs_backend_afc_close_connection (self); + g_vfs_job_succeeded (G_VFS_JOB(job)); @@ -768,7 +770,7 @@ index 0000000..97d0a22 + if (req > 0 && + G_UNLIKELY(g_vfs_backend_afc_check (afc_file_read (self->afc_cli, + fd, buffer, req, &nread), -+ G_VFS_JOB(job)))) ++ G_VFS_JOB(job)))) + { + return; + } @@ -797,7 +799,7 @@ index 0000000..97d0a22 + if (sz > 0 && + G_UNLIKELY(g_vfs_backend_afc_check(afc_file_write (self->afc_cli, + fd, buffer, sz, &nwritten), -+ G_VFS_JOB(job)))) ++ G_VFS_JOB(job)))) + { + return; + } @@ -1179,19 +1181,19 @@ index 0000000..97d0a22 + g_strfreev (kvps); + + g_file_info_set_attribute_uint32 (info, -+ G_FILE_ATTRIBUTE_UNIX_BLOCK_SIZE, ++ G_FILE_ATTRIBUTE_UNIX_BLOCK_SIZE, + (guint32) blocksize); -+ g_file_info_set_attribute_uint64 (info, -+ G_FILE_ATTRIBUTE_FILESYSTEM_SIZE, ++ g_file_info_set_attribute_uint64 (info, ++ G_FILE_ATTRIBUTE_FILESYSTEM_SIZE, + (guint64) totalspace); -+ g_file_info_set_attribute_uint64 (info, -+ G_FILE_ATTRIBUTE_FILESYSTEM_FREE, ++ g_file_info_set_attribute_uint64 (info, ++ G_FILE_ATTRIBUTE_FILESYSTEM_FREE, + (guint64) freespace); -+ g_file_info_set_attribute_boolean (info, -+ G_FILE_ATTRIBUTE_FILESYSTEM_READONLY, ++ g_file_info_set_attribute_boolean (info, ++ G_FILE_ATTRIBUTE_FILESYSTEM_READONLY, + FALSE); + g_file_info_set_attribute_uint32 (info, -+ G_FILE_ATTRIBUTE_FILESYSTEM_USE_PREVIEW, ++ G_FILE_ATTRIBUTE_FILESYSTEM_USE_PREVIEW, + G_FILESYSTEM_PREVIEW_TYPE_IF_LOCAL); + } + @@ -1502,10 +1504,10 @@ index 0000000..1663573 + diff --git a/monitor/afc/afcvolume.c b/monitor/afc/afcvolume.c new file mode 100644 -index 0000000..fe290a1 +index 0000000..688f75b --- /dev/null +++ b/monitor/afc/afcvolume.c -@@ -0,0 +1,336 @@ +@@ -0,0 +1,353 @@ +/* + * gvfs/monitor/afc/afc-volume.c + * @@ -1592,7 +1594,7 @@ index 0000000..fe290a1 + err = iphone_get_device_by_uuid (&dev, self->uuid); + if (err == IPHONE_E_SUCCESS) + break; -+ g_usleep (G_USEC_PER_SEC); ++ g_usleep (G_USEC_PER_SEC); + } while (retries++ < 10); + + if (err != IPHONE_E_SUCCESS) @@ -1624,7 +1626,7 @@ index 0000000..fe290a1 + model = afc_get_device_info_field (afc_cli, "Model"); + if (model != NULL) + { -+ if(strstr(model, "iPod") != NULL) ++ if(g_str_has_prefix(model, "iPod") != FALSE) + { + g_free (self->icon); + self->icon = g_strdup ("multimedia-player-apple-ipod-touch"); @@ -1699,6 +1701,17 @@ index 0000000..fe290a1 + return TRUE; +} + ++static GDrive * ++g_vfs_afc_volume_get_drive (GVolume *volume) ++{ ++ return NULL; ++} ++ ++static GMount * ++g_vfs_afc_volume_get_mount (GVolume *volume) ++{ ++ return NULL; ++} + +typedef struct +{ @@ -1778,7 +1791,7 @@ index 0000000..fe290a1 + char *id; + + id = NULL; -+ if (strcmp (kind, G_VOLUME_IDENTIFIER_KIND_UUID) == 0) ++ if (g_str_equal (kind, G_VOLUME_IDENTIFIER_KIND_UUID) != FALSE) + id = g_strdup (afc_volume->uuid); + + return id; @@ -1810,7 +1823,11 @@ index 0000000..fe290a1 +static GFile * +g_vfs_afc_volume_get_activation_root (GVolume *volume) +{ -+ GFile *root = g_object_get_data (G_OBJECT (volume), "root"); ++ GFile *root; ++ ++ root = g_object_get_data (G_OBJECT (volume), "root"); ++ if (root == NULL) ++ return NULL; + + return g_object_ref (root); +} @@ -1821,6 +1838,8 @@ index 0000000..fe290a1 + iface->get_name = g_vfs_afc_volume_get_name; + iface->get_icon = g_vfs_afc_volume_get_icon; + iface->get_uuid = g_vfs_afc_volume_get_uuid; ++ iface->get_drive = g_vfs_afc_volume_get_drive; ++ iface->get_mount = g_vfs_afc_volume_get_mount; + iface->can_mount = g_vfs_afc_volume_can_mount; + iface->should_automount = g_vfs_afc_volume_should_automount; + iface->mount_fn = g_vfs_afc_volume_mount; @@ -1894,10 +1913,10 @@ index 0000000..de24cd5 + */ diff --git a/monitor/afc/afcvolumemonitor.c b/monitor/afc/afcvolumemonitor.c new file mode 100644 -index 0000000..c98b603 +index 0000000..93926eb --- /dev/null +++ b/monitor/afc/afcvolumemonitor.c -@@ -0,0 +1,215 @@ +@@ -0,0 +1,224 @@ +/* + * gvfs/monitor/afc/afc-volume-monitor.c + * @@ -1977,33 +1996,28 @@ index 0000000..c98b603 + gpointer user_data) +{ + GVfsAfcVolumeMonitor *self; -+ const char *vendor, *devname, *uuid; ++ const char *vendor, *uuid; + + self = G_VFS_AFC_VOLUME_MONITOR(user_data); + + /* Vendor is Apple? */ + vendor = g_udev_device_get_property (device, "ID_VENDOR"); + if (vendor == NULL || -+ g_str_equal (vendor, "Apple_Inc.") == FALSE) -+ return; -+ -+ /* Device is for end point 85? */ -+ devname = g_udev_device_get_device_file (device); -+ if (devname == NULL || -+ g_str_has_suffix (devname, "_ep85") == FALSE) ++ g_str_equal (vendor, "Apple_Inc.") == FALSE) { + return; ++ } + + /* Get us a UUID */ + uuid = g_udev_device_get_property (device, "ID_SERIAL_SHORT"); + if (uuid == NULL) + { -+ g_warning ("Could not get UUID for device '%s'", devname); ++ g_message ("No serial for device"); + return; + } + + if (g_str_equal (action, "add") != FALSE) + g_vfs_afc_monitor_create_volume (self, uuid); -+ else ++ else if (g_str_equal (action, "remove") != FALSE) + g_vfs_afc_monitor_remove_volume (self, uuid); +} + @@ -2013,7 +2027,7 @@ index 0000000..c98b603 +{ + GVfsAfcVolumeMonitor *self; + GList *devices, *l; -+ const gchar * const subsystems[] = { "usb_endpoint", NULL }; ++ const gchar * const subsystems[] = { "usb", NULL }; + + /* Boilerplate code to chain from parent. */ + self = G_VFS_AFC_VOLUME_MONITOR((*G_OBJECT_CLASS(g_vfs_afc_volume_monitor_parent_class)->constructor)(type, ncps, cps)); @@ -2066,6 +2080,12 @@ index 0000000..c98b603 +} + +static GList * ++g_vfs_afc_volume_monitor_get_mounts (GVolumeMonitor *_self) ++{ ++ return NULL; ++} ++ ++static GList * +g_vfs_afc_volume_monitor_get_volumes (GVolumeMonitor *_self) +{ + GVfsAfcVolumeMonitor *self; @@ -2079,6 +2099,12 @@ index 0000000..c98b603 + return l; +} + ++static GList * ++g_vfs_afc_volume_monitor_get_connected_drives (GVolumeMonitor *_self) ++{ ++ return NULL; ++} ++ +static gboolean +g_vfs_afc_volume_monitor_is_supported (void) +{ @@ -2094,7 +2120,9 @@ index 0000000..c98b603 + gobject_class->constructor = g_vfs_afc_volume_monitor_constructor; + gobject_class->finalize = g_vfs_afc_volume_monitor_finalize; + ++ monitor_class->get_mounts = g_vfs_afc_volume_monitor_get_mounts; + monitor_class->get_volumes = g_vfs_afc_volume_monitor_get_volumes; ++ monitor_class->get_connected_drives = g_vfs_afc_volume_monitor_get_connected_drives; + monitor_class->is_supported = g_vfs_afc_volume_monitor_is_supported; +} + diff --git a/0001-Revert-part-of-the-excessive-function-culling.patch b/0001-Revert-part-of-the-excessive-function-culling.patch deleted file mode 100644 index 771c8cb..0000000 --- a/0001-Revert-part-of-the-excessive-function-culling.patch +++ /dev/null @@ -1,52 +0,0 @@ -From 8b926f38fe60569de6ddcddf3e19ef0ee3fbad8a Mon Sep 17 00:00:00 2001 -From: Bastien Nocera -Date: Tue, 11 Aug 2009 17:19:31 +0100 -Subject: [PATCH] Revert part of the excessive function culling - ---- - monitor/afc/afc-volume-monitor.c | 14 ++++++++++++++ - 1 files changed, 14 insertions(+), 0 deletions(-) - -diff --git a/monitor/afc/afcvolumemonitor.c b/monitor/afc/afcvolumemonitor.c -index ee491d5..faa384d 100644 ---- a/monitor/afc/afcvolumemonitor.c -+++ b/monitor/afc/afcvolumemonitor.c -@@ -166,6 +166,12 @@ g_vfs_afc_volume_monitor_finalize (GObject *_self) - } - - static GList * -+g_vfs_afc_volume_monitor_get_mounts (GVolumeMonitor *_self) -+{ -+ return NULL; -+} -+ -+static GList * - g_vfs_afc_volume_monitor_get_volumes (GVolumeMonitor *_self) - { - GVfsAfcVolumeMonitor *self; -@@ -179,6 +185,12 @@ g_vfs_afc_volume_monitor_get_volumes (GVolumeMonitor *_self) - return l; - } - -+static GList * -+g_vfs_afc_volume_monitor_get_connected_drives (GVolumeMonitor *_self) -+{ -+ return NULL; -+} -+ - static gboolean - g_vfs_afc_volume_monitor_is_supported (void) - { -@@ -194,7 +206,9 @@ g_vfs_afc_volume_monitor_class_init (GVfsAfcVolumeMonitorClass * klass) - gobject_class->constructor = g_vfs_afc_volume_monitor_constructor; - gobject_class->finalize = g_vfs_afc_volume_monitor_finalize; - -+ monitor_class->get_mounts = g_vfs_afc_volume_monitor_get_mounts; - monitor_class->get_volumes = g_vfs_afc_volume_monitor_get_volumes; -+ monitor_class->get_connected_drives = g_vfs_afc_volume_monitor_get_connected_drives; - monitor_class->is_supported = g_vfs_afc_volume_monitor_is_supported; - } - --- -1.6.2.5 - diff --git a/gvfs.spec b/gvfs.spec index c386a98..6d7a917 100644 --- a/gvfs.spec +++ b/gvfs.spec @@ -1,7 +1,7 @@ Summary: Backends for the gio framework in GLib Name: gvfs Version: 1.3.4 -Release: 5%{?dist} +Release: 6%{?dist} License: LGPLv2+ Group: System Environment/Libraries URL: http://www.gtk.org @@ -48,7 +48,6 @@ Patch8: gvfs-1.2.2-dnssd-deadlock.patch Patch9: gvfs-1.2.3-sftp-40sec-timeout.patch # http://bugzilla.gnome.org/show_bug.cgi?id=591005 Patch10: 0001-Add-AFC-backend.patch -Patch11: 0001-Revert-part-of-the-excessive-function-culling.patch %description The gvfs package provides backend implementations for the gio @@ -301,6 +300,9 @@ update-desktop-database &> /dev/null ||: %{_datadir}/gvfs/remote-volume-monitors/afc.monitor %changelog +* Fri Aug 14 2009 Bastien Nocera 1.3.4-6 +- Update AFC patch + * Thu Aug 13 2009 Tomas Bzatek - 1.3.4-5 - More complete fix for DAV mount path prefix issues