fixed issue 84 with battery git-svn-id: http://tint2.googlecode.com/svn/trunk@75 121b4492-b84c-0410-8b4c-0d4edfb3f3cc
lorthiois@bbsoft.fr lorthiois@bbsoft.fr@121b4492-b84c-0410-8b4c-0d4edfb3f3cc
3 files changed,
32 insertions(+),
5 deletions(-)
M
src/battery/battery.c
→
src/battery/battery.c
@@ -54,27 +54,27 @@ if(fp != NULL) {
fgets(tmp, sizeof tmp, fp); energy_now = atoi(tmp); fclose(fp); - } else printf("ERROR: battery applet can't open energy_now\n"); + } fp = fopen("/sys/class/power_supply/BAT0/energy_full", "r"); if(fp != NULL) { fgets(tmp, sizeof tmp, fp); energy_full = atoi(tmp); fclose(fp); - } else printf("ERROR: battery applet can't open energy_full\n"); + } fp = fopen("/sys/class/power_supply/BAT0/current_now", "r"); if(fp != NULL) { fgets(tmp, sizeof tmp, fp); current_now = atoi(tmp); fclose(fp); - } else printf("ERROR: battery applet can't open current_now\n"); + } fp = fopen("/sys/class/power_supply/BAT0/status", "r"); if(fp != NULL) { fgets(tmp, sizeof tmp, fp); fclose(fp); - } else printf("ERROR: battery applet can't open status"); + } data->state = BATTERY_UNKNOWN; if(strcasecmp(tmp, "Charging\n")==0) data->state = BATTERY_CHARGING;@@ -109,9 +109,11 @@ }
data->percentage = new_percentage; } + void init_battery() { + FILE *fp; Panel *panel; Battery *battery; int i, bat_percentage_height, bat_percentage_height_ink, bat_time_height, bat_time_height_ink;@@ -126,6 +128,30 @@ battery->area._draw_foreground = draw_battery;
battery->area._resize = resize_battery; if (!battery->area.on_screen) continue; + if((fp = fopen("/sys/class/power_supply/BAT0/energy_now", "r")) == NULL) { + fprintf(stderr, "ERROR: battery applet can't open energy_now\n"); + panel->battery.area.on_screen = 0; + continue; + } + fclose(fp); + if((fp = fopen("/sys/class/power_supply/BAT0/energy_full", "r")) == NULL) { + fprintf(stderr, "ERROR: battery applet can't open energy_full\n"); + panel->battery.area.on_screen = 0; + continue; + } + fclose(fp); + if((fp = fopen("/sys/class/power_supply/BAT0/current_now", "r")) == NULL) { + fprintf(stderr, "ERROR: battery applet can't open current_now\n"); + panel->battery.area.on_screen = 0; + continue; + } + fclose(fp); + if((fp = fopen("/sys/class/power_supply/BAT0/status", "r")) == NULL) { + fprintf(stderr, "ERROR: battery applet can't open status"); + panel->battery.area.on_screen = 0; + continue; + } + fclose(fp); battery->area.posy = panel->area.pix.border.width + panel->area.paddingy; battery->area.height = panel->area.height - (2 * battery->area.posy);
M
src/tint.c
→
src/tint.c
@@ -468,7 +468,8 @@
if (abs(stv.tv_sec - time_clock.tv_sec) < time_precision) return; // update battery - update_battery(&battery_state); + if (panel1[0].battery.area.on_screen) + update_battery(&battery_state); // update clock time_clock.tv_sec = stv.tv_sec;