summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMichael Stapelberg <michael@stapelberg.de>2009-07-25 21:32:38 +0200
committerMichael Stapelberg <michael@stapelberg.de>2009-07-25 21:32:38 +0200
commitf8be2d1b81454be9f3205f3c908ea11e23f9c1e9 (patch)
tree5332d8cd5bd0c7cd9d572e6f8fe51f39bd988b30 /src
parent94911d4cc3741df95fef45e0cceed1ebc311404b (diff)
Return "no battery" instead of dying if a battery wasn’t found (Thanks Mirko)
Diffstat (limited to 'src')
-rw-r--r--src/general.c6
-rw-r--r--src/get_battery_info.c3
-rw-r--r--src/get_cpu_temperature.c3
-rw-r--r--src/get_wireless_info.c3
4 files changed, 10 insertions, 5 deletions
diff --git a/src/general.c b/src/general.c
index 62d242d..8d48f74 100644
--- a/src/general.c
+++ b/src/general.c
@@ -13,14 +13,16 @@
* Reads size bytes into the destination buffer from filename.
*
*/
-void slurp(char *filename, char *destination, int size) {
+bool slurp(char *filename, char *destination, int size) {
int fd;
if ((fd = open(filename, O_RDONLY)) == -1)
- die("Could not open \"%s\"\n", filename);
+ return false;
(void)read(fd, destination, size);
(void)close(fd);
+
+ return true;
}
/*
diff --git a/src/get_battery_info.c b/src/get_battery_info.c
index 8ac7743..41f2ff3 100644
--- a/src/get_battery_info.c
+++ b/src/get_battery_info.c
@@ -26,7 +26,8 @@ const char *get_battery_info(struct battery *bat) {
charging_status_t status = CS_DISCHARGING;
#if defined(LINUX)
- slurp(bat->path, buf, sizeof(buf));
+ if (!slurp(bat->path, buf, sizeof(buf)))
+ return "No battery";
for (walk = buf, last = buf; (walk-buf) < 1024; walk++) {
if (*walk == '\n') {
diff --git a/src/get_cpu_temperature.c b/src/get_cpu_temperature.c
index 09fbd25..ca6b9df 100644
--- a/src/get_cpu_temperature.c
+++ b/src/get_cpu_temperature.c
@@ -24,7 +24,8 @@ const char *get_cpu_temperature_info() {
#if defined(LINUX)
long int temp;
- slurp(thermal_zone, buf, sizeof(buf));
+ if (!slurp(thermal_zone, buf, sizeof(buf)))
+ die("Could not open \"%s\"\n", thermal_zone);
temp = strtol(buf, NULL, 10);
if (temp == LONG_MIN || temp == LONG_MAX || temp <= 0)
(void)snprintf(buf, sizeof(buf), "T: ? C");
diff --git a/src/get_wireless_info.c b/src/get_wireless_info.c
index 4d8d0b2..c257f56 100644
--- a/src/get_wireless_info.c
+++ b/src/get_wireless_info.c
@@ -20,7 +20,8 @@ const char *get_wireless_info() {
memset(buf, 0, sizeof(buf));
memset(part, 0, sizeof(part));
- slurp("/proc/net/wireless", buf, sizeof(buf));
+ if (!slurp("/proc/net/wireless", buf, sizeof(buf)))
+ die("Could not open \"/proc/net/wireless\"\n");
interfaces = skip_character(buf, '\n', 1) + 1;
while ((interfaces = skip_character(interfaces, '\n', 1)+1) < buf+strlen(buf)) {