X-Git-Url: https://git.xinqibao.xyz/slstatus.git/blobdiff_plain/720328cef9a9d81d2bd876bdf89103782b9cab91..7710c9ed8514767af3d1fdc86d0e64d7621fc5d9:/slstatus.c?ds=inline diff --git a/slstatus.c b/slstatus.c index da4b237..55e638f 100644 --- a/slstatus.c +++ b/slstatus.c @@ -1,6 +1,7 @@ /* See LICENSE file for copyright and license details. */ #include +#include #include #include #include @@ -26,6 +27,9 @@ #include "strlcat.h" #include "strlcpy.h" +#include "concat.h" + +char concat[]; struct arg { char *(*func)(); @@ -91,35 +95,24 @@ static char * battery_perc(const char *battery) { int now, full, perc; - char batterynowfile[64]; - char batteryfullfile[64]; FILE *fp; - strlcpy(batterynowfile, BATTERY_PATH, sizeof(batterynowfile)); - strlcat(batterynowfile, battery, sizeof(batterynowfile)); - strlcat(batterynowfile, "/", sizeof(batterynowfile)); - strlcat(batterynowfile, BATTERY_NOW, sizeof(batterynowfile)); - - strlcpy(batteryfullfile, BATTERY_PATH, sizeof(batteryfullfile)); - strlcat(batteryfullfile, battery, sizeof(batteryfullfile)); - strlcat(batteryfullfile, "/", sizeof(batteryfullfile)); - strlcat(batteryfullfile, BATTERY_FULL, sizeof(batteryfullfile)); - - fp = fopen(batterynowfile, "r"); - if (fp == NULL ) { - fprintf(stderr, "Error opening battery file: %s: %s\n", - batterynowfile, - strerror(errno)); + ccat(4, BATTERY_PATH, battery, "/", BATTERY_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); - fp = fopen(batteryfullfile, "r"); + ccat(4, BATTERY_PATH, battery, "/", BATTERY_FULL); + + fp = fopen(concat, "r"); if (fp == NULL) { - fprintf(stderr, "Error opening battery file: %s\n", - strerror(errno)); + warn("Error opening battery file: %s", concat); return smprintf(UNKNOWN_STR); } @@ -139,8 +132,7 @@ cpu_perc(void) FILE *fp = fopen("/proc/stat","r"); if (fp == NULL) { - fprintf(stderr, "Error opening stat file: %s\n", - strerror(errno)); + warn("Error opening stat file"); return smprintf(UNKNOWN_STR); } @@ -151,8 +143,7 @@ cpu_perc(void) fp = fopen("/proc/stat","r"); if (fp == NULL) { - fprintf(stderr, "Error opening stat file: %s\n", - strerror(errno)); + warn("Error opening stat file"); return smprintf(UNKNOWN_STR); } @@ -181,8 +172,7 @@ disk_free(const char *mountpoint) struct statvfs fs; if (statvfs(mountpoint, &fs) < 0) { - fprintf(stderr, "Could not get filesystem info: %s\n", - strerror(errno)); + warn("Could not get filesystem info"); return smprintf(UNKNOWN_STR); } return smprintf("%f", (float)fs.f_bsize * (float)fs.f_bfree / 1024 / 1024 / 1024); @@ -195,8 +185,7 @@ disk_perc(const char *mountpoint) struct statvfs fs; if (statvfs(mountpoint, &fs) < 0) { - fprintf(stderr, "Could not get filesystem info: %s\n", - strerror(errno)); + warn("Could not get filesystem info"); return smprintf(UNKNOWN_STR); } @@ -210,8 +199,7 @@ disk_total(const char *mountpoint) struct statvfs fs; if (statvfs(mountpoint, &fs) < 0) { - fprintf(stderr, "Could not get filesystem info: %s\n", - strerror(errno)); + warn("Could not get filesystem info"); return smprintf(UNKNOWN_STR); } @@ -224,8 +212,7 @@ disk_used(const char *mountpoint) struct statvfs fs; if (statvfs(mountpoint, &fs) < 0) { - fprintf(stderr, "Could not get filesystem info: %s\n", - strerror(errno)); + warn("Could not get filesystem info"); return smprintf(UNKNOWN_STR); } @@ -239,8 +226,7 @@ entropy(void) FILE *fp = fopen("/proc/sys/kernel/random/entropy_avail", "r"); if (fp == NULL) { - fprintf(stderr, "Could not open entropy file: %s\n", - strerror(errno)); + warn("Could not open entropy file"); return smprintf(UNKNOWN_STR); } @@ -262,8 +248,7 @@ hostname(void) FILE *fp = fopen("/proc/sys/kernel/hostname", "r"); if (fp == NULL) { - fprintf(stderr, "Could not open hostname file: %s\n", - strerror(errno)); + warn("Could not open hostname file"); return smprintf(UNKNOWN_STR); } @@ -283,8 +268,7 @@ ip(const char *interface) char host[NI_MAXHOST]; if (getifaddrs(&ifaddr) == -1) { - fprintf(stderr, "Error getting IP address: %s\n", - strerror(errno)); + warn("Error getting IP address"); return smprintf(UNKNOWN_STR); } @@ -298,7 +282,7 @@ ip(const char *interface) if ((strcmp(ifa->ifa_name, interface) == 0) && (ifa->ifa_addr->sa_family == AF_INET)) { if (s != 0) { - fprintf(stderr, "Error getting IP address.\n"); + warnx("Error getting IP address."); return smprintf(UNKNOWN_STR); } return smprintf("%s", host); @@ -317,7 +301,7 @@ load_avg(void) double avgs[3]; if (getloadavg(avgs, 3) < 0) { - fprintf(stderr, "Error getting load avg.\n"); + warnx("Error getting load avg."); return smprintf(UNKNOWN_STR); } @@ -331,8 +315,7 @@ ram_free(void) FILE *fp = fopen("/proc/meminfo", "r"); if (fp == NULL) { - fprintf(stderr, "Error opening meminfo file: %s\n", - strerror(errno)); + warn("Error opening meminfo file"); return smprintf(UNKNOWN_STR); } @@ -349,8 +332,7 @@ ram_perc(void) FILE *fp = fopen("/proc/meminfo", "r"); if (fp == NULL) { - fprintf(stderr, "Error opening meminfo file: %s\n", - strerror(errno)); + warn("Error opening meminfo file"); return smprintf(UNKNOWN_STR); } @@ -371,8 +353,7 @@ ram_total(void) FILE *fp = fopen("/proc/meminfo", "r"); if (fp == NULL) { - fprintf(stderr, "Error opening meminfo file: %s\n", - strerror(errno)); + warn("Error opening meminfo file"); return smprintf(UNKNOWN_STR); } @@ -388,8 +369,7 @@ ram_used(void) FILE *fp = fopen("/proc/meminfo", "r"); if (fp == NULL) { - fprintf(stderr, "Error opening meminfo file: %s\n", - strerror(errno)); + warn("Error opening meminfo file"); return smprintf(UNKNOWN_STR); } @@ -411,8 +391,7 @@ run_command(const char* command) char buffer[64]; if (fp == NULL) { - fprintf(stderr, "Could not get command output for: %s: %s\n", - command, strerror(errno)); + warn("Could not get command output for: %s", command); return smprintf(UNKNOWN_STR); } @@ -436,8 +415,7 @@ temp(const char *file) FILE *fp = fopen(file, "r"); if (fp == NULL) { - fprintf(stderr, "Could not open temperature file: %s\n", - strerror(errno)); + warn("Could not open temperature file"); return smprintf(UNKNOWN_STR); } @@ -469,8 +447,7 @@ username(void) if (pw == NULL) return smprintf("%s", pw->pw_name); - fprintf(stderr, "Could not get username: %s\n", - strerror(errno)); + warn("Could not get username"); return smprintf(UNKNOWN_STR); } @@ -490,17 +467,17 @@ vol_perc(const char *snd_card) snd_mixer_selem_id_t *s_elem; snd_mixer_open(&handle, 0); - snd_mixer_attach(handle, snd_card); + snd_mixer_attach(handle, "default"); snd_mixer_selem_register(handle, NULL, NULL); snd_mixer_load(handle); snd_mixer_selem_id_malloc(&s_elem); - snd_mixer_selem_id_set_name(s_elem, "Master"); + snd_mixer_selem_id_set_name(s_elem, snd_card); elem = snd_mixer_find_selem(handle, s_elem); if (elem == NULL) { snd_mixer_selem_id_free(s_elem); snd_mixer_close(handle); - perror("alsa error: "); + perror("alsa error"); return smprintf(UNKNOWN_STR); } @@ -520,20 +497,15 @@ wifi_perc(const char *wificard) int strength; char buf[255]; char *datastart; - char path[64]; char status[5]; - char needle[strlen(wificard)+2]; FILE *fp; - strlcpy(path, "/sys/class/net/", sizeof(path)); - strlcat(path, wificard, sizeof(path)); - strlcat(path, "/operstate", sizeof(path)); + ccat(3, "/sys/class/net", wificard, "/operstate"); - fp = fopen(path, "r"); + fp = fopen(concat, "r"); if(fp == NULL) { - fprintf(stderr, "Error opening wifi operstate file: %s\n", - strerror(errno)); + warn("Error opening wifi operstate file"); return smprintf(UNKNOWN_STR); } @@ -544,18 +516,16 @@ wifi_perc(const char *wificard) fp = fopen("/proc/net/wireless", "r"); if (fp == NULL) { - fprintf(stderr, "Error opening wireless file: %s\n", - strerror(errno)); + warn("Error opening wireless file"); return smprintf(UNKNOWN_STR); } - strlcpy(needle, wificard, sizeof(needle)); - strlcat(needle, ":", sizeof(needle)); + ccat(2, wificard, ":"); fgets(buf, sizeof(buf), fp); fgets(buf, sizeof(buf), fp); fgets(buf, sizeof(buf), fp); - datastart = strstr(buf, needle); + datastart = strstr(buf, concat); if (datastart != NULL) { datastart = strstr(buf, ":"); sscanf(datastart + 1, " %*d %d %*d %*d %*d %*d %*d %*d %*d %*d", &strength); @@ -576,14 +546,12 @@ wifi_essid(const char *wificard) wreq.u.essid.length = IW_ESSID_MAX_SIZE+1; sprintf(wreq.ifr_name, wificard); if(sockfd == -1) { - fprintf(stderr, "Cannot open socket for interface: %s: %s\n", - wificard, strerror(errno)); + warn("Cannot open socket for interface: %s", wificard); return smprintf(UNKNOWN_STR); } wreq.u.essid.pointer = id; if (ioctl(sockfd,SIOCGIWESSID, &wreq) == -1) { - fprintf(stderr, "Get ESSID ioctl failed for interface %s: %s\n", - wificard, strerror(errno)); + warn("Get ESSID ioctl failed for interface %s", wificard); return smprintf(UNKNOWN_STR); } @@ -614,7 +582,7 @@ main(void) element = smprintf(argument.format, res); if (element == NULL) { element = smprintf(UNKNOWN_STR); - fprintf(stderr, "Failed to format output.\n"); + warnx("Failed to format output."); } strlcat(status_string, element, sizeof(status_string)); free(res);