diff options
author | Pierre Beyssac <pb@FreeBSD.org> | 2003-07-26 12:14:58 +0000 |
---|---|---|
committer | Pierre Beyssac <pb@FreeBSD.org> | 2003-07-26 12:14:58 +0000 |
commit | c6df222c98f0c701aaaebedf9acf2fcd35566892 (patch) | |
tree | 947439b0ea48ac25f89c259fd659c386ac928fab /usr.sbin/burncd/burncd.c | |
parent | e139a45198350e12fa6c5fdd525d8fc3194d4132 (diff) |
Fix "write from stdin".
Reviewed by: sos
MFC after: 1 week
Notes
Notes:
svn path=/head/; revision=118055
Diffstat (limited to 'usr.sbin/burncd/burncd.c')
-rw-r--r-- | usr.sbin/burncd/burncd.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/usr.sbin/burncd/burncd.c b/usr.sbin/burncd/burncd.c index 95a681c0b623..5878d9b20377 100644 --- a/usr.sbin/burncd/burncd.c +++ b/usr.sbin/burncd/burncd.c @@ -611,8 +611,10 @@ write_file(int fd, struct track_info *track_info) size = 0; while ((count = read(track_info->file, buf, - MIN((track_info->file_size - size), - track_info->block_size * BLOCKS))) > 0) { + track_info->file_size == -1 + ? track_info->block_size * BLOCKS + : MIN((track_info->file_size - size), + track_info->block_size * BLOCKS))) > 0) { int res; if (count % track_info->block_size) { @@ -641,7 +643,8 @@ write_file(int fd, struct track_info *track_info) fprintf(stderr, " total %jd KB\r", (intmax_t)tot_size / 1024); } - if (size >= track_info->file_size) + if (track_info->file_size != -1 + && size >= track_info->file_size) break; } |