Add a safe wrapper for write and fix some warnings
1. Add a function writeall and make swrite wrap that function. Use either writeall or swrite, depending on whether we want to exit on errors or not. 2. Fix warnings when compiling with a higher optimisation level. (CFLAGS ?= -pipe -O3 -march=native -mtune=native -freorder-blocks-and-partition) Signed-off-by: hwangcc <hwangcc@csie.nctu.edu.tw>
This commit is contained in:
parent
822cd3bf1b
commit
42515308e7
@ -43,8 +43,7 @@ static int check_for_wrap(void) {
|
|||||||
* of the log. */
|
* of the log. */
|
||||||
wrap_count = header->wrap_count;
|
wrap_count = header->wrap_count;
|
||||||
const int len = (logbuffer + header->offset_last_wrap) - walk;
|
const int len = (logbuffer + header->offset_last_wrap) - walk;
|
||||||
if (write(STDOUT_FILENO, walk, len) != len)
|
swrite(STDOUT_FILENO, walk, len);
|
||||||
err(EXIT_FAILURE, "write()");
|
|
||||||
walk = logbuffer + sizeof(i3_shmlog_header);
|
walk = logbuffer + sizeof(i3_shmlog_header);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -52,12 +51,8 @@ static int check_for_wrap(void) {
|
|||||||
static void print_till_end(void) {
|
static void print_till_end(void) {
|
||||||
check_for_wrap();
|
check_for_wrap();
|
||||||
const int len = (logbuffer + header->offset_next_write) - walk;
|
const int len = (logbuffer + header->offset_next_write) - walk;
|
||||||
const int n = write(STDOUT_FILENO, walk, len);
|
swrite(STDOUT_FILENO, walk, len);
|
||||||
if (len != n)
|
walk += len;
|
||||||
err(EXIT_FAILURE, "write()");
|
|
||||||
if (n > 0) {
|
|
||||||
walk += n;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
|
@ -164,7 +164,9 @@ static void handle_button_release(xcb_connection_t *conn, xcb_button_release_eve
|
|||||||
char *link_path;
|
char *link_path;
|
||||||
char *exe_path = get_exe_path(argv0);
|
char *exe_path = get_exe_path(argv0);
|
||||||
sasprintf(&link_path, "%s.nagbar_cmd", script_path);
|
sasprintf(&link_path, "%s.nagbar_cmd", script_path);
|
||||||
symlink(exe_path, link_path);
|
if (symlink(exe_path, link_path) == -1) {
|
||||||
|
err(EXIT_FAILURE, "Failed to symlink %s to %s", link_path, exe_path);
|
||||||
|
}
|
||||||
|
|
||||||
char *terminal_cmd;
|
char *terminal_cmd;
|
||||||
sasprintf(&terminal_cmd, "i3-sensible-terminal -e %s", link_path);
|
sasprintf(&terminal_cmd, "i3-sensible-terminal -e %s", link_path);
|
||||||
|
@ -103,7 +103,7 @@ __attribute__((format(printf, 1, 2))) static void set_statusline_error(const cha
|
|||||||
char *message;
|
char *message;
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, format);
|
va_start(args, format);
|
||||||
vasprintf(&message, format, args);
|
(void)vasprintf(&message, format, args);
|
||||||
|
|
||||||
struct status_block *err_block = scalloc(sizeof(struct status_block));
|
struct status_block *err_block = scalloc(sizeof(struct status_block));
|
||||||
err_block->full_text = i3string_from_utf8("Error: ");
|
err_block->full_text = i3string_from_utf8("Error: ");
|
||||||
@ -455,11 +455,22 @@ void child_write_output(void) {
|
|||||||
if (child.click_events) {
|
if (child.click_events) {
|
||||||
const unsigned char *output;
|
const unsigned char *output;
|
||||||
size_t size;
|
size_t size;
|
||||||
|
ssize_t n;
|
||||||
|
|
||||||
yajl_gen_get_buf(gen, &output, &size);
|
yajl_gen_get_buf(gen, &output, &size);
|
||||||
write(child_stdin, output, size);
|
|
||||||
write(child_stdin, "\n", 1);
|
n = writeall(child_stdin, output, size);
|
||||||
|
if (n != -1)
|
||||||
|
n = writeall(child_stdin, "\n", 1);
|
||||||
|
|
||||||
yajl_gen_clear(gen);
|
yajl_gen_clear(gen);
|
||||||
|
|
||||||
|
if (n == -1) {
|
||||||
|
child.click_events = false;
|
||||||
|
kill_child();
|
||||||
|
set_statusline_error("child_write_output failed");
|
||||||
|
draw_bars(false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -296,18 +296,7 @@ int i3_send_msg(uint32_t type, const char *payload) {
|
|||||||
if (payload != NULL)
|
if (payload != NULL)
|
||||||
strncpy(walk, payload, len);
|
strncpy(walk, payload, len);
|
||||||
|
|
||||||
uint32_t written = 0;
|
swrite(i3_connection->fd, buffer, to_write);
|
||||||
|
|
||||||
while (to_write > 0) {
|
|
||||||
int n = write(i3_connection->fd, buffer + written, to_write);
|
|
||||||
if (n == -1) {
|
|
||||||
ELOG("write() failed: %s\n", strerror(errno));
|
|
||||||
exit(EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
|
|
||||||
to_write -= n;
|
|
||||||
written += n;
|
|
||||||
}
|
|
||||||
|
|
||||||
FREE(buffer);
|
FREE(buffer);
|
||||||
|
|
||||||
|
@ -134,6 +134,20 @@ char *sstrdup(const char *str);
|
|||||||
*/
|
*/
|
||||||
int sasprintf(char **strp, const char *fmt, ...);
|
int sasprintf(char **strp, const char *fmt, ...);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Wrapper around correct write which returns -1 (meaning that
|
||||||
|
* write failed) or count (meaning that all bytes were written)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
ssize_t writeall(int fd, const void *buf, size_t count);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Safe-wrapper around writeall which exits if it returns -1 (meaning that
|
||||||
|
* write failed)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
ssize_t swrite(int fd, const void *buf, size_t count);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Build an i3String from an UTF-8 encoded string.
|
* Build an i3String from an UTF-8 encoded string.
|
||||||
* Returns the newly-allocated i3String.
|
* Returns the newly-allocated i3String.
|
||||||
|
@ -32,33 +32,11 @@ int ipc_send_message(int sockfd, const uint32_t message_size,
|
|||||||
.size = message_size,
|
.size = message_size,
|
||||||
.type = message_type};
|
.type = message_type};
|
||||||
|
|
||||||
size_t sent_bytes = 0;
|
if (writeall(sockfd, ((void *)&header), sizeof(i3_ipc_header_t)) == -1)
|
||||||
int n = 0;
|
|
||||||
|
|
||||||
/* This first loop is basically unnecessary. No operating system has
|
|
||||||
* buffers which cannot fit 14 bytes into them, so the write() will only be
|
|
||||||
* called once. */
|
|
||||||
while (sent_bytes < sizeof(i3_ipc_header_t)) {
|
|
||||||
if ((n = write(sockfd, ((void *)&header) + sent_bytes, sizeof(i3_ipc_header_t) - sent_bytes)) == -1) {
|
|
||||||
if (errno == EAGAIN)
|
|
||||||
continue;
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
|
|
||||||
sent_bytes += n;
|
if (writeall(sockfd, payload, message_size) == -1)
|
||||||
}
|
|
||||||
|
|
||||||
sent_bytes = 0;
|
|
||||||
|
|
||||||
while (sent_bytes < message_size) {
|
|
||||||
if ((n = write(sockfd, payload + sent_bytes, message_size - sent_bytes)) == -1) {
|
|
||||||
if (errno == EAGAIN)
|
|
||||||
continue;
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
|
|
||||||
sent_bytes += n;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -8,8 +8,10 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
#include <unistd.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <err.h>
|
#include <err.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
#include "libi3.h"
|
#include "libi3.h"
|
||||||
|
|
||||||
@ -56,3 +58,30 @@ int sasprintf(char **strp, const char *fmt, ...) {
|
|||||||
va_end(args);
|
va_end(args);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ssize_t writeall(int fd, const void *buf, size_t count) {
|
||||||
|
int written = 0;
|
||||||
|
ssize_t n = 0;
|
||||||
|
|
||||||
|
while (written < count) {
|
||||||
|
n = write(fd, buf + written, count - written);
|
||||||
|
if (n == -1) {
|
||||||
|
if (errno == EINTR || errno == EAGAIN)
|
||||||
|
continue;
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
written += n;
|
||||||
|
}
|
||||||
|
|
||||||
|
return written;
|
||||||
|
}
|
||||||
|
|
||||||
|
ssize_t swrite(int fd, const void *buf, size_t count) {
|
||||||
|
ssize_t n;
|
||||||
|
|
||||||
|
n = writeall(fd, buf, count);
|
||||||
|
if (n == -1)
|
||||||
|
err(EXIT_FAILURE, "Failed to write %d", fd);
|
||||||
|
else
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
@ -46,6 +46,9 @@ static bool tiling_resize_for_border(Con *con, border_t border, xcb_button_press
|
|||||||
case BORDER_BOTTOM:
|
case BORDER_BOTTOM:
|
||||||
search_direction = D_DOWN;
|
search_direction = D_DOWN;
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
|
assert(false);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool res = resize_find_tiling_participants(&first, &second, search_direction);
|
bool res = resize_find_tiling_participants(&first, &second, search_direction);
|
||||||
|
@ -778,15 +778,10 @@ static char *migrate_config(char *input, off_t size) {
|
|||||||
|
|
||||||
/* write the whole config file to the pipe, the script will read everything
|
/* write the whole config file to the pipe, the script will read everything
|
||||||
* immediately */
|
* immediately */
|
||||||
int written = 0;
|
if (writeall(writepipe[1], input, size) == -1) {
|
||||||
int ret;
|
|
||||||
while (written < size) {
|
|
||||||
if ((ret = write(writepipe[1], input + written, size - written)) < 0) {
|
|
||||||
warn("Could not write to pipe");
|
warn("Could not write to pipe");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
written += ret;
|
|
||||||
}
|
|
||||||
close(writepipe[1]);
|
close(writepipe[1]);
|
||||||
|
|
||||||
/* close writing end of the readpipe (connected to the script’s stdout) */
|
/* close writing end of the readpipe (connected to the script’s stdout) */
|
||||||
@ -795,7 +790,7 @@ static char *migrate_config(char *input, off_t size) {
|
|||||||
/* read the script’s output */
|
/* read the script’s output */
|
||||||
int conv_size = 65535;
|
int conv_size = 65535;
|
||||||
char *converted = malloc(conv_size);
|
char *converted = malloc(conv_size);
|
||||||
int read_bytes = 0;
|
int read_bytes = 0, ret;
|
||||||
do {
|
do {
|
||||||
if (read_bytes == conv_size) {
|
if (read_bytes == conv_size) {
|
||||||
conv_size += 65535;
|
conv_size += 65535;
|
||||||
|
@ -105,7 +105,7 @@ static int json_end_map(void *ctx) {
|
|||||||
int cnt = 1;
|
int cnt = 1;
|
||||||
while (workspace != NULL) {
|
while (workspace != NULL) {
|
||||||
FREE(json_node->name);
|
FREE(json_node->name);
|
||||||
asprintf(&(json_node->name), "%s_%d", base, cnt++);
|
sasprintf(&(json_node->name), "%s_%d", base, cnt++);
|
||||||
workspace = NULL;
|
workspace = NULL;
|
||||||
TAILQ_FOREACH(output, &(croot->nodes_head), nodes)
|
TAILQ_FOREACH(output, &(croot->nodes_head), nodes)
|
||||||
GREP_FIRST(workspace, output_get_content(output), !strcasecmp(child->name, json_node->name));
|
GREP_FIRST(workspace, output_get_content(output), !strcasecmp(child->name, json_node->name));
|
||||||
|
@ -70,8 +70,14 @@ static int backtrace(void) {
|
|||||||
int stdin_pipe[2],
|
int stdin_pipe[2],
|
||||||
stdout_pipe[2];
|
stdout_pipe[2];
|
||||||
|
|
||||||
pipe(stdin_pipe);
|
if (pipe(stdin_pipe) == -1) {
|
||||||
pipe(stdout_pipe);
|
ELOG("Failed to init stdin_pipe\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (pipe(stdout_pipe) == -1) {
|
||||||
|
ELOG("Failed to init stdout_pipe\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
/* close standard streams in case i3 is started from a terminal; gdb
|
/* close standard streams in case i3 is started from a terminal; gdb
|
||||||
* needs to run without controlling terminal for it to work properly in
|
* needs to run without controlling terminal for it to work properly in
|
||||||
|
18
src/util.c
18
src/util.c
@ -265,25 +265,13 @@ char *store_restart_layout(void) {
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t written = 0;
|
if (writeall(fd, payload, length) == -1) {
|
||||||
while (written < length) {
|
ELOG("Could not write restart layout to \"%s\", layout will be lost: %s\n", filename, strerror(errno));
|
||||||
int n = write(fd, payload + written, length - written);
|
|
||||||
/* TODO: correct error-handling */
|
|
||||||
if (n == -1) {
|
|
||||||
perror("write()");
|
|
||||||
free(filename);
|
free(filename);
|
||||||
close(fd);
|
close(fd);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
if (n == 0) {
|
|
||||||
DLOG("write == 0?\n");
|
|
||||||
free(filename);
|
|
||||||
close(fd);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
written += n;
|
|
||||||
DLOG("written: %zd of %zd\n", written, length);
|
|
||||||
}
|
|
||||||
close(fd);
|
close(fd);
|
||||||
|
|
||||||
if (length > 0) {
|
if (length > 0) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user