1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Workarounds for compiling with -D_FORTIFY_SOURCE=2 (as Ubuntu does), which

doesn't like you to ignore the return value from read()/write()/etc (and
apparently can't be shut up with a cast to void).

[originally from svn r8614]
This commit is contained in:
Jacob Nevins 2009-08-07 00:19:04 +00:00
parent 9c1f81dd94
commit 4bddcc2b5d
6 changed files with 24 additions and 10 deletions

View File

@ -43,7 +43,10 @@ static void logwrite(struct LogContext *ctx, void *data, int len)
bufchain_add(&ctx->queue, data, len); bufchain_add(&ctx->queue, data, len);
} else if (ctx->state == L_OPEN) { } else if (ctx->state == L_OPEN) {
assert(ctx->lgfp); assert(ctx->lgfp);
fwrite(data, 1, len, ctx->lgfp); if (fwrite(data, 1, len, ctx->lgfp) < len) {
logfclose(ctx);
ctx->state = L_ERROR;
}
} /* else L_ERROR, so ignore the write */ } /* else L_ERROR, so ignore the write */
} }

3
pscp.c
View File

@ -178,7 +178,8 @@ int from_backend(void *frontend, int is_stderr, const char *data, int datalen)
*/ */
if (is_stderr) { if (is_stderr) {
if (len > 0) if (len > 0)
fwrite(data, 1, len, stderr); if (fwrite(data, 1, len, stderr) < len)
/* oh well */;
return 0; return 0;
} }

View File

@ -2518,7 +2518,8 @@ int from_backend(void *frontend, int is_stderr, const char *data, int datalen)
*/ */
if (is_stderr) { if (is_stderr) {
if (len > 0) if (len > 0)
fwrite(data, 1, len, stderr); if (fwrite(data, 1, len, stderr) < len)
/* oh well */;
return 0; return 0;
} }

View File

@ -161,7 +161,8 @@ int verify_ssh_host_key(void *frontend, char *host, int port, char *keytype,
newmode.c_lflag |= ECHO | ISIG | ICANON; newmode.c_lflag |= ECHO | ISIG | ICANON;
tcsetattr(0, TCSANOW, &newmode); tcsetattr(0, TCSANOW, &newmode);
line[0] = '\0'; line[0] = '\0';
read(0, line, sizeof(line) - 1); if (read(0, line, sizeof(line) - 1) <= 0)
/* handled below */;
tcsetattr(0, TCSANOW, &oldmode); tcsetattr(0, TCSANOW, &oldmode);
} }
@ -213,7 +214,8 @@ int askalg(void *frontend, const char *algtype, const char *algname,
newmode.c_lflag |= ECHO | ISIG | ICANON; newmode.c_lflag |= ECHO | ISIG | ICANON;
tcsetattr(0, TCSANOW, &newmode); tcsetattr(0, TCSANOW, &newmode);
line[0] = '\0'; line[0] = '\0';
read(0, line, sizeof(line) - 1); if (read(0, line, sizeof(line) - 1) <= 0)
/* handled below */;
tcsetattr(0, TCSANOW, &oldmode); tcsetattr(0, TCSANOW, &oldmode);
} }
@ -266,7 +268,8 @@ int askappend(void *frontend, Filename filename,
newmode.c_lflag |= ECHO | ISIG | ICANON; newmode.c_lflag |= ECHO | ISIG | ICANON;
tcsetattr(0, TCSANOW, &newmode); tcsetattr(0, TCSANOW, &newmode);
line[0] = '\0'; line[0] = '\0';
read(0, line, sizeof(line) - 1); if (read(0, line, sizeof(line) - 1) <= 0)
/* handled below */;
tcsetattr(0, TCSANOW, &oldmode); tcsetattr(0, TCSANOW, &oldmode);
} }

View File

@ -513,7 +513,8 @@ int signalpipe[2];
void sigwinch(int signum) void sigwinch(int signum)
{ {
write(signalpipe[1], "x", 1); if (write(signalpipe[1], "x", 1) <= 0)
/* not much we can do about it */;
} }
/* /*
@ -1030,7 +1031,9 @@ int main(int argc, char **argv)
if (FD_ISSET(signalpipe[0], &rset)) { if (FD_ISSET(signalpipe[0], &rset)) {
char c[1]; char c[1];
struct winsize size; struct winsize size;
read(signalpipe[0], c, 1); /* ignore its value; it'll be `x' */ if (read(signalpipe[0], c, 1) <= 0)
/* ignore error */;
/* ignore its value; it'll be `x' */
if (ioctl(0, TIOCGWINSZ, (void *)&size) >= 0) if (ioctl(0, TIOCGWINSZ, (void *)&size) >= 0)
back->size(backhandle, size.ws_col, size.ws_row); back->size(backhandle, size.ws_col, size.ws_row);
} }

View File

@ -260,7 +260,8 @@ static void cleanup_utmp(void)
static void sigchld_handler(int signum) static void sigchld_handler(int signum)
{ {
write(pty_signal_pipe[1], "x", 1); if (write(pty_signal_pipe[1], "x", 1) <= 0)
/* not much we can do about it */;
} }
#ifndef OMIT_UTMP #ifndef OMIT_UTMP
@ -633,7 +634,9 @@ int pty_select_result(int fd, int event)
int status; int status;
char c[1]; char c[1];
read(pty_signal_pipe[0], c, 1); /* ignore its value; it'll be `x' */ if (read(pty_signal_pipe[0], c, 1) <= 0)
/* ignore error */;
/* ignore its value; it'll be `x' */
do { do {
pid = waitpid(-1, &status, WNOHANG); pid = waitpid(-1, &status, WNOHANG);