diff options
-rw-r--r-- | x11/lxpanel/Makefile | 3 | ||||
-rw-r--r-- | x11/lxpanel/files/patch-src__plugins__batt__batt.c | 101 | ||||
-rw-r--r-- | x11/lxpanel/files/patch-src__plugins__batt__batt_sys.c | 271 | ||||
-rw-r--r-- | x11/lxpanel/files/patch-src__plugins__batt__batt_sys.h | 26 | ||||
-rw-r--r-- | x11/lxpanel/pkg-plist | 1 |
5 files changed, 401 insertions, 1 deletions
diff --git a/x11/lxpanel/Makefile b/x11/lxpanel/Makefile index b9ef093fbdd0..ee4538c267ce 100644 --- a/x11/lxpanel/Makefile +++ b/x11/lxpanel/Makefile @@ -7,6 +7,7 @@ PORTNAME= lxpanel PORTVERSION= 0.5.8 +PORTREVISION= 1 CATEGORIES= x11 MASTER_SITES= SF/lxde/LXPanel%20%28desktop%20panel%29/LXPanel%20${PORTVERSION} @@ -24,7 +25,7 @@ USE_GNOME= gnomehack gtk20 pkgconfig GNU_CONFIGURE= yes USE_AUTOTOOLS= automake:env CONFIGURE_ARGS= --prefix=${PREFIX} \ - --with-plugins=volume,deskno,kbled,xkb\ + --with-plugins=volume,deskno,kbled,xkb,batt\ CPPFLAGS="-I${LOCALBASE}/include" \ LDFLAGS="-L${LOCALBASE}/lib" CFLAGS+= -I${WRKSRC} diff --git a/x11/lxpanel/files/patch-src__plugins__batt__batt.c b/x11/lxpanel/files/patch-src__plugins__batt__batt.c new file mode 100644 index 000000000000..c8b41e632e70 --- /dev/null +++ b/x11/lxpanel/files/patch-src__plugins__batt__batt.c @@ -0,0 +1,101 @@ +--- src/plugins/batt/batt.c.o 2011-09-16 11:13:43.000000000 -0400 ++++ src/plugins/batt/batt.c 2011-09-16 11:36:21.000000000 -0400 +@@ -71,7 +71,7 @@ + GdkPixmap *pixmap; + GtkWidget *drawingArea; + int orientation; +- unsigned int alarmTime, ++ unsigned int alarmPercentage, + border, + height, + length, +@@ -120,15 +120,15 @@ + char tooltip[ 256 ]; + battery *b = lx_b->b; + /* unit: mW */ +- int rate = lx_b->b->present_rate; + + if (! lx_b->pixmap ) + return; + + /* no battery is found */ +- if( b == NULL ) ++ if( b == NULL || b->percentage < 0 ) + { + gtk_widget_set_tooltip_text( lx_b->drawingArea, _("No batteries found") ); ++ gdk_draw_rectangle(lx_b->pixmap, lx_b->bg, TRUE, 0, 0, lx_b->width, lx_b->height); + return; + } + +@@ -145,8 +145,8 @@ + isCharging = battery_is_charging ( b ); + + /* Consider running the alarm command */ +- if (! isCharging && rate && +- ( ( battery_get_remaining( b ) / 60 ) < lx_b->alarmTime ) ) ++ if (! isCharging && ++ ( ( b->percentage ) < lx_b->alarmPercentage ) ) + { + /* Shrug this should be done using glibs process functions */ + /* Alarms should not run concurrently; determine whether an alarm is +@@ -176,7 +176,7 @@ + int left_seconds = b->seconds -= 3600 * hours; + int minutes = left_seconds / 60; + snprintf(tooltip, 256, +- _("Battery: %d%% charged, %d:%02d until full"), ++ _("Battery: %d%% charged"), + lx_b->b->percentage, + hours, + minutes ); +@@ -187,10 +187,10 @@ + int left_seconds = b->seconds -= 3600 * hours; + int minutes = left_seconds / 60; + snprintf(tooltip, 256, +- _("Battery: %d%% charged, %d:%02d left"), ++ _("Battery: %d%% charged, %d:%02dh left"), + lx_b->b->percentage, +- hours, +- minutes ); ++ lx_b->b->minutes / 60, ++ lx_b->b->minutes % 60 ); + } else { + snprintf(tooltip, 256, + _("Battery: %d%% charged"), +@@ -374,7 +374,7 @@ + = lx_b->dischargingColor1 = lx_b->dischargingColor2 = NULL; + + /* Set default values for integers */ +- lx_b->alarmTime = 5; ++ lx_b->alarmPercentage = 10; + lx_b->requestedBorder = 1; + + line s; +@@ -403,8 +403,8 @@ + lx_b->dischargingColor1 = g_strdup(s.t[1]); + else if (!g_ascii_strcasecmp(s.t[0], "DischargingColor2")) + lx_b->dischargingColor2 = g_strdup(s.t[1]); +- else if (!g_ascii_strcasecmp(s.t[0], "AlarmTime")) +- lx_b->alarmTime = atoi(s.t[1]); ++ else if (!g_ascii_strcasecmp(s.t[0], "AlarmPercentage")) ++ lx_b->alarmPercentage = atoi(s.t[1]); + else if (!g_ascii_strcasecmp(s.t[0], "BorderWidth")) + lx_b->requestedBorder = atoi(s.t[1]); + else if (!g_ascii_strcasecmp(s.t[0], "Size")) { +@@ -580,7 +580,7 @@ + _("Hide if there is no battery"), &b->hide_if_no_battery, CONF_TYPE_BOOL, + #endif + _("Alarm command"), &b->alarmCommand, CONF_TYPE_STR, +- _("Alarm time (minutes left)"), &b->alarmTime, CONF_TYPE_INT, ++ _("Alarm percentage (percentage left)"), &b->alarmPercentage, CONF_TYPE_INT, + _("Background color"), &b->backgroundColor, CONF_TYPE_STR, + _("Charging color 1"), &b->chargingColor1, CONF_TYPE_STR, + _("Charging color 2"), &b->chargingColor2, CONF_TYPE_STR, +@@ -600,7 +600,7 @@ + + lxpanel_put_bool(fp, "HideIfNoBattery",lx_b->hide_if_no_battery); + lxpanel_put_str(fp, "AlarmCommand", lx_b->alarmCommand); +- lxpanel_put_int(fp, "AlarmTime", lx_b->alarmTime); ++ lxpanel_put_int(fp, "AlarmPercentage", lx_b->alarmPercentage); + lxpanel_put_str(fp, "BackgroundColor", lx_b->backgroundColor); + lxpanel_put_int(fp, "BorderWidth", lx_b->requestedBorder); + lxpanel_put_str(fp, "ChargingColor1", lx_b->chargingColor1); diff --git a/x11/lxpanel/files/patch-src__plugins__batt__batt_sys.c b/x11/lxpanel/files/patch-src__plugins__batt__batt_sys.c new file mode 100644 index 000000000000..4ed46c325bba --- /dev/null +++ b/x11/lxpanel/files/patch-src__plugins__batt__batt_sys.c @@ -0,0 +1,271 @@ +--- src/plugins/batt/batt_sys.c.o 2011-09-16 11:13:37.000000000 -0400 ++++ src/plugins/batt/batt_sys.c 2011-09-16 11:40:08.000000000 -0400 +@@ -46,15 +46,6 @@ + + void battery_reset( battery * b) { + b->type_battery = TRUE; +- b->capacity_unit = "mAh"; +- b->last_capacity_unit = -1; +- b->last_capacity = -1; +- b->voltage = -1; +- b->design_capacity_unit = -1; +- b->design_capacity = -1; +- b->remaining_energy = -1; +- b->remaining_capacity = -1; +- b->present_rate = -1; + b->state = NULL; + } + +@@ -79,7 +70,7 @@ + return n; + } + +-void battery_print(battery *b, int show_capacity) ++void battery_print(battery *b) + { + if ( b->type_battery ) + { +@@ -93,195 +84,65 @@ + b->seconds -= 3600 * b->hours; + b->minutes = b->seconds / 60; + b->seconds -= 60 * b->minutes; +- printf(", %02d:%02d:%02d%s", b->hours, b->minutes, b->seconds, b->poststr); ++ printf(", %02d:%02d:%02d", b->hours, b->minutes, b->seconds); + } else if (b->poststr != NULL) { + printf(", %s", b->poststr); + } + +- + printf("\n"); + +- if (show_capacity && b->design_capacity > 0) { +- if (b->last_capacity <= 100) { +- /* some broken systems just give a percentage here */ +- b->percentage = b->last_capacity; +- b->last_capacity = b->percentage * b->design_capacity / 100; +- } else { +- b->percentage = b->last_capacity * 100 / b->design_capacity; +- } +- if (b->percentage > 100) +- b->percentage = 100; +- +- printf ("%s %d: design capacity %d %s, last full capacity %d %s = %d%%\n", +- BATTERY_DESC, b->battery_num - 1, b->design_capacity, b->capacity_unit, b->last_capacity, b->capacity_unit, b->percentage); +- } + } + } + } + + + void battery_update( battery *b ) { +- int i = 0; +- const gchar *sys_list[] = { +- "current_now", +- "charge_now", +- "energy_now", +- "voltage_now", +- "voltage_min_design", +- "charge_full", +- "energy_full", +- "charge_full_design", +- "energy_full_design", +- "online", +- "status", +- "type", +- NULL +- }; +- const gchar *sys_file; ++ ++ char sstmp[ 100 ]; ++ int c, state; ++ size_t intlen = sizeof c; ++ ++ snprintf(sstmp, sizeof(sstmp), "hw.acpi.battery.life"); ++ sysctlbyname(sstmp, &c, &intlen, NULL, 0); ++ b->percentage = c; + + battery_reset(b); + +- while ( (sys_file = sys_list[i]) != NULL ) { +- +- gchar *file_content; +- GString *filename = g_string_new( ACPI_PATH_SYS_POWER_SUPPY ); +- g_string_append_printf ( filename, "/%s/%s", b->path, +- sys_file ); +- if ((file_content = parse_info_file(filename->str)) != NULL) { +- +- if ( strcmp("charge_now", sys_file ) == 0 ) { +- b->remaining_capacity = get_unit_value((gchar*) file_content) / 1000; +- if (!b->state) +- b->state = "available"; +- } +- else if ( strcmp("energy_now", sys_file ) == 0 ) { +- b->remaining_energy = get_unit_value((gchar*) file_content) / 1000; +- if (!b->state) +- b->state = "available"; +- } +- else if ( strcmp("current_now", sys_file ) == 0 ) { +- b->present_rate = get_unit_value((gchar*) file_content) / 1000; +- } +- else if ( strcmp("charge_full", sys_file ) == 0 ) { +- b->last_capacity = get_unit_value((gchar*) file_content) / 1000; +- if (!b->state) +- b->state = ("available"); +- } +- else if ( strcmp("energy_full", sys_file ) == 0 ) { +- b->last_capacity_unit = get_unit_value((gchar*) file_content) / 1000; +- if (!b->state) +- b->state = ("available"); +- } +- else if ( strcmp("charge_full_design", sys_file ) == 0 ) { +- b->design_capacity = get_unit_value((gchar*) file_content) / 1000; +- } +- else if ( strcmp("energy_full_design", sys_file ) == 0 ) { +- b->design_capacity_unit = get_unit_value((gchar*) file_content) / 1000; +- } +- else if ( strcmp("type", sys_file ) == 0 ) { +- b->type_battery = (strcasecmp(file_content, "battery") == 0 ); +- } +- else if ( ( strcmp("status", sys_file ) == 0 ) || strcmp("state", sys_file ) == 0 ) +- b->state = file_content; +- else if ( strcmp("voltage_now", sys_file ) == 0 ) { +- b->voltage = get_unit_value((gchar*) file_content) / 1000; +- } +- +- g_string_free( filename, TRUE ); +- } +- i++; +- } +- +- /* convert energy values (in mWh) to charge values (in mAh) if needed and possible */ +- if (b->last_capacity_unit != -1 && b->last_capacity == -1) { +- if (b->voltage != -1) { +- b->last_capacity = b->last_capacity_unit * 1000 / b->voltage; +- } else { +- b->last_capacity = b->last_capacity_unit; +- b->capacity_unit = "mWh"; +- } +- } +- if (b->design_capacity_unit != -1 && b->design_capacity == -1) { +- if (b->voltage != -1) { +- b->design_capacity = b->design_capacity_unit * 1000 / b->voltage; +- } else { +- b->design_capacity = b->design_capacity_unit; +- b->capacity_unit = "mWh"; +- } +- } +- if (b->remaining_energy != -1 && b->remaining_capacity == -1) { +- if (b->voltage != -1) { +- b->remaining_capacity = b->remaining_energy * 1000 / b->voltage; +- b->present_rate = b->present_rate * 1000 / b->voltage; +- } else { +- b->remaining_capacity = b->remaining_energy; +- } +- } +- if (b->last_capacity < MIN_CAPACITY) +- b->percentage = 0; +- else +- b->percentage = ((float) b->remaining_energy * 100.0) / (float) b->last_capacity_unit; +- +- if (b->percentage > 100) +- b->percentage = 100; ++ snprintf(sstmp, sizeof(sstmp), "hw.acpi.battery.state"); ++ sysctlbyname(sstmp, &state, &intlen, NULL, 0); + ++ switch(state) { ++ case BATT_FULL: ++ b->state = "Full"; ++ break; ++ case BATT_DISCHARGING: ++ b->state = "Discharging"; ++ break; ++ case BATT_CHARGING: ++ b->state = "Charging"; ++ break; ++ case BATT_CRITICAL: ++ b->state = "Critical"; ++ break; ++ case BATT_NONE: ++ b->state = "Unavailable"; ++ break; ++ default: ++ b->state = "Unknown"; ++ break; + +- +- if (b->present_rate == -1) { +- b->poststr = "rate information unavailable"; +- b->seconds = -1; +- } else if (!strcasecmp(b->state, "charging")) { +- if (b->present_rate > MIN_PRESENT_RATE) { +- b->seconds = 3600 * (b->last_capacity - b->remaining_capacity) / b->present_rate; +- b->poststr = " until charged"; +- } else { +- b->poststr = "charging at zero rate - will never fully charge."; +- b->seconds = -1; +- } +- } else if (!strcasecmp(b->state, "discharging")) { +- if (b->present_rate > MIN_PRESENT_RATE) { +- b->seconds = 3600 * b->remaining_capacity / b->present_rate; +- b->poststr = " remaining"; +- } else { +- b->poststr = "discharging at zero rate - will never fully discharge."; +- b->seconds = -1; +- } +- } else { +- b->poststr = NULL; +- b->seconds = -1; + } +- +-} + +-static battery* acpi_sys_get_battery_from_dir (const gchar *device_name ) { +- battery *b = battery_new(); +- b->path = g_strdup( device_name ); +- return b; ++ snprintf(sstmp, sizeof(sstmp), "hw.acpi.battery.time"); ++ sysctlbyname(sstmp, &c, &intlen, NULL, 0); ++ b->minutes = c; ++ b->seconds = c * 60; ++ + } + + battery *battery_get() { +- GError * error = NULL; +- const gchar *entry; +- GDir * dir = g_dir_open( ACPI_PATH_SYS_POWER_SUPPY, 0, &error ); +- battery *b = NULL; +- if ( dir == NULL ) +- { +- g_warning( "NO ACPI/sysfs support in kernel: %s", error->message ); +- return NULL; +- } +- while ( ( entry = g_dir_read_name (dir) ) != NULL ) +- { +- b = acpi_sys_get_battery_from_dir(entry); +- battery_update ( b ); +- if ( b->type_battery == TRUE ) +- break; +- /* ignore non-batteries */ +- else { +- g_free(b); +- b = NULL; +- } +- } +- g_dir_close( dir ); ++ battery *b = battery_new(); ++ battery_update(b); + return b; + } + +@@ -291,10 +152,3 @@ + strcasecmp( b->state, "Full" ) == 0 + || strcasecmp( b->state, "Charging" ) == 0 ); + } +- +-gint battery_get_remaining( battery *b ) +-{ +- return b->seconds; +-} +- +- diff --git a/x11/lxpanel/files/patch-src__plugins__batt__batt_sys.h b/x11/lxpanel/files/patch-src__plugins__batt__batt_sys.h new file mode 100644 index 000000000000..91e55dfbd18e --- /dev/null +++ b/x11/lxpanel/files/patch-src__plugins__batt__batt_sys.h @@ -0,0 +1,26 @@ +--- src/plugins/batt/batt_sys.h.o 2011-09-16 11:12:42.000000000 -0400 ++++ src/plugins/batt/batt_sys.h 2011-09-16 11:39:12.000000000 -0400 +@@ -23,6 +23,12 @@ + #ifndef BATT_SYS_H + #define BATT_SYS_H + ++/* The states a battery can have */ ++#define BATT_FULL 0 ++#define BATT_DISCHARGING 1 ++#define BATT_CHARGING 2 ++#define BATT_CRITICAL 5 ++#define BATT_NONE 7 + + #define BUF_SIZE 1024 + #define ACPI_PATH_SYS_POWER_SUPPY "/sys/class/power_supply" +@@ -53,8 +59,8 @@ + + battery *battery_get(); + void battery_update( battery *b ); +-void battery_print(battery *b, int show_capacity); ++void battery_print(battery *b); ++void battery_reset(battery *b); + gboolean battery_is_charging( battery *b ); +-gint battery_get_remaining( battery *b ); + + #endif diff --git a/x11/lxpanel/pkg-plist b/x11/lxpanel/pkg-plist index 397af789ba59..551ae2247ca8 100644 --- a/x11/lxpanel/pkg-plist +++ b/x11/lxpanel/pkg-plist @@ -1,5 +1,6 @@ bin/lxpanel bin/lxpanelctl +lib/lxpanel/plugins/batt.so lib/lxpanel/plugins/deskno.so lib/lxpanel/plugins/kbled.so lib/lxpanel/plugins/volume.so |