diff options
author | Ken VanDine <ken.vandine@canonical.com> | 2010-07-15 11:55:34 -0400 |
---|---|---|
committer | Ken VanDine <ken.vandine@canonical.com> | 2010-07-15 11:55:34 -0400 |
commit | 8c56a899a92e1f93fa6e04672718fe16b8d03c6e (patch) | |
tree | 9eb4232003756397461db8c2b77b75788b1267a1 /libindicator | |
parent | b52f07039fdf21d25fb1724c47a34a66c4981798 (diff) | |
parent | c6b0ab35023b3a68130ff692ab3d85cf5b44831e (diff) | |
download | libayatana-indicator-8c56a899a92e1f93fa6e04672718fe16b8d03c6e.tar.gz libayatana-indicator-8c56a899a92e1f93fa6e04672718fe16b8d03c6e.tar.bz2 libayatana-indicator-8c56a899a92e1f93fa6e04672718fe16b8d03c6e.zip |
releasing version 0.3.10-0ubuntu10.3.10-0ubuntu1
Diffstat (limited to 'libindicator')
-rw-r--r-- | libindicator/Makefile.in | 5 | ||||
-rw-r--r-- | libindicator/indicator-service.c | 17 |
2 files changed, 16 insertions, 6 deletions
diff --git a/libindicator/Makefile.in b/libindicator/Makefile.in index 9d5a624..ebe7648 100644 --- a/libindicator/Makefile.in +++ b/libindicator/Makefile.in @@ -57,10 +57,7 @@ DIST_COMMON = $(libindicatorinclude_HEADERS) $(srcdir)/Makefile.am \ $(top_srcdir)/Makefile.am.marshal subdir = libindicator ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ - $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ - $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ - $(top_srcdir)/configure.ac +am__aclocal_m4_deps = $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) mkinstalldirs = $(install_sh) -d diff --git a/libindicator/indicator-service.c b/libindicator/indicator-service.c index 55fb650..e9005db 100644 --- a/libindicator/indicator-service.c +++ b/libindicator/indicator-service.c @@ -55,6 +55,7 @@ struct _IndicatorServicePrivate { DBusGProxy * dbus_proxy; DBusGConnection * bus; guint timeout; + guint timeout_length; GHashTable * watchers; guint this_service_version; }; @@ -164,6 +165,16 @@ indicator_service_init (IndicatorService *self) priv->watchers = NULL; priv->bus = NULL; priv->this_service_version = 0; + priv->timeout_length = 500; + + const gchar * timeoutenv = g_getenv("INDICATOR_SERVICE_SHUTDOWN_TIMEOUT"); + if (timeoutenv != NULL) { + gdouble newtimeout = g_strtod(timeoutenv, NULL); + if (newtimeout >= 1.0f) { + priv->timeout_length = newtimeout; + g_debug("Setting shutdown timeout to: %u", priv->timeout_length); + } + } /* NOTE: We're using g_object_unref here because that's what needs to happen, but you really should call watchers_remove first as well @@ -373,7 +384,9 @@ try_and_get_name_cb (DBusGProxy * proxy, guint status, GError * error, gpointer } IndicatorServicePrivate * priv = INDICATOR_SERVICE_GET_PRIVATE(service); - priv->timeout = g_timeout_add_seconds(1, timeout_no_watchers, service); + /* Allow some extra time at start up as things can be in high + contention then. */ + priv->timeout = g_timeout_add(priv->timeout_length * 2, timeout_no_watchers, service); return; } @@ -515,7 +528,7 @@ unwatch_core (IndicatorService * service, const gchar * name) priv->timeout = 0; } /* If we don't get a new watcher quickly, we'll shutdown. */ - priv->timeout = g_timeout_add(500, timeout_no_watchers, service); + priv->timeout = g_timeout_add(priv->timeout_length, timeout_no_watchers, service); } return; |