/* alsa sound */
#define ALSA_CHANNEL "Master"
-/* battery */
-#define BATTERY_PATH "/sys/class/power_supply/"
-#define BATTERY_NOW "energy_now"
-#define BATTERY_FULL "energy_full_design"
-
/* how often to update the statusbar (min value == 1) */
#define UPDATE_INTERVAL 1
static char *
battery_perc(const char *battery)
{
- int now, full, perc;
+ int now, full;
FILE *fp;
- ccat(4, BATTERY_PATH, battery, "/", BATTERY_NOW);
-
+ ccat(3, "/sys/class/power_supply/", battery, "/energy_now");
fp = fopen(concat, "r");
if (fp == NULL) {
- warn("Error opening battery file: %s", concat);
- return smprintf(UNKNOWN_STR);
+ ccat(4, "/sys/class/power_supply/", battery, "/charge_now");
+ fp = fopen(concat, "r");
+ if (fp == NULL) {
+ warn("Error opening battery file: %s", concat);
+ return smprintf(UNKNOWN_STR);
+ }
}
-
fscanf(fp, "%i", &now);
fclose(fp);
- ccat(4, BATTERY_PATH, battery, "/", BATTERY_FULL);
-
+ ccat(3, "/sys/class/power_supply/", battery, "/energy_full");
fp = fopen(concat, "r");
if (fp == NULL) {
- warn("Error opening battery file: %s", concat);
- return smprintf(UNKNOWN_STR);
+ ccat(4, "/sys/class/power_supply/", battery, "/charge_full");
+ fp = fopen(concat, "r");
+ if (fp == NULL) {
+ warn("Error opening battery file: %s", concat);
+ return smprintf(UNKNOWN_STR);
+ }
}
-
fscanf(fp, "%i", &full);
fclose(fp);
- perc = now / (full / 100);
-
- return smprintf("%d%%", perc);
+ return smprintf("%d%%", now / (full / 100));
}
static char *