Mercurial > dovecot > original-hg > dovecot-1.2
changeset 1207:cf9558657ded HEAD
ostream: get initial offset. flush buffer before seeking.
author | Timo Sirainen <tss@iki.fi> |
---|---|
date | Thu, 20 Feb 2003 01:35:09 +0200 |
parents | 60770e7e3dea |
children | 3aa40f0dde5f |
files | src/lib/ostream-file.c |
diffstat | 1 files changed, 17 insertions(+), 4 deletions(-) [+] |
line wrap: on
line diff
--- a/src/lib/ostream-file.c Wed Feb 19 23:32:21 2003 +0200 +++ b/src/lib/ostream-file.c Thu Feb 20 01:35:09 2003 +0200 @@ -220,7 +220,6 @@ update_iovec(iov, iov_size, ret); update_buffer(fstream, ret); - fstream->ostream.ostream.offset += ret; return ret; } @@ -362,6 +361,9 @@ return -1; } + if (buffer_flush(fstream) < 0) + return -1; + ret = lseek(fstream->fd, (off_t)offset, SEEK_SET); if (ret < 0) { stream->ostream.stream_errno = errno; @@ -501,11 +503,14 @@ /* send it blocking */ if (o_stream_send_blocking(fstream, data, size) < 0) return -1; - return (ssize_t)size; + ret = (ssize_t)size; } else { /* buffer it, at least partly */ - return (ssize_t)o_stream_add(fstream, data, size); + ret = (ssize_t)o_stream_add(fstream, data, size); } + + stream->ostream.offset += ret; + return ret; } static off_t io_stream_sendfile(struct _ostream *outstream, @@ -619,6 +624,7 @@ /* error */ return -1; } + outstream->ostream.offset += ret; if (ret == 0 && !STREAM_IS_BLOCKING(foutstream)) { /* don't block */ @@ -801,6 +807,8 @@ int priority, int autoclose_fd) { struct file_ostream *fstream; + struct ostream *ostream; + off_t offset; fstream = p_new(pool, struct file_ostream, 1); fstream->fd = fd; @@ -820,5 +828,10 @@ fstream->ostream.send = _send; fstream->ostream.send_istream = _send_istream; - return _o_stream_create(&fstream->ostream, pool); + ostream = _o_stream_create(&fstream->ostream, pool); + + offset = lseek(fd, 0, SEEK_CUR); + if (offset >= 0) + ostream->offset = offset; + return ostream; }