summaryrefslogtreecommitdiff
path: root/scp.c
diff options
context:
space:
mode:
authordjm <djm>2003-01-10 10:44:48 +0000
committerdjm <djm>2003-01-10 10:44:48 +0000
commit49c5670d216b4ca2a84b158edb533afe31b436c8 (patch)
treeafa7743596c0c51b28163086977128e5caae94a3 /scp.c
parentae4a6b5ff10780c6fff5d2f1935284d24c8edd7a (diff)
downloadopenssh-49c5670d216b4ca2a84b158edb533afe31b436c8.tar.gz
- djm@cvs.openbsd.org 2003/01/10 10:29:35
[scp.c] Don't ftruncate after write error, creating sparse files of incorrect length mindrot bug #403, reported by rusr@cup.hp.com; ok markus@
Diffstat (limited to 'scp.c')
-rw-r--r--scp.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/scp.c b/scp.c
index 44b5b458..616dd378 100644
--- a/scp.c
+++ b/scp.c
@@ -75,7 +75,7 @@
*/
#include "includes.h"
-RCSID("$OpenBSD: scp.c,v 1.97 2003/01/10 08:19:07 fgsch Exp $");
+RCSID("$OpenBSD: scp.c,v 1.98 2003/01/10 10:29:35 djm Exp $");
#include "xmalloc.h"
#include "atomicio.h"
@@ -864,7 +864,7 @@ bad: run_err("%s: %s", np, strerror(errno));
wrerr = YES;
wrerrno = j >= 0 ? EIO : errno;
}
- if (ftruncate(ofd, size)) {
+ if (wrerr == NO && ftruncate(ofd, size) != 0) {
run_err("%s: truncate: %s", np, strerror(errno));
wrerr = DISPLAYED;
}