diff options
| author | Ted Gould <ted@gould.cx> | 2009-11-24 17:03:24 -0600 | 
|---|---|---|
| committer | Ted Gould <ted@gould.cx> | 2009-11-24 17:03:24 -0600 | 
| commit | 8c7ce8faffe025e5c5cf8f4f23d9cf97cf719533 (patch) | |
| tree | dc31888f2106019130da16fb1af5e1bba63bb46b /src | |
| parent | acbab334ce6b9cef6d80c94d29aac7fb35534b4d (diff) | |
| download | ayatana-indicator-application-8c7ce8faffe025e5c5cf8f4f23d9cf97cf719533.tar.gz ayatana-indicator-application-8c7ce8faffe025e5c5cf8f4f23d9cf97cf719533.tar.bz2 ayatana-indicator-application-8c7ce8faffe025e5c5cf8f4f23d9cf97cf719533.zip | |
Moving the connection code into a function that is called to check to see if we have enough data.  This fixes distcheck after the merge from main.
Diffstat (limited to 'src')
| -rw-r--r-- | src/libcustomindicator/custom-indicator.c | 52 | 
1 files changed, 34 insertions, 18 deletions
| diff --git a/src/libcustomindicator/custom-indicator.c b/src/libcustomindicator/custom-indicator.c index 6ade629..8d6633a 100644 --- a/src/libcustomindicator/custom-indicator.c +++ b/src/libcustomindicator/custom-indicator.c @@ -38,6 +38,7 @@ struct _CustomIndicatorPrivate {  	/* Fun stuff */  	DBusGProxy * watcher_proxy; +	DBusGConnection * connection;  };  /* Signals Stuff */ @@ -270,34 +271,21 @@ custom_indicator_init (CustomIndicator *self)  	priv->menu = NULL;  	priv->watcher_proxy = NULL; +	priv->connection = NULL;  	/* Put the object on DBus */  	GError * error = NULL; -	DBusGConnection * connection = dbus_g_bus_get(DBUS_BUS_SESSION, &error); +	priv->connection = dbus_g_bus_get(DBUS_BUS_SESSION, &error);  	if (error != NULL) {  		g_error("Unable to connect to the session bus when creating custom indicator: %s", error->message);  		g_error_free(error);  		return;  	} -	dbus_g_connection_register_g_object(connection, +	dbus_g_connection_register_g_object(priv->connection,  	                                    "/need/a/path",  	                                    G_OBJECT(self)); -	priv->watcher_proxy = dbus_g_proxy_new_for_name_owner(connection, -	                                                      INDICATOR_CUSTOM_DBUS_ADDR, -	                                                      NOTIFICATION_WATCHER_DBUS_OBJ, -	                                                      NOTIFICATION_WATCHER_DBUS_IFACE, -	                                                      &error); -	if (error != NULL) { -		g_warning("Unable to create Ayatana Watcher proxy!  %s", error->message); -		/* TODO: This is where we should start looking at fallbacks */ -		g_error_free(error); -		return; -	} - -	org_ayatana_indicator_custom_NotificationWatcher_register_service_async(priv->watcher_proxy, "/need/a/path", register_service_cb, self); -  	return;  } @@ -321,8 +309,7 @@ custom_indicator_dispose (GObject *object)  	}  	if (priv->watcher_proxy != NULL) { -		DBusGConnection * session_bus = dbus_g_bus_get(DBUS_BUS_SESSION, NULL); -		dbus_g_connection_flush(session_bus); +		dbus_g_connection_flush(priv->connection);  		g_object_unref(G_OBJECT(priv->watcher_proxy));  		priv->watcher_proxy = NULL;  	} @@ -439,6 +426,7 @@ custom_indicator_set_property (GObject * object, guint prop_id, const GValue * v  		} else {  			WARN_BAD_TYPE(PROP_ICON_NAME_S, value);  		} +		check_connect(self);  		break;  	/* *********************** */  	case PROP_ATTENTION_ICON_NAME: @@ -473,6 +461,7 @@ custom_indicator_set_property (GObject * object, guint prop_id, const GValue * v  		} else {  			WARN_BAD_TYPE(PROP_MENU_S, value);  		} +		check_connect(self);  		break;  	/* *********************** */  	default: @@ -606,16 +595,43 @@ custom_indicator_get_property (GObject * object, guint prop_id, GValue * value,  static void  check_connect (CustomIndicator * self)  { +	CustomIndicatorPrivate * priv = CUSTOM_INDICATOR_GET_PRIVATE(self); + +	/* We're alreadying connecting or trying to connect. */ +	if (priv->watcher_proxy != NULL) return; +	/* Do we have enough information? */ +	if (priv->menu == NULL) return; +	if (priv->icon_name == NULL) return; +	if (priv->id == NULL) return; +	GError * error = NULL; +	priv->watcher_proxy = dbus_g_proxy_new_for_name_owner(priv->connection, +	                                                      INDICATOR_CUSTOM_DBUS_ADDR, +	                                                      NOTIFICATION_WATCHER_DBUS_OBJ, +	                                                      NOTIFICATION_WATCHER_DBUS_IFACE, +	                                                      &error); +	if (error != NULL) { +		g_warning("Unable to create Ayatana Watcher proxy!  %s", error->message); +		/* TODO: This is where we should start looking at fallbacks */ +		g_error_free(error); +		return; +	} + +	org_ayatana_indicator_custom_NotificationWatcher_register_service_async(priv->watcher_proxy, "/need/a/path", register_service_cb, self); +	return;  }  static void  register_service_cb (DBusGProxy * proxy, GError * error, gpointer data)  { +	CustomIndicatorPrivate * priv = CUSTOM_INDICATOR_GET_PRIVATE(data); +  	if (error != NULL) {  		g_warning("Unable to connect to the Notification Watcher: %s", error->message); +		g_object_unref(G_OBJECT(priv->watcher_proxy)); +		priv->watcher_proxy = NULL;  	}  	return;  } | 
