diff options
Diffstat (limited to 'desktop/lxpanel/patches')
2 files changed, 180 insertions, 0 deletions
diff --git a/desktop/lxpanel/patches/0001-Fix-battery-selection-it-appears-incompatible-with-0.patch b/desktop/lxpanel/patches/0001-Fix-battery-selection-it-appears-incompatible-with-0.patch new file mode 100644 index 0000000000000..6210cf8d8bf63 --- /dev/null +++ b/desktop/lxpanel/patches/0001-Fix-battery-selection-it-appears-incompatible-with-0.patch @@ -0,0 +1,115 @@ +From ad0022eb8b1524b18d2b512d7dd8d2920c0f8dab Mon Sep 17 00:00:00 2001 +From: Andriy Grytsenko <andrej@rep.kiev.ua> +Date: Fri, 25 Nov 2016 01:18:47 +0200 +Subject: [PATCH 1/2] Fix battery selection, it appears incompatible with 0.7.2 + behavior. + +See https://bugs.debian.org/845555 +--- + ChangeLog | 2 ++ + TODO | 2 +- + plugins/batt/batt_sys.c | 30 +++++++++++++++--------------- + 3 files changed, 18 insertions(+), 16 deletions(-) + +diff --git a/ChangeLog b/ChangeLog +index a21a14e..0abe16b 100644 +--- a/ChangeLog ++++ b/ChangeLog +@@ -1,3 +1,5 @@ ++* Fixed battery selection, it appears incompatible with 0.7.2 behavior. ++ + 0.9.1 + ------------------------------------------------------------------------- + * Fixed build failure without ALSA. +diff --git a/TODO b/TODO +index 965b17c..8d9f91f 100644 +--- a/TODO ++++ b/TODO +@@ -17,7 +17,7 @@ + * decide 'netstat' vs 'netstatus' + * optional libnotify support (useful for battery and volume plugins) + * pull improvements from Raspbian +-* add Most Recent support into 'menu' plugin ++* add Most Recent support into 'menu' plugin (option: ones not by Run too) + * check and use weather-* standard themed icons for weather plugin + * "Remove this Launch Button" option in launchbar context menu + * 'usb-unmount' plugin +diff --git a/plugins/batt/batt_sys.c b/plugins/batt/batt_sys.c +index 154bd3d..2482c6f 100644 +--- a/plugins/batt/batt_sys.c ++++ b/plugins/batt/batt_sys.c +@@ -4,6 +4,7 @@ + * Copyright 2009 Juergen Hötzel <juergen@archlinux.org> + * 2015 Henry Gebhardt <hsggebhardt@googlemail.com> + * 2015 Stanislav Kozina, Ersin <xersin@users.sf.net> ++ * 2016 Andriy Grytsenko <andrej@rep.kiev.ua> + * + * Parts shameless stolen and glibified from acpi package + * Copyright (C) 2001 Grahame Bowland <grahame@angrygoats.net> +@@ -295,15 +296,8 @@ battery *battery_get(int battery_number) { + const gchar *entry; + gchar *batt_name = NULL; + gchar *batt_path = NULL; +- GDir * dir = g_dir_open( ACPI_PATH_SYS_POWER_SUPPLY, 0, &error ); ++ GDir * dir; + battery *b = NULL; +- int i; +- +- if ( dir == NULL ) +- { +- g_warning( "NO ACPI/sysfs support in kernel: %s", error->message ); +- return NULL; +- } + + /* Try the expected path in sysfs first */ + batt_name = g_strdup_printf(ACPI_BATTERY_DEVICE_NAME "%d", battery_number); +@@ -324,13 +318,20 @@ battery *battery_get(int battery_number) { + g_free(batt_path); + + if (b != NULL) +- goto done; ++ return b; + + /* + * We didn't find the expected path in sysfs. +- * Walk the dir and blindly return n-th entry. ++ * Walk the dir and return any battery. + */ +- i = 0; ++ dir = g_dir_open( ACPI_PATH_SYS_POWER_SUPPLY, 0, &error ); ++ if ( dir == NULL ) ++ { ++ g_warning( "NO ACPI/sysfs support in kernel: %s", error->message ); ++ g_error_free(error); ++ return NULL; ++ } ++ + while ( ( entry = g_dir_read_name (dir) ) != NULL ) + { + b = battery_new(); +@@ -339,9 +340,7 @@ battery *battery_get(int battery_number) { + + /* We're looking for a battery with the selected ID */ + if (b->type_battery == TRUE) { +- if (i == battery_number) +- break; +- i++; ++ break; + } + battery_free(b); + b = NULL; +@@ -349,9 +348,10 @@ battery *battery_get(int battery_number) { + if (b != NULL) + g_warning( "Battery entry " ACPI_BATTERY_DEVICE_NAME "%d not found, using %s", + battery_number, b->path); ++ // FIXME: update config? + else + g_warning( "Battery %d not found", battery_number ); +-done: ++ + g_dir_close( dir ); + return b; + } +-- +2.11.0 + diff --git a/desktop/lxpanel/patches/0002-Fix-battery-percentage-calculations-if-charge-isn-t-.patch b/desktop/lxpanel/patches/0002-Fix-battery-percentage-calculations-if-charge-isn-t-.patch new file mode 100644 index 0000000000000..3d3bf993c08f6 --- /dev/null +++ b/desktop/lxpanel/patches/0002-Fix-battery-percentage-calculations-if-charge-isn-t-.patch @@ -0,0 +1,65 @@ +From 138ff9b22b45192a3b020ebbbed04e9060470a66 Mon Sep 17 00:00:00 2001 +From: Andriy Grytsenko <andrej@rep.kiev.ua> +Date: Fri, 25 Nov 2016 02:06:39 +0200 +Subject: [PATCH 2/2] Fix battery percentage calculations if charge isn't + available but energy is. + +Should fix https://bugs.debian.org/845555 bug. +--- + ChangeLog | 4 +++- + plugins/batt/batt_sys.c | 17 ++++++++++------- + 2 files changed, 13 insertions(+), 8 deletions(-) + +diff --git a/ChangeLog b/ChangeLog +index 0abe16b..f4e4f61 100644 +--- a/ChangeLog ++++ b/ChangeLog +@@ -1,4 +1,6 @@ +-* Fixed battery selection, it appears incompatible with 0.7.2 behavior. ++* Fixed battery selection if battery detached but another is available. ++* Fixed battery percentage calculations if charge isn't available but ++ energy is, it appears broken in 0.9.0. + + 0.9.1 + ------------------------------------------------------------------------- +diff --git a/plugins/batt/batt_sys.c b/plugins/batt/batt_sys.c +index 2482c6f..bd01e08 100644 +--- a/plugins/batt/batt_sys.c ++++ b/plugins/batt/batt_sys.c +@@ -167,6 +167,7 @@ static gboolean battery_inserted(gchar* path) + battery* battery_update(battery *b) + { + gchar *gctmp; ++ int promille; + + if (b == NULL) + return NULL; +@@ -253,16 +254,18 @@ battery* battery_update(battery *b) + } + #endif + +- if (b->charge_full < MIN_CAPACITY) +- b->percentage = 0; +- else { +- int promille = (b->charge_now * 1000) / b->charge_full; +- b->percentage = (promille + 5) / 10; /* round properly */ +- } ++ if (b->charge_now != -1 && b->charge_full != -1) ++ promille = (b->charge_now * 1000) / b->charge_full; ++ else if (b->energy_full != -1 && b->energy_now != -1) ++ /* no charge data, let try energy instead */ ++ promille = (b->energy_now * 1000) / b->energy_full; ++ else ++ promille = 0; ++ ++ b->percentage = (promille + 5) / 10; /* round properly */ + if (b->percentage > 100) + b->percentage = 100; + +- + if (b->current_now == -1) { + //b->poststr = "rate information unavailable"; + b->seconds = -1; +-- +2.11.0 + |