istream.c revision b7651d283ca261015ef3c445f1f27f340f0864e2
/* Copyright (c) 2002-2010 Dovecot authors, see the included COPYING file */
#include "lib.h"
#include "ioloop.h"
#include "str.h"
#include "istream-internal.h"
{
}
{
return "";
}
}
{
}
{
}
{
}
}
{
}
{
}
{
if (stream->stream_errno == 0)
}
{
}
{
}
{
}
{
}
{
stream->access_counter++;
else {
}
}
{
return -1;
stream->stream_errno = 0;
switch (ret) {
case -2:
break;
case -1:
if (stream->stream_errno != 0) {
/* error handling should be easier if we now just
assume the stream is now at EOF */
} else {
}
break;
case 0:
break;
default:
break;
}
return ret;
}
{
ret = 0;
else do {
return -2;
/* check again, in case the parent stream had been seeked
backwards and the previous read() didn't get us far
enough. */
(ret == 0 ? 0 : -1);
return ret;
}
{
/* within buffer */
return;
}
/* have to seek forward */
return;
stream->stream_errno = 0;
}
{
return TRUE;
/* use the fast route only if the parent stream hasn't been changed */
if (stream->access_counter !=
return FALSE;
}
{
else {
return;
}
}
{
return;
}
{
return;
}
}
{
return NULL;
}
{
return -1;
}
{
}
{
(void)i_stream_read(stream);
return !i_stream_have_bytes_left(stream);
}
{
char *ret;
end = i - 1;
else
end = i;
/* modify the buffer directly */
} else {
/* use a temporary string to return it */
}
i++;
return ret;
}
{
/* the last line is missing LF and we want to return it. */
}
return NULL;
}
{
const unsigned char *pos;
stream->stream_errno = 0;
return NULL;
}
i_error("i_stream_next_line(%s) called for unmodifiable stream",
return NULL;
}
return i_stream_next_line_finish(_stream,
} else {
return i_stream_last_line(_stream);
}
}
{
char *line;
for (;;) {
break;
if (i_stream_read(stream) <= 0)
}
return line;
}
const unsigned char *
{
*size_r = 0;
return NULL;
}
}
{
*size_r = 0;
return NULL;
}
}
{
do {
return 1;
/* we need more data */
if (ret > 0)
} while (ret > 0);
if (ret == -2)
return -2;
if (ret == 0) {
/* need to read more */
return 0;
}
if (read_more) {
/* we read at least some new data */
return 0;
}
} else {
}
return -1;
}
{
}
{
else
if (stream->max_buffer_size > 0 &&
else {
}
}
{
i_assert(wanted_size > 0);
/* remove the unused bytes from beginning of buffer */
} else if (stream->max_buffer_size == 0 ||
/* buffer is full - grow it */
}
}
}
{
return FALSE;
return TRUE;
}
static void
{
}
{
}
static void
{
i_panic("stream doesn't support seeking backwards");
if (available == 0) {
return;
}
else {
}
}
}
static const struct stat *
{
}
static int
{
return -1;
return 0;
return 1;
}
struct istream *
{
}
}
}
if (_stream->init_buffer_size == 0)
}