aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-dbus.c
diff options
context:
space:
mode:
authorChristian Persch <chpe@cvs.gnome.org>2006-01-24 20:01:23 +0800
committerChristian Persch <chpe@src.gnome.org>2006-01-24 20:01:23 +0800
commit21086fc06ec3d08e3c5609cc53383e7c18fd2175 (patch)
treed1369c22bd13556991212cba3dec47f1ea525fd4 /src/ephy-dbus.c
parentfa5456904722028972f1bbebdbb196c2cfd2e521 (diff)
downloadgsoc2013-epiphany-21086fc06ec3d08e3c5609cc53383e7c18fd2175.tar
gsoc2013-epiphany-21086fc06ec3d08e3c5609cc53383e7c18fd2175.tar.gz
gsoc2013-epiphany-21086fc06ec3d08e3c5609cc53383e7c18fd2175.tar.bz2
gsoc2013-epiphany-21086fc06ec3d08e3c5609cc53383e7c18fd2175.tar.lz
gsoc2013-epiphany-21086fc06ec3d08e3c5609cc53383e7c18fd2175.tar.xz
gsoc2013-epiphany-21086fc06ec3d08e3c5609cc53383e7c18fd2175.tar.zst
gsoc2013-epiphany-21086fc06ec3d08e3c5609cc53383e7c18fd2175.zip
Use DBUS_NAME_FLAG_DO_NOT_QUEUE when requesting the name, and also handle
2006-01-24 Christian Persch <chpe@cvs.gnome.org> * src/ephy-dbus.c: (ephy_dbus_connect_to_session_bus): Use DBUS_NAME_FLAG_DO_NOT_QUEUE when requesting the name, and also handle unexpected request return values.
Diffstat (limited to 'src/ephy-dbus.c')
-rw-r--r--src/ephy-dbus.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/src/ephy-dbus.c b/src/ephy-dbus.c
index ea33a076b..214a8452e 100644
--- a/src/ephy-dbus.c
+++ b/src/ephy-dbus.c
@@ -35,6 +35,11 @@
#define DBUS_NAME_FLAG_PROHIBIT_REPLACEMENT 0
#endif
+/* dbus < 0.6 compat */
+#ifndef DBUS_NAME_FLAG_DO_NOT_QUEUE
+#define DBUS_NAME_FLAG_DO_NOT_QUEUE 0
+#endif
+
#define RECONNECT_DELAY 3000
#define EPHY_DBUS_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_DBUS, EphyDbusPrivate))
@@ -275,7 +280,8 @@ ephy_dbus_connect_to_session_bus (EphyDbus *ephy_dbus,
if (!org_freedesktop_DBus_request_name (proxy,
DBUS_EPHY_SERVICE,
- DBUS_NAME_FLAG_PROHIBIT_REPLACEMENT,
+ DBUS_NAME_FLAG_PROHIBIT_REPLACEMENT |
+ DBUS_NAME_FLAG_DO_NOT_QUEUE,
&request_ret, error))
{
/* We have a BIG problem! */
@@ -283,19 +289,16 @@ ephy_dbus_connect_to_session_bus (EphyDbus *ephy_dbus,
return FALSE;
}
- if (request_ret == DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER)
+ if (request_ret == DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER ||
+ request_ret == DBUS_REQUEST_NAME_REPLY_ALREADY_OWNER)
{
ephy_dbus->priv->is_session_service_owner = TRUE;
}
- else if (request_ret == DBUS_REQUEST_NAME_REPLY_EXISTS)
+ else if (request_ret == DBUS_REQUEST_NAME_REPLY_EXISTS ||
+ request_ret == DBUS_REQUEST_NAME_REPLY_IN_QUEUE)
{
ephy_dbus->priv->is_session_service_owner = FALSE;
}
- else
- {
- /* FIXME can this happen? */
- g_assert_not_reached ();
- }
LOG ("Instance is %ssession bus owner.", ephy_dbus->priv->is_session_service_owner ? "" : "NOT ");