Add hide_seconds option
Patch status: merged
Patch by Iakov Davydov
Long description:
fixes: #1134
To apply this patch, use:
curl http://cr.i3wm.org/patch/405/raw.patch | git am
b/i3status.c
17 |
@@ -246,6 +246,7 @@ int main(int argc, char *argv[]) { |
18 |
CFG_STR("threshold_type", "time", CFGF_NONE), |
19 |
CFG_BOOL("last_full_capacity", false, CFGF_NONE), |
20 |
CFG_BOOL("integer_battery_capacity", false, CFGF_NONE), |
21 |
+ CFG_BOOL("hide_seconds", false, CFGF_NONE), |
22 |
CFG_CUSTOM_COLOR_OPTS, |
23 |
CFG_END() |
24 |
}; |
25 |
@@ -480,7 +481,7 @@ int main(int argc, char *argv[]) { |
26 |
|
27 |
CASE_SEC_TITLE("battery") { |
28 |
SEC_OPEN_MAP("battery"); |
29 |
- print_battery_info(json_gen, buffer, atoi(title), cfg_getstr(sec, "path"), cfg_getstr(sec, "format"), cfg_getstr(sec, "format_down"), cfg_getint(sec, "low_threshold"), cfg_getstr(sec, "threshold_type"), cfg_getbool(sec, "last_full_capacity"), cfg_getbool(sec, "integer_battery_capacity")); |
30 |
+ print_battery_info(json_gen, buffer, atoi(title), cfg_getstr(sec, "path"), cfg_getstr(sec, "format"), cfg_getstr(sec, "format_down"), cfg_getint(sec, "low_threshold"), cfg_getstr(sec, "threshold_type"), cfg_getbool(sec, "last_full_capacity"), cfg_getbool(sec, "integer_battery_capacity"), cfg_getbool(sec, "hide_seconds")); |
31 |
SEC_CLOSE_MAP; |
32 |
} |
33 |
|
b/include/i3status.h
38 |
@@ -146,7 +146,7 @@ void set_timezone(const char *tz); |
39 |
|
40 |
void print_ipv6_info(yajl_gen json_gen, char *buffer, const char *format_up, const char *format_down); |
41 |
void print_disk_info(yajl_gen json_gen, char *buffer, const char *path, const char *format, const char *prefix_type); |
42 |
-void print_battery_info(yajl_gen json_gen, char *buffer, int number, const char *path, const char *format, const char *format_down, int low_threshold, char *threshold_type, bool last_full_capacity, bool integer_battery_capacity); |
43 |
+void print_battery_info(yajl_gen json_gen, char *buffer, int number, const char *path, const char *format, const char *format_down, int low_threshold, char *threshold_type, bool last_full_capacity, bool integer_battery_capacity, bool hide_seconds); |
44 |
void print_time(yajl_gen json_gen, char *buffer, const char *format, const char *tz, time_t t); |
45 |
void print_ddate(yajl_gen json_gen, char *buffer, const char *format, time_t t); |
46 |
const char *get_ip_addr(); |
b/man/i3status.man
51 |
@@ -251,7 +251,8 @@ estimated to be empty. If you want to use the last full capacity instead of the |
52 |
design capacity (when using the design capacity, it may happen that your |
53 |
battery is at 23% when fully charged because it’s old. In general, I want to |
54 |
see it this way, because it tells me how worn off my battery is.), just specify |
55 |
-+last_full_capacity = true+. |
56 |
++last_full_capacity = true+. You can hide seconds in the remaining time and |
57 |
+empty time estimations by setting +hide_seconds = true+. |
58 |
|
59 |
If you want the battery percentage to be shown without decimals, add |
60 |
+integer_battery_capacity = true+. |
b/src/print_battery_info.c
65 |
@@ -30,7 +30,7 @@ |
66 |
* worn off your battery is. |
67 |
* |
68 |
*/ |
69 |
-void print_battery_info(yajl_gen json_gen, char *buffer, int number, const char *path, const char *format, const char *format_down, int low_threshold, char *threshold_type, bool last_full_capacity, bool integer_battery_capacity) { |
70 |
+void print_battery_info(yajl_gen json_gen, char *buffer, int number, const char *path, const char *format, const char *format_down, int low_threshold, char *threshold_type, bool last_full_capacity, bool integer_battery_capacity, bool hide_seconds) { |
71 |
time_t empty_time; |
72 |
struct tm *empty_tm; |
73 |
char buf[1024]; |
74 |
@@ -166,15 +166,23 @@ void print_battery_info(yajl_gen json_gen, char *buffer, int number, const char |
75 |
} |
76 |
} |
77 |
|
78 |
- (void)snprintf(remainingbuf, sizeof(remainingbuf), "%02d:%02d:%02d", |
79 |
- max(hours, 0), max(minutes, 0), max(seconds, 0)); |
80 |
+ if (hide_seconds) |
81 |
+ (void)snprintf(remainingbuf, sizeof(remainingbuf), "%02d:%02d", |
82 |
+ max(hours, 0), max(minutes, 0)); |
83 |
+ else |
84 |
+ (void)snprintf(remainingbuf, sizeof(remainingbuf), "%02d:%02d:%02d", |
85 |
+ max(hours, 0), max(minutes, 0), max(seconds, 0)); |
86 |
|
87 |
empty_time = time(NULL); |
88 |
empty_time += seconds_remaining; |
89 |
empty_tm = localtime(&empty_time); |
90 |
|
91 |
- (void)snprintf(emptytimebuf, sizeof(emptytimebuf), "%02d:%02d:%02d", |
92 |
- max(empty_tm->tm_hour, 0), max(empty_tm->tm_min, 0), max(empty_tm->tm_sec, 0)); |
93 |
+ if (hide_seconds) |
94 |
+ (void)snprintf(emptytimebuf, sizeof(emptytimebuf), "%02d:%02d", |
95 |
+ max(empty_tm->tm_hour, 0), max(empty_tm->tm_min, 0)); |
96 |
+ else |
97 |
+ (void)snprintf(emptytimebuf, sizeof(emptytimebuf), "%02d:%02d:%02d", |
98 |
+ max(empty_tm->tm_hour, 0), max(empty_tm->tm_min, 0), max(empty_tm->tm_sec, 0)); |
99 |
|
100 |
(void)snprintf(consumptionbuf, sizeof(consumptionbuf), "%1.2fW", |
101 |
((float)present_rate / 1000.0 / 1000.0)); |