X-Git-Url: https://git.xinqibao.xyz/slstatus.git/blobdiff_plain/a8d5bde6a52ed5828ff217c8276673720f897c31..093f39df23da146cc88e9987469081e5b3016cfe:/slstatus.c?ds=sidebyside diff --git a/slstatus.c b/slstatus.c index c56efd9..505f25d 100644 --- a/slstatus.c +++ b/slstatus.c @@ -6,6 +6,7 @@ #include #include #include +#include #include #include #include @@ -13,10 +14,11 @@ #include #include #include -#include +#include #include #include #include +#include #include #include #include @@ -160,6 +162,7 @@ datetime(const char *timeformat) setlocale(LC_TIME, ""); if(!strftime(buf, bufsize, timeformat, localtime(&tm))) { setlocale(LC_TIME, "C"); + free(buf); fprintf(stderr, "Strftime failed.\n"); return smprintf("n/a"); } @@ -452,6 +455,7 @@ ram_used(const char *null) char * run_command(const char* command) { + int good; FILE *fp; char buffer[64]; @@ -468,7 +472,15 @@ run_command(const char* command) pclose(fp); /* add nullchar at the end */ - buffer[strlen(buffer) - 1] = '\0'; + for (int i = 0 ; i != sizeof(buffer) ; i++) { + if (buffer[i] == '\0') { + good = 1; + break; + } + } + if (good) { + buffer[strlen(buffer) - 1] = '\0'; + } /* return the output */ return smprintf("%s", buffer); @@ -656,6 +668,45 @@ wifi_perc(const char *wificard) return smprintf("%d%%", strength); } +/* wifi essid */ +char * +wifi_essid(const char *wificard) +{ + char *id = malloc(IW_ESSID_MAX_SIZE+1); + if (id == NULL) { + fprintf(stderr, "Cannot get ESSID."); + return smprintf("n/a"); + } + int sockfd; + struct iwreq wreq; + + /* prepare */ + memset(&wreq, 0, sizeof(struct iwreq)); + wreq.u.essid.length = IW_ESSID_MAX_SIZE+1; + + /* set the interface */ + sprintf(wreq.ifr_name, wificard); + + /* check */ + if((sockfd = socket(AF_INET, SOCK_DGRAM, 0)) == -1) { + fprintf(stderr, "Cannot open socket for interface: %s\n", wificard); + return smprintf("n/a"); + } + wreq.u.essid.pointer = id; + if (ioctl(sockfd,SIOCGIWESSID, &wreq) == -1) { + fprintf(stderr, "Get ESSID ioctl failed for interface %s\n", wificard); + return smprintf("n/a"); + } + + /* return the essid */ + if (strcmp((char *)wreq.u.essid.pointer, "") == 0) { + return smprintf("n/a"); + } + else { + return smprintf("%s", (char *)wreq.u.essid.pointer); + } +} + /* main function */ int main(void) @@ -679,6 +730,10 @@ main(void) argument = args[i]; char *res = argument.func(argument.args); char *element = smprintf(argument.format, res); + if (element == NULL) { + element = smprintf("n/a"); + fprintf(stderr, "Failed to format output."); + } strcat(status_string, element); free(res); free(element);