[gvfs/gdbus: 8/11] gdbus: Strip unmapped GError quark strings
- From: Tomas Bzatek <tbzatek src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gvfs/gdbus: 8/11] gdbus: Strip unmapped GError quark strings
- Date: Tue, 7 Jun 2011 13:44:05 +0000 (UTC)
commit b3a0e308af518e08897916597563f6e15709a72b
Author: Tomas Bzatek <tbzatek redhat com>
Date: Thu Jun 2 11:36:18 2011 +0200
gdbus: Strip unmapped GError quark strings
Typically happens when receiving side is not aware of extra GError domains
registered on sending (server) side, such as GDU_ERROR.
While the receiving side will get different error (G_IO_ERROR_DBUS_ERROR)
it's not usually a problem as long as the error message is preserved.
monitor/proxy/gproxydrive.c | 84 ++++++++++++++++++++++++++----------------
monitor/proxy/gproxymount.c | 21 ++++++----
monitor/proxy/gproxyvolume.c | 21 ++++++----
3 files changed, 78 insertions(+), 48 deletions(-)
---
diff --git a/monitor/proxy/gproxydrive.c b/monitor/proxy/gproxydrive.c
index 8e1d840..bb3866d 100644
--- a/monitor/proxy/gproxydrive.c
+++ b/monitor/proxy/gproxydrive.c
@@ -533,15 +533,20 @@ eject_cb (GVfsRemoteVolumeMonitor *proxy,
GSimpleAsyncResult *simple;
if (error != NULL)
- simple = g_simple_async_result_new_from_error (G_OBJECT (data->drive),
- data->callback,
- data->user_data,
- error);
+ {
+ g_dbus_error_strip_remote_error (error);
+ simple = g_simple_async_result_new_from_error (G_OBJECT (data->drive),
+ data->callback,
+ data->user_data,
+ error);
+ }
else
- simple = g_simple_async_result_new (G_OBJECT (data->drive),
- data->callback,
- data->user_data,
- NULL);
+ {
+ simple = g_simple_async_result_new (G_OBJECT (data->drive),
+ data->callback,
+ data->user_data,
+ NULL);
+ }
g_simple_async_result_complete (simple);
g_object_unref (simple);
}
@@ -673,15 +678,20 @@ stop_cb (GVfsRemoteVolumeMonitor *proxy,
GSimpleAsyncResult *simple;
if (error != NULL)
- simple = g_simple_async_result_new_from_error (G_OBJECT (data->drive),
- data->callback,
- data->user_data,
- error);
+ {
+ g_dbus_error_strip_remote_error (error);
+ simple = g_simple_async_result_new_from_error (G_OBJECT (data->drive),
+ data->callback,
+ data->user_data,
+ error);
+ }
else
- simple = g_simple_async_result_new (G_OBJECT (data->drive),
- data->callback,
- data->user_data,
- NULL);
+ {
+ simple = g_simple_async_result_new (G_OBJECT (data->drive),
+ data->callback,
+ data->user_data,
+ NULL);
+ }
g_simple_async_result_complete (simple);
g_object_unref (simple);
}
@@ -806,15 +816,20 @@ if (data->cancelled_handler_id > 0)
GSimpleAsyncResult *simple;
if (error != NULL)
- simple = g_simple_async_result_new_from_error (G_OBJECT (data->drive),
- data->callback,
- data->user_data,
- error);
+ {
+ g_dbus_error_strip_remote_error (error);
+ simple = g_simple_async_result_new_from_error (G_OBJECT (data->drive),
+ data->callback,
+ data->user_data,
+ error);
+ }
else
- simple = g_simple_async_result_new (G_OBJECT (data->drive),
- data->callback,
- data->user_data,
- NULL);
+ {
+ simple = g_simple_async_result_new (G_OBJECT (data->drive),
+ data->callback,
+ data->user_data,
+ NULL);
+ }
g_simple_async_result_complete_in_idle (simple);
g_object_unref (simple);
}
@@ -957,15 +972,20 @@ poll_for_media_cb (GVfsRemoteVolumeMonitor *proxy,
GSimpleAsyncResult *simple;
if (error != NULL)
- simple = g_simple_async_result_new_from_error (G_OBJECT (data->drive),
- data->callback,
- data->user_data,
- error);
+ {
+ g_dbus_error_strip_remote_error (error);
+ simple = g_simple_async_result_new_from_error (G_OBJECT (data->drive),
+ data->callback,
+ data->user_data,
+ error);
+ }
else
- simple = g_simple_async_result_new (G_OBJECT (data->drive),
- data->callback,
- data->user_data,
- NULL);
+ {
+ simple = g_simple_async_result_new (G_OBJECT (data->drive),
+ data->callback,
+ data->user_data,
+ NULL);
+ }
g_simple_async_result_complete (simple);
g_object_unref (simple);
}
diff --git a/monitor/proxy/gproxymount.c b/monitor/proxy/gproxymount.c
index aab20d0..eaf5b55 100644
--- a/monitor/proxy/gproxymount.c
+++ b/monitor/proxy/gproxymount.c
@@ -492,15 +492,20 @@ unmount_cb (GVfsRemoteVolumeMonitor *proxy,
{
GSimpleAsyncResult *simple;
if (error != NULL)
- simple = g_simple_async_result_new_from_error (G_OBJECT (data->mount),
- data->callback,
- data->user_data,
- error);
+ {
+ g_dbus_error_strip_remote_error (error);
+ simple = g_simple_async_result_new_from_error (G_OBJECT (data->mount),
+ data->callback,
+ data->user_data,
+ error);
+ }
else
- simple = g_simple_async_result_new (G_OBJECT (data->mount),
- data->callback,
- data->user_data,
- NULL);
+ {
+ simple = g_simple_async_result_new (G_OBJECT (data->mount),
+ data->callback,
+ data->user_data,
+ NULL);
+ }
g_simple_async_result_complete (simple);
g_object_unref (simple);
}
diff --git a/monitor/proxy/gproxyvolume.c b/monitor/proxy/gproxyvolume.c
index 14f382d..e375a2c 100644
--- a/monitor/proxy/gproxyvolume.c
+++ b/monitor/proxy/gproxyvolume.c
@@ -728,15 +728,20 @@ mount_cb (GVfsRemoteVolumeMonitor *proxy,
GSimpleAsyncResult *simple;
if (error != NULL)
- simple = g_simple_async_result_new_from_error (G_OBJECT (data->volume),
- data->callback,
- data->user_data,
- error);
+ {
+ g_dbus_error_strip_remote_error (error);
+ simple = g_simple_async_result_new_from_error (G_OBJECT (data->volume),
+ data->callback,
+ data->user_data,
+ error);
+ }
else
- simple = g_simple_async_result_new (G_OBJECT (data->volume),
- data->callback,
- data->user_data,
- NULL);
+ {
+ simple = g_simple_async_result_new (G_OBJECT (data->volume),
+ data->callback,
+ data->user_data,
+ NULL);
+ }
g_simple_async_result_complete_in_idle (simple);
g_object_unref (simple);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]