update_iovec(iov, iov_size, ret);
update_buffer(fstream, ret);
- fstream->ostream.ostream.offset += ret;
return ret;
}
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;
/* 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,
/* error */
return -1;
}
+ outstream->ostream.offset += ret;
if (ret == 0 && !STREAM_IS_BLOCKING(foutstream)) {
/* don't block */
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;
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;
}