diff options
author | Ken VanDine <ken.vandine@canonical.com> | 2011-10-24 11:07:53 -0400 |
---|---|---|
committer | Ken VanDine <ken.vandine@canonical.com> | 2011-10-24 11:07:53 -0400 |
commit | 8541fa2fca5e702df025c670f7d03bceb66ca2aa (patch) | |
tree | 25a833e555fdb8ef1ff8a2379136000c1b89b07e | |
parent | 56dd8ea486d13905bf24ea28a59d48e1c30130d9 (diff) | |
parent | 31651dddeaa9dce1d51b0b78ccdcf98c118ca06e (diff) | |
download | ayatana-indicator-power-8541fa2fca5e702df025c670f7d03bceb66ca2aa.tar.gz ayatana-indicator-power-8541fa2fca5e702df025c670f7d03bceb66ca2aa.tar.bz2 ayatana-indicator-power-8541fa2fca5e702df025c670f7d03bceb66ca2aa.zip |
Import upstream version 0.10
-rw-r--r-- | ChangeLog | 44 | ||||
-rwxr-xr-x | configure | 20 | ||||
-rw-r--r-- | configure.ac | 2 | ||||
-rw-r--r-- | po/POTFILES.in | 2 | ||||
-rw-r--r-- | src/indicator-power.c | 112 |
5 files changed, 144 insertions, 36 deletions
@@ -1,5 +1,49 @@ # Generated by Makefile. Do not edit. +2011-10-13 Javier Jardón <javier.jardon@codethink.co.uk> + + 0.10 + +2011-10-13 Javier Jardón <javier.jardon@codethink.co.uk> + + Do not hardcode icon percentage when discharging + +2011-10-13 Javier Jardón <javier.jardon@codethink.co.uk> + + Add support for old name icons + +2011-10-13 Javier Jardón <javier.jardon@codethink.co.uk> + + Fix icon creation for UP_DEVICE_STATE_CHARGING state + +2011-10-04 Javier Jardón <javier.jardon@codethink.co.uk> + + Only show a red icon when we have less than 30 minutes of battery remainig + + Fixes https://bugs.launchpad.net/indicator-power/+bug/743823 + +2011-10-03 Javier Jardón <javier.jardon@codethink.co.uk> + + Use battery-with-a-plug when the batttery is fully charged but still on AC + + Fixes https://bugs.launchpad.net/indicator-power/+bug/865342 + +2011-10-03 Javier Jardón <javier.jardon@codethink.co.uk> + + Show non present batteries in the menu + +2011-10-02 Javier Jardón <javier.jardon@codethink.co.uk> + + Add a workaround to fix the case when we get a empty bay as a real battery + +2011-09-23 Ken VanDine <ken.vandine@canonical.com> + + Fix POTFILES.in to reflect new gsettings schema filename + +2011-09-23 Ken VanDine <ken.vandine@canonical.com> + + fixed filename for gsettings schema + 2011-09-23 Javier Jardón <javier.jardon@codethink.co.uk> 0.9 @@ -1,6 +1,6 @@ #! /bin/sh # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.68 for indicator-power 0.9. +# Generated by GNU Autoconf 2.68 for indicator-power 0.10. # # Report bugs to <http://bugs.launchpad.net/indicator-power>. # @@ -570,8 +570,8 @@ MAKEFLAGS= # Identity of this package. PACKAGE_NAME='indicator-power' PACKAGE_TARNAME='indicator-power' -PACKAGE_VERSION='0.9' -PACKAGE_STRING='indicator-power 0.9' +PACKAGE_VERSION='0.10' +PACKAGE_STRING='indicator-power 0.10' PACKAGE_BUGREPORT='http://bugs.launchpad.net/indicator-power' PACKAGE_URL='http://launchpad.net/indicator-power' @@ -1367,7 +1367,7 @@ if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF -\`configure' configures indicator-power 0.9 to adapt to many kinds of systems. +\`configure' configures indicator-power 0.10 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... @@ -1437,7 +1437,7 @@ fi if test -n "$ac_init_help"; then case $ac_init_help in - short | recursive ) echo "Configuration of indicator-power 0.9:";; + short | recursive ) echo "Configuration of indicator-power 0.10:";; esac cat <<\_ACEOF @@ -1568,7 +1568,7 @@ fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF -indicator-power configure 0.9 +indicator-power configure 0.10 generated by GNU Autoconf 2.68 Copyright (C) 2010 Free Software Foundation, Inc. @@ -1846,7 +1846,7 @@ cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. -It was created by indicator-power $as_me 0.9, which was +It was created by indicator-power $as_me 0.10, which was generated by GNU Autoconf 2.68. Invocation command line was $ $0 $@ @@ -2670,7 +2670,7 @@ fi # Define the identity of the package. PACKAGE='indicator-power' - VERSION='0.9' + VERSION='0.10' cat >>confdefs.h <<_ACEOF @@ -15119,7 +15119,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" -This file was extended by indicator-power $as_me 0.9, which was +This file was extended by indicator-power $as_me 0.10, which was generated by GNU Autoconf 2.68. Invocation command line was CONFIG_FILES = $CONFIG_FILES @@ -15186,7 +15186,7 @@ _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ -indicator-power config.status 0.9 +indicator-power config.status 0.10 configured by $0, generated by GNU Autoconf 2.68, with options \\"\$ac_cs_config\\" diff --git a/configure.ac b/configure.ac index 4176d1f..2d42c3c 100644 --- a/configure.ac +++ b/configure.ac @@ -1,5 +1,5 @@ AC_INIT([indicator-power], - [0.9], + [0.10], [http://bugs.launchpad.net/indicator-power], [indicator-power], [http://launchpad.net/indicator-power]) diff --git a/po/POTFILES.in b/po/POTFILES.in index 62d1e12..7c8c8a1 100644 --- a/po/POTFILES.in +++ b/po/POTFILES.in @@ -1,2 +1,2 @@ -data/org.ubuntu.indicator-power.gschema.xml.in +data/com.canonical.indicator.power.gschema.xml.in src/indicator-power.c diff --git a/src/indicator-power.c b/src/indicator-power.c index 275e871..cb684f5 100644 --- a/src/indicator-power.c +++ b/src/indicator-power.c @@ -360,35 +360,94 @@ set_accessible_desc (IndicatorPower *self, priv->accessible_desc = g_strdup (desc); } +static const gchar * +get_icon_percentage_for_status (const gchar *status) +{ + + if (g_strcmp0 (status, "caution") == 0) + return "000"; + else if (g_strcmp0 (status, "low") == 0) + return "040"; + else if (g_strcmp0 (status, "good") == 0) + return "080"; + else + return "100"; +} + static GIcon* -get_device_icon (UpDeviceKind kind, - UpDeviceState state, - gchar *device_icon) +build_battery_icon (UpDeviceState state, + gchar *suffix_str) { GIcon *gicon; - if (kind == UP_DEVICE_KIND_BATTERY && - state == UP_DEVICE_STATE_CHARGING) + GString *filename; + gchar **iconnames; + + filename = g_string_new (NULL); + + if (state == UP_DEVICE_STATE_FULLY_CHARGED) { - GString *filename; - gchar **iconnames; - const gchar *kind_str; + g_string_append (filename, "battery-charged;"); + g_string_append (filename, "battery-full-charged-symbolic;"); + g_string_append (filename, "battery-full-charged;"); + g_string_append (filename, "gpm-battery-charged;"); + g_string_append (filename, "gpm-battery-100-charging;"); + } + else if (state == UP_DEVICE_STATE_CHARGING) + { + g_string_append (filename, "battery-000-charging;"); + g_string_append (filename, "battery-caution-charging-symbolic;"); + g_string_append (filename, "battery-caution-charging;"); + g_string_append (filename, "gpm-battery-000-charging;"); + } + else if (state == UP_DEVICE_STATE_DISCHARGING) + { + const gchar *percentage = get_icon_percentage_for_status (suffix_str); + g_string_append_printf (filename, "battery-%s;", suffix_str); + g_string_append_printf (filename, "battery-%s-symbolic;", suffix_str); + g_string_append_printf (filename, "battery-%s;", percentage); + g_string_append_printf (filename, "gpm-battery-%s;", percentage); + } - kind_str = up_device_kind_to_string (kind); - filename = g_string_new (NULL); - g_string_append_printf (filename, "battery-caution-charging-symbolic;"); - g_string_append_printf (filename, "gpm-%s-000-charging;", kind_str); - g_string_append_printf (filename, "battery-caution-charging;"); + iconnames = g_strsplit (filename->str, ";", -1); + gicon = g_themed_icon_new_from_names (iconnames, -1); - iconnames = g_strsplit (filename->str, ";", -1); - gicon = g_themed_icon_new_from_names (iconnames, -1); + g_strfreev (iconnames); + g_string_free (filename, TRUE); - g_strfreev (iconnames); - g_string_free (filename, TRUE); - } - else + return gicon; +} + +static GIcon* +get_device_icon (UpDeviceKind kind, + UpDeviceState state, + guint64 time_sec, + gchar *device_icon) +{ + GIcon *gicon; + + gicon = g_icon_new_for_string (device_icon, NULL); + + if (kind == UP_DEVICE_KIND_BATTERY && + (state == UP_DEVICE_STATE_FULLY_CHARGED || + state == UP_DEVICE_STATE_CHARGING || + state == UP_DEVICE_STATE_DISCHARGING)) { - gicon = g_icon_new_for_string (device_icon, NULL); + if (state == UP_DEVICE_STATE_FULLY_CHARGED || + state == UP_DEVICE_STATE_CHARGING) + { + gicon = build_battery_icon (state, NULL); + } + else if (state == UP_DEVICE_STATE_DISCHARGING) + { + if ((time_sec > 60 * 30) && /* more than 30 minutes left */ + (g_strrstr (device_icon, "000") || + g_strrstr (device_icon, "020") || + g_strrstr (device_icon, "caution"))) /* the icon is red */ + { + gicon = build_battery_icon (state, "low"); + } + } } return gicon; @@ -427,13 +486,13 @@ menu_add_device (GtkMenu *menu, &state, &time); + g_debug ("%s: got data from object %s", G_STRFUNC, object_path); + if (kind == UP_DEVICE_KIND_LINE_POWER) return; - g_debug ("%s: got data from object %s", G_STRFUNC, object_path); - /* Process the data */ - device_gicons = get_device_icon (kind, state, device_icon); + device_gicons = get_device_icon (kind, state, time, device_icon); icon = gtk_image_new_from_gicon (device_gicons, GTK_ICON_SIZE_SMALL_TOOLBAR); @@ -582,6 +641,11 @@ get_primary_device (GVariant *devices) g_debug ("%s: got data from object %s", G_STRFUNC, object_path); + /* Try to fix the case when we get a empty battery bay as a real battery */ + if (state == UP_DEVICE_STATE_UNKNOWN && + percentage == 0) + continue; + /* not battery */ if (kind != UP_DEVICE_KIND_BATTERY) continue; @@ -659,7 +723,7 @@ put_primary_device (IndicatorPower *self, g_debug ("%s: got data from object %s", G_STRFUNC, object_path); /* set icon */ - device_gicons = get_device_icon (kind, state, device_icon); + device_gicons = get_device_icon (kind, state, time, device_icon); gtk_image_set_from_gicon (priv->status_image, device_gicons, GTK_ICON_SIZE_LARGE_TOOLBAR); |