gnome-power-manager r3172 - in trunk: . src



Author: rhughes
Date: Fri Jan 23 10:54:07 2009
New Revision: 3172
URL: http://svn.gnome.org/viewvc/gnome-power-manager?rev=3172&view=rev

Log:
2009-01-23  Richard Hughes  <richard hughsie com>

* src/gpm-cell-unit.h:
* src/gpm-cell.c: (gpm_cell_refresh_hal_all), (gpm_cell_get_id):
We have to include capacity in the profile name as some vendors create
different sized batteries with the same serial number.
This break batteries that use the current voltage for the mAh to mWh
conversion when the design voltage is also invalid. In this case
use the reporting string as we don't care about units.
Patch from Stephen Gildea and Joe, many thanks.
Fixes #562576


Modified:
   trunk/ChangeLog
   trunk/src/gpm-cell-unit.h
   trunk/src/gpm-cell.c

Modified: trunk/src/gpm-cell-unit.h
==============================================================================
--- trunk/src/gpm-cell-unit.h	(original)
+++ trunk/src/gpm-cell-unit.h	Fri Jan 23 10:54:07 2009
@@ -47,6 +47,7 @@
 	guint		 charge_design;
 	guint		 charge_last_full;
 	guint		 charge_current;
+	guint		 reporting_design;
 	guint		 rate;
 	gfloat		 percentage;
 	guint		 time_charge;

Modified: trunk/src/gpm-cell.c
==============================================================================
--- trunk/src/gpm-cell.c	(original)
+++ trunk/src/gpm-cell.c	Fri Jan 23 10:54:07 2009
@@ -105,6 +105,8 @@
 
 	hal_device_get_uint (device, "battery.charge_level.design",
 				 &unit->charge_design, NULL);
+	hal_device_get_uint (device, "battery.reporting.design",
+				 &unit->reporting_design, NULL);
 	hal_device_get_uint (device, "battery.charge_level.last_full",
 				 &unit->charge_last_full, NULL);
 	hal_device_get_uint (device, "battery.charge_level.current",
@@ -181,12 +183,12 @@
 				capacity = 100.0f / (float) unit->charge_design;
 				unit->capacity = capacity * (float) unit->charge_last_full;
 				if (unit->capacity > 100) {
-					egg_debug ("rounding down capactity from "
+					egg_debug ("rounding down capacity from "
 						   "%i to 100", unit->capacity);
 					unit->capacity = 100;
 				}
 				if (unit->capacity < 0) {
-					egg_debug ("rounding up capactity from "
+					egg_debug ("rounding up capacity from "
 						   "%i to 0", unit->capacity);
 					unit->capacity = 0;
 				}
@@ -483,8 +485,8 @@
 		g_string_append (string, cell->priv->model);
 		g_string_append_c (string, '-');
 	}
-	if (cell->priv->unit.charge_design > 0) {
-		g_string_append_printf (string, "%i", cell->priv->unit.charge_design);
+	if (cell->priv->unit.reporting_design > 0) {
+		g_string_append_printf (string, "%i", cell->priv->unit.reporting_design);
 		g_string_append_c (string, '-');
 	}
 	if (cell->priv->serial != NULL && strlen (cell->priv->serial) > 2) {



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]