aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2010-01-12 13:37:40 -0600
committerTed Gould <ted@gould.cx>2010-01-12 13:37:40 -0600
commit9518459fda51ce675794115b401e36cb2f4306f5 (patch)
treee456c6ce6fa325a3738065675cfec584d75980b2
parent7e5e095f25954857936213bd7136fb1e18583819 (diff)
downloadayatana-indicator-application-9518459fda51ce675794115b401e36cb2f4306f5.tar.gz
ayatana-indicator-application-9518459fda51ce675794115b401e36cb2f4306f5.tar.bz2
ayatana-indicator-application-9518459fda51ce675794115b401e36cb2f4306f5.zip
Fallback timer pointer lifecycle.
-rw-r--r--src/libappindicator/app-indicator.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/libappindicator/app-indicator.c b/src/libappindicator/app-indicator.c
index b28a876..687ce21 100644
--- a/src/libappindicator/app-indicator.c
+++ b/src/libappindicator/app-indicator.c
@@ -66,7 +66,9 @@ struct _AppIndicatorPrivate {
gchar * icon_path;
DbusmenuServer *menuservice;
GtkWidget *menu;
+
GtkStatusIcon * status_icon;
+ gint fallback_timer;
/* Fun stuff */
DBusGProxy *watcher_proxy;
@@ -116,6 +118,9 @@ enum {
#define DEFAULT_ITEM_PATH "/org/ayatana/NotificationItem"
#define DEFAULT_MENU_PATH "/org/ayatana/NotificationItem/Menu"
+/* More constants */
+#define DEFAULT_FALLBACK_TIMER 100 /* in milliseconds */
+
/* Boiler plate */
static void app_indicator_class_init (AppIndicatorClass *klass);
static void app_indicator_init (AppIndicator *self);
@@ -308,6 +313,7 @@ app_indicator_init (AppIndicator *self)
priv->connection = NULL;
priv->status_icon = NULL;
+ priv->fallback_timer = 0;
/* Put the object on DBus */
GError * error = NULL;
@@ -347,6 +353,11 @@ app_indicator_dispose (GObject *object)
priv->status_icon = NULL;
}
+ if (priv->fallback_timer != 0) {
+ g_source_remove(priv->fallback_timer);
+ priv->fallback_timer = 0;
+ }
+
if (priv->menu != NULL) {
g_object_unref(G_OBJECT(priv->menu));
priv->menu = NULL;
@@ -583,6 +594,9 @@ register_service_cb (DBusGProxy * proxy, GError * error, gpointer data)
priv->watcher_proxy = NULL;
start_fallback_timer(APP_INDICATOR(data), TRUE);
}
+
+ /* TODO: Unfallback here */
+
return;
}
@@ -604,7 +618,13 @@ category_from_enum (AppIndicatorCategory category)
static void
start_fallback_timer (AppIndicator * self, gboolean do_it_now)
{
+ AppIndicatorPrivate * priv = APP_INDICATOR_GET_PRIVATE(self);
+ if (priv->fallback_timer != 0) {
+ /* The timer is set, let's just be happy with the one
+ we've already got running */
+ return;
+ }
}