X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=bspc.c;h=95fdb85d5d4223d746f63056573cb64fd93b2ff0;hb=30eb9598b837a482b5f41c447f276590b47cddfb;hp=dc6763bf85113e4d30e255c8e2f9087aa64346f4;hpb=7614a51b3c76d7769e1492cbb0dc39f3e9f1dd41;p=bspwm.git diff --git a/bspc.c b/bspc.c index dc6763b..95fdb85 100644 --- a/bspc.c +++ b/bspc.c @@ -1,80 +1,58 @@ -#include -#include #include -#include #include #include #include +#include "helpers.h" #include "common.h" -static void logmsg(FILE *stream, char *fmt, va_list ap) { - vfprintf(stream, fmt, ap); -} - -static void warn(char *warnfmt, ...) { - va_list ap; - va_start(ap, warnfmt); - logmsg(stderr, warnfmt, ap); - va_end(ap); -} - -__attribute__((noreturn)) -static void err(char *errfmt, ...) { - va_list ap; - va_start(ap, errfmt); - logmsg(stderr, errfmt, ap); - va_end(ap); - exit(EXIT_FAILURE); -} - int main(int argc, char *argv[]) { int sock_fd; struct sockaddr_un sock_address; - size_t msglen = 0; - char msg[BUFSIZ] = {0}; - char rsp[BUFSIZ] = {0}; + char msg[BUFSIZ]; + char rsp[BUFSIZ]; if (argc < 2) - err("invalid number of arguments: %d\n", argc); + err("No arguments given.\n"); - char *sock_path = getenv(SOCKET_ENV_VAR); - if (sock_path == NULL || strlen(sock_path) == 0) - warn("environmental variable '%s' is not set or empty - using default value: %s\n", SOCKET_ENV_VAR, DEFAULT_SOCKET_PATH); - else if (sizeof(sock_address.sun_path) <= strlen(sock_path)) - err("value too long for environmental variable '%s'\n", SOCKET_ENV_VAR); + char *sp = getenv(SOCKET_ENV_VAR); sock_address.sun_family = AF_UNIX; - strncpy(sock_address.sun_path, (sock_path == NULL ? DEFAULT_SOCKET_PATH: sock_path), sizeof(sock_address.sun_path)); - sock_address.sun_path[sizeof(sock_address.sun_path) - 1] = 0; + snprintf(sock_address.sun_path, sizeof(sock_address.sun_path), "%s", (sp == NULL ? DEFAULT_SOCKET_PATH : sp)); - for (int offset = 0, len = BUFSIZ, n = 0; --argc && ++argv && len > 0; offset += n, len -= n) - n = snprintf(msg + offset, len, "%s ", *argv); + argc--, argv++; + int msg_len = 0; - msglen = strlen(msg); - if (msg[msglen - 1] == ' ') - msg[--msglen] = '\0'; + for (int offset = 0, rem = sizeof(msg), n = 0; argc > 0 && rem > 0; offset += n, rem -= n, argc--, argv++) { + n = snprintf(msg + offset, rem, "%s%c", *argv, 0); + msg_len += n; + } - sock_fd = socket(AF_UNIX, SOCK_STREAM, 0); - if (sock_fd == -1) - err("failed to create socket\n"); + if ((sock_fd = socket(AF_UNIX, SOCK_STREAM, 0)) == -1) + err("Failed to create the socket.\n"); if (connect(sock_fd, (struct sockaddr *) &sock_address, sizeof(sock_address)) == -1) - err("failed to connect to socket\n"); + err("Failed to connect to the socket.\n"); + + if (send(sock_fd, msg, msg_len, 0) == -1) + err("Failed to send the data.\n"); - if (send(sock_fd, msg, msglen, 0) == -1) - err("failed to send data\n"); + int ret = EXIT_SUCCESS; int n = recv(sock_fd, rsp, sizeof(rsp), 0); - if (n == -1) - err("failed to get response\n"); - else if (n > 0) { - rsp[n] = '\0'; - printf("%s\n", rsp); + if (n == -1) { + err("Failed to get the response.\n"); + } else if (n > 0) { + if (n == 1 && rsp[0] == MESSAGE_FAILURE) { + ret = EXIT_FAILURE; + } else { + rsp[n] = '\0'; + printf("%s\n", rsp); + } } if (sock_fd) close(sock_fd); - return EXIT_SUCCESS; + return ret; }