sway

i3-compatible Wayland compositor
git clone https://git.awy.one/sway
Log | Files | Refs | README | LICENSE

commit 79369681ab3d6785aabf39bd8080cd4f30507524
parent 055d662baa3975d71552992772e97d6b489f0771
Author: Peter Grayson <pete@jpgrayson.net>
Date:   Mon, 11 Mar 2019 22:28:35 -0400

Repair swaynag crash reading message from stdin

When swaynag is run with the -l/--detailed-message option, a crash may
occur if the detailed message read from stdin is large enough. E.g.:

    swaynag -m hello -l < ~/.config/sway/config

The root cause is that the read_from_stdin() function under-allocates
memory for the destination buffer which causes that buffer to be overflowed
when copying line data to it with snprintf().

The repair is to allocate one more byte for the terminating null byte.

N.B. although getline() returns the number of bytes read excluding a
terminating null byte, the line buffer is terminated with a null byte. Thus
we have a guarantee that the line buffer will be null terminated (which is
important when copying with snprintf()).
Diffstat:
Mswaynag/config.c | 2+-
1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/swaynag/config.c b/swaynag/config.c @@ -18,7 +18,7 @@ static char *read_from_stdin(void) { size_t line_size = 0; ssize_t nread; while ((nread = getline(&line, &line_size, stdin)) != -1) { - buffer = realloc(buffer, buffer_len + nread); + buffer = realloc(buffer, buffer_len + nread + 1); snprintf(&buffer[buffer_len], nread + 1, "%s", line); buffer_len += nread; }