summaryrefslogtreecommitdiff
path: root/libupower-glib
diff options
context:
space:
mode:
Diffstat (limited to 'libupower-glib')
-rw-r--r--libupower-glib/up-client.c49
-rw-r--r--libupower-glib/up-client.h1
2 files changed, 50 insertions, 0 deletions
diff --git a/libupower-glib/up-client.c b/libupower-glib/up-client.c
index 2fb5280..3da75ef 100644
--- a/libupower-glib/up-client.c
+++ b/libupower-glib/up-client.c
@@ -64,6 +64,7 @@ struct _UpClientPrivate
gboolean on_battery;
gboolean on_low_battery;
gboolean lid_is_present;
+ gboolean lid_force_sleep;
gboolean is_docked;
gboolean done_enumerate;
};
@@ -85,6 +86,7 @@ enum {
PROP_ON_LOW_BATTERY,
PROP_LID_IS_CLOSED,
PROP_LID_IS_PRESENT,
+ PROP_LID_FORCE_SLEEP,
PROP_IS_DOCKED,
PROP_LAST
};
@@ -419,6 +421,17 @@ up_client_get_properties_sync (UpClient *client, GCancellable *cancellable, GErr
g_object_notify (G_OBJECT(client), "is-docked");
}
+ value = g_hash_table_lookup (props, "LidForceSleep");
+ if (value == NULL) {
+ g_warning ("No 'LidForceSleep' property");
+ goto out;
+ }
+ ret = g_value_get_boolean (value);
+ if (ret != client->priv->lid_force_sleep) {
+ client->priv->lid_force_sleep = ret;
+ g_object_notify (G_OBJECT(client), "lid-force-sleep");
+ }
+
/* cached */
client->priv->have_properties = TRUE;
@@ -501,6 +514,24 @@ up_client_get_lid_is_present (UpClient *client)
}
/**
+ * up_client_get_lid_force_sleep:
+ * @client: a #UpClient instance.
+ *
+ * Get whether the laptop has to sleep when the lid is closed.
+ *
+ * Return value: %TRUE if the session has to suspend
+ *
+ * Since: 0.9.9
+ */
+gboolean
+up_client_get_lid_force_sleep (UpClient *client)
+{
+ g_return_val_if_fail (UP_IS_CLIENT (client), FALSE);
+ up_client_get_properties_sync (client, NULL, NULL);
+ return client->priv->lid_force_sleep;
+}
+
+/**
* up_client_get_is_docked:
* @client: a #UpClient instance.
*
@@ -681,6 +712,9 @@ up_client_get_property (GObject *object,
case PROP_LID_IS_PRESENT:
g_value_set_boolean (value, client->priv->lid_is_present);
break;
+ case PROP_LID_FORCE_SLEEP:
+ g_value_set_boolean (value, client->priv->lid_force_sleep);
+ break;
case PROP_IS_DOCKED:
g_value_set_boolean (value, client->priv->is_docked);
break;
@@ -802,6 +836,21 @@ up_client_class_init (UpClientClass *klass)
G_PARAM_READABLE));
/**
+ * UpClient:lid-force-sleep:
+ *
+ * If a laptop has to sleep if the lid is closed.
+ *
+ * Since: 0.9.9
+ */
+ g_object_class_install_property (object_class,
+ PROP_LID_FORCE_SLEEP,
+ g_param_spec_boolean ("lid-force-sleep",
+ "If a laptop has to sleep on lid close",
+ NULL,
+ FALSE,
+ G_PARAM_READABLE));
+
+ /**
* UpClient:is-docked:
*
* If the laptop is docked
diff --git a/libupower-glib/up-client.h b/libupower-glib/up-client.h
index 05c8a07..aa522ab 100644
--- a/libupower-glib/up-client.h
+++ b/libupower-glib/up-client.h
@@ -99,6 +99,7 @@ const gchar *up_client_get_daemon_version (UpClient *client);
gboolean up_client_get_can_hibernate (UpClient *client);
gboolean up_client_get_lid_is_closed (UpClient *client);
gboolean up_client_get_lid_is_present (UpClient *client);
+gboolean up_client_get_lid_force_sleep (UpClient *client);
gboolean up_client_get_is_docked (UpClient *client);
gboolean up_client_get_can_suspend (UpClient *client);
gboolean up_client_get_on_battery (UpClient *client);