diff options
author | raveit65 <[email protected]> | 2013-10-31 01:39:36 +0100 |
---|---|---|
committer | raveit65 <[email protected]> | 2013-10-31 01:39:36 +0100 |
commit | 2c5a103b59a53d5fb586572e38d65e7afb5ecb44 (patch) | |
tree | 781ccfa5479336982d95ff2e2b418e912b87f29b /mate-session/gsm-autostart-app.c | |
parent | 6c8051b0d0c020a450a9cfe43600444f4d600d1c (diff) | |
download | mate-session-manager-2c5a103b59a53d5fb586572e38d65e7afb5ecb44.tar.bz2 mate-session-manager-2c5a103b59a53d5fb586572e38d65e7afb5ecb44.tar.xz |
session: support_autostart_delay
Diffstat (limited to 'mate-session/gsm-autostart-app.c')
-rw-r--r-- | mate-session/gsm-autostart-app.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/mate-session/gsm-autostart-app.c b/mate-session/gsm-autostart-app.c index f19f6b6..04cc8e6 100644 --- a/mate-session/gsm-autostart-app.c +++ b/mate-session/gsm-autostart-app.c @@ -65,6 +65,7 @@ struct _GsmAutostartAppPrivate { char *condition_string; gboolean condition; gboolean autorestart; + int autostart_delay; GFileMonitor *condition_monitor; GSettings *condition_settings; @@ -101,6 +102,7 @@ gsm_autostart_app_init (GsmAutostartApp *app) app->priv->pid = -1; app->priv->condition_monitor = NULL; app->priv->condition = FALSE; + app->priv->autostart_delay = -1; } static gboolean @@ -482,6 +484,18 @@ load_desktop_file (GsmAutostartApp *app) NULL); setup_condition_monitor (app); + if (phase == GSM_MANAGER_PHASE_APPLICATION) { + /* Only accept an autostart delay for the application phase */ + app->priv->autostart_delay = egg_desktop_file_get_integer (app->priv->desktop_file, + GSM_AUTOSTART_APP_DELAY_KEY, + NULL); + if (app->priv->autostart_delay < 0) { + g_warning ("Invalid autostart delay of %d for %s", app->priv->autostart_delay, + gsm_app_peek_id (GSM_APP (app))); + app->priv->autostart_delay = -1; + } + } + g_object_set (app, "phase", phase, "startup-id", startup_id, @@ -1108,6 +1122,14 @@ gsm_autostart_app_get_app_id (GsmApp *app) } } +static int +gsm_autostart_app_peek_autostart_delay (GsmApp *app) +{ + GsmAutostartApp *aapp = GSM_AUTOSTART_APP (app); + + return aapp->priv->autostart_delay; +} + static GObject * gsm_autostart_app_constructor (GType type, guint n_construct_properties, @@ -1148,6 +1170,7 @@ gsm_autostart_app_class_init (GsmAutostartAppClass *klass) app_class->impl_has_autostart_condition = gsm_autostart_app_has_autostart_condition; app_class->impl_get_app_id = gsm_autostart_app_get_app_id; app_class->impl_get_autorestart = gsm_autostart_app_get_autorestart; + app_class->impl_peek_autostart_delay = gsm_autostart_app_peek_autostart_delay; g_object_class_install_property (object_class, PROP_DESKTOP_FILENAME, |