more buffered input tweaking
This commit is contained in:
parent
ca5d75f7ec
commit
805da46670
@ -242,6 +242,8 @@ gint64 vips_streami_size( VipsStreami *streami );
|
|||||||
typedef struct _VipsStreamib {
|
typedef struct _VipsStreamib {
|
||||||
VipsStreami parent_object;
|
VipsStreami parent_object;
|
||||||
|
|
||||||
|
/*< private >*/
|
||||||
|
|
||||||
/* The +1 means there's always a \0 byte at the end.
|
/* The +1 means there's always a \0 byte at the end.
|
||||||
*/
|
*/
|
||||||
char input_buffer[VIPS_STREAMIB_BUFFER_SIZE + 1];
|
char input_buffer[VIPS_STREAMIB_BUFFER_SIZE + 1];
|
||||||
@ -249,6 +251,10 @@ typedef struct _VipsStreamib {
|
|||||||
char *read_point;
|
char *read_point;
|
||||||
int bytes_remaining;
|
int bytes_remaining;
|
||||||
|
|
||||||
|
/* No seeks on buffered streams, so an EOF flag is easy.
|
||||||
|
*/
|
||||||
|
gboolean eof;
|
||||||
|
|
||||||
} VipsStreamib;
|
} VipsStreamib;
|
||||||
|
|
||||||
typedef struct _VipsStreamibClass {
|
typedef struct _VipsStreamibClass {
|
||||||
|
@ -1114,7 +1114,8 @@ vips_streamib_refill( VipsStreamib *streamib )
|
|||||||
*/
|
*/
|
||||||
streamib->read_postion[bytes_read] = '\0';
|
streamib->read_postion[bytes_read] = '\0';
|
||||||
|
|
||||||
how do we siganl EOF?
|
if( bytes_read == 0 )
|
||||||
|
streamib->eof = TRUE;
|
||||||
|
|
||||||
return( 0 );
|
return( 0 );
|
||||||
}
|
}
|
||||||
@ -1192,8 +1193,13 @@ vips_streamib_get_line( VipsStreamib *streamib, const char **line )
|
|||||||
*/
|
*/
|
||||||
if( vips_streamib_refill( streamib ) )
|
if( vips_streamib_refill( streamib ) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
|
||||||
|
if( streamib->eof )
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user