diff options
author | Martin Pitt <martin.pitt@canonical.com> | 2010-02-17 11:13:04 +0100 |
---|---|---|
committer | Martin Pitt <martin.pitt@canonical.com> | 2010-02-17 11:13:04 +0100 |
commit | 757ff3f23b2dd5f170f040c1bc81c5c107c22e53 (patch) | |
tree | 033acf5a77ee60e0b424267a19f6c63ee92cb344 /debian/patches | |
parent | 68c0523b4a6a55575f284ec03aa1bf33c80e1ede (diff) | |
download | ayatana-indicator-session-757ff3f23b2dd5f170f040c1bc81c5c107c22e53.tar.gz ayatana-indicator-session-757ff3f23b2dd5f170f040c1bc81c5c107c22e53.tar.bz2 ayatana-indicator-session-757ff3f23b2dd5f170f040c1bc81c5c107c22e53.zip |
Add debian/patches/01_port_to_upower.patch: Straightforward port to
upower's D-Bus API. A more elaborate port to libupower-glib has been
proposed upstream as well, but it's not yet clear whether to use the
client library or the D-Bus API.
Diffstat (limited to 'debian/patches')
-rw-r--r-- | debian/patches/01_port_to_upower.patch | 151 |
1 files changed, 151 insertions, 0 deletions
diff --git a/debian/patches/01_port_to_upower.patch b/debian/patches/01_port_to_upower.patch new file mode 100644 index 0000000..f04c1c7 --- /dev/null +++ b/debian/patches/01_port_to_upower.patch @@ -0,0 +1,151 @@ +Description: Port to upower +Author: Martin Pitt <martin.pitt@ubuntu.com> +Upstream: https://code.launchpad.net/~pitti/indicator-session/upower/+merge/19472 +--- indicator-session/src/session-service.c 2010-02-16 10:25:28.000000000 +0100 ++++ indicator-session.new/src/session-service.c 2010-02-17 11:11:18.149652860 +0100 +@@ -44,9 +44,9 @@ + #include "users-service-dbus.h" + #include "lock-helper.h" + +-#define DKP_ADDRESS "org.freedesktop.DeviceKit.Power" +-#define DKP_OBJECT "/org/freedesktop/DeviceKit/Power" +-#define DKP_INTERFACE "org.freedesktop.DeviceKit.Power" ++#define UP_ADDRESS "org.freedesktop.UPower" ++#define UP_OBJECT "/org/freedesktop/UPower" ++#define UP_INTERFACE "org.freedesktop.UPower" + + #define GUEST_SESSION_LAUNCHER "/usr/share/gdm/guest-session/guest-session-launch" + +@@ -72,8 +72,8 @@ + + static DbusmenuMenuitem * root_menuitem = NULL; + static GMainLoop * mainloop = NULL; +-static DBusGProxy * dkp_main_proxy = NULL; +-static DBusGProxy * dkp_prop_proxy = NULL; ++static DBusGProxy * up_main_proxy = NULL; ++static DBusGProxy * up_prop_proxy = NULL; + + static DBusGProxyCall * suspend_call = NULL; + static DBusGProxyCall * hibernate_call = NULL; +@@ -147,14 +147,14 @@ + { + gchar * type = (gchar *)userdata; + +- if (dkp_main_proxy == NULL) { +- g_warning("Can not %s as no DeviceKit Power Proxy", type); ++ if (up_main_proxy == NULL) { ++ g_warning("Can not %s as no upower proxy", type); + } + + screensaver_throttle(type); + lock_screen(NULL, 0, NULL); + +- dbus_g_proxy_begin_call(dkp_main_proxy, ++ dbus_g_proxy_begin_call(up_main_proxy, + type, + sleep_response, + NULL, +@@ -213,17 +213,17 @@ + /* A signal that we need to recheck to ensure we can still + hibernate and/or suspend */ + static void +-dpk_changed_cb (DBusGProxy * proxy, gpointer user_data) ++up_changed_cb (DBusGProxy * proxy, gpointer user_data) + { + /* Start Async call to see if we can hibernate */ + if (suspend_call == NULL) { +- suspend_call = dbus_g_proxy_begin_call(dkp_prop_proxy, ++ suspend_call = dbus_g_proxy_begin_call(up_prop_proxy, + "Get", + suspend_prop_cb, + NULL, + NULL, + G_TYPE_STRING, +- DKP_INTERFACE, ++ UP_INTERFACE, + G_TYPE_STRING, + "can-suspend", + G_TYPE_INVALID, +@@ -233,13 +233,13 @@ + + /* Start Async call to see if we can suspend */ + if (hibernate_call == NULL) { +- hibernate_call = dbus_g_proxy_begin_call(dkp_prop_proxy, ++ hibernate_call = dbus_g_proxy_begin_call(up_prop_proxy, + "Get", + hibernate_prop_cb, + NULL, + NULL, + G_TYPE_STRING, +- DKP_INTERFACE, ++ UP_INTERFACE, + G_TYPE_STRING, + "can-hibernate", + G_TYPE_INVALID, +@@ -254,39 +254,39 @@ + DKp checking. We're even setting up the calls for the props + we need */ + static void +-setup_dkp (void) { ++setup_up (void) { + DBusGConnection * bus = dbus_g_bus_get(DBUS_BUS_SYSTEM, NULL); + g_return_if_fail(bus != NULL); + +- if (dkp_main_proxy == NULL) { +- dkp_main_proxy = dbus_g_proxy_new_for_name(bus, +- DKP_ADDRESS, +- DKP_OBJECT, +- DKP_INTERFACE); +- } +- g_return_if_fail(dkp_main_proxy != NULL); +- +- if (dkp_prop_proxy == NULL) { +- dkp_prop_proxy = dbus_g_proxy_new_for_name(bus, +- DKP_ADDRESS, +- DKP_OBJECT, ++ if (up_main_proxy == NULL) { ++ up_main_proxy = dbus_g_proxy_new_for_name(bus, ++ UP_ADDRESS, ++ UP_OBJECT, ++ UP_INTERFACE); ++ } ++ g_return_if_fail(up_main_proxy != NULL); ++ ++ if (up_prop_proxy == NULL) { ++ up_prop_proxy = dbus_g_proxy_new_for_name(bus, ++ UP_ADDRESS, ++ UP_OBJECT, + DBUS_INTERFACE_PROPERTIES); + } +- g_return_if_fail(dkp_prop_proxy != NULL); ++ g_return_if_fail(up_prop_proxy != NULL); + + /* Connect to changed signal */ +- dbus_g_proxy_add_signal(dkp_main_proxy, ++ dbus_g_proxy_add_signal(up_main_proxy, + "Changed", + G_TYPE_INVALID); + +- dbus_g_proxy_connect_signal(dkp_main_proxy, ++ dbus_g_proxy_connect_signal(up_main_proxy, + "Changed", +- G_CALLBACK(dpk_changed_cb), ++ G_CALLBACK(up_changed_cb), + NULL, + NULL); + + /* Force an original "changed" event */ +- dpk_changed_cb(dkp_main_proxy, NULL); ++ up_changed_cb(up_main_proxy, NULL); + + return; + } +@@ -639,7 +639,7 @@ + G_CALLBACK (user_removed), + root_menuitem); + +- setup_dkp(); ++ setup_up(); + + DbusmenuServer * server = dbusmenu_server_new(INDICATOR_SESSION_DBUS_OBJECT); + dbusmenu_server_set_root(server, root_menuitem); |