From 744ec1d54962d79528eef40dce5913edf9f78c6d Mon Sep 17 00:00:00 2001 From: Eric Andersen Date: Mon, 15 Apr 2002 07:40:27 +0000 Subject: [PATCH] Patch from Ben Low to allow tftp to work with stdin as well as stdout. --- networking/tftp.c | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) 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 -- 2.25.1