From: Eric Andersen Date: Mon, 15 Apr 2002 07:40:27 +0000 (-0000) Subject: Patch from Ben Low to allow tftp to work X-Git-Tag: 0_60_3~18 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=744ec1d54962d79528eef40dce5913edf9f78c6d;p=oweals%2Fbusybox.git Patch from Ben Low to allow tftp to work with stdin as well as stdout. --- diff --git a/networking/tftp.c b/networking/tftp.c index a82415c60..ec30725d2 100644 --- a/networking/tftp.c +++ b/networking/tftp.c @@ -548,17 +548,13 @@ int tftp_main(int argc, char **argv) if ((cmd == 0) || (optind == argc)) { show_usage(); } - if(cmd == tftp_cmd_get) { - if(localfile == NULL) - localfile = remotefile; - if(localfile && strcmp(localfile, "-") == 0) { - fd = fileno(stdout); - } + if(localfile && strcmp(localfile, "-") == 0) { + fd = fileno((cmd==tftp_cmd_get)? stdin : stdout); } - if(cmd == tftp_cmd_put) - if(remotefile == NULL) - remotefile = localfile; - + if(localfile == NULL) + localfile = remotefile; + if(remotefile == NULL) + remotefile = localfile; if (fd==-1) { fd = open(localfile, flags, 0644); } @@ -582,7 +578,7 @@ int tftp_main(int argc, char **argv) result = tftp(cmd, host, remotefile, fd, port, blocksize); #ifdef CONFIG_FEATURE_CLEAN_UP - if (fd!=fileno(stdout)) { + if (!(fd == fileno(stdout) || fd == fileno(stdin))) { close(fd); } #endif