2014-02-04 19:41:03 +08:00
|
|
|
#include "stream_buffer.h"
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
2014-03-28 23:33:35 +08:00
|
|
|
static gmio_bool_t gmio_stream_buffer_at_end(void* cookie)
|
2014-02-04 19:41:03 +08:00
|
|
|
{
|
2014-03-28 23:33:35 +08:00
|
|
|
const gmio_buffer_t* buff = (const gmio_buffer_t*)cookie;
|
2014-02-04 19:41:03 +08:00
|
|
|
return buff->pos >= buff->len;
|
|
|
|
}
|
|
|
|
|
2014-03-28 23:33:35 +08:00
|
|
|
static int gmio_stream_buffer_error(void* cookie)
|
2014-02-04 19:41:03 +08:00
|
|
|
{
|
2014-03-28 23:33:35 +08:00
|
|
|
const gmio_buffer_t* buff = (const gmio_buffer_t*)cookie;
|
2014-02-04 19:41:03 +08:00
|
|
|
return buff == NULL || buff->pos > buff->len;
|
|
|
|
}
|
|
|
|
|
2014-03-28 23:33:35 +08:00
|
|
|
static size_t gmio_stream_buffer_read(void* cookie,
|
2014-02-04 19:41:03 +08:00
|
|
|
void* ptr,
|
|
|
|
size_t item_size,
|
|
|
|
size_t item_count)
|
|
|
|
{
|
|
|
|
if (item_size > 0 && item_count > 0) {
|
2014-03-28 23:33:35 +08:00
|
|
|
gmio_buffer_t* buff = (gmio_buffer_t*)cookie;
|
2014-02-04 19:41:03 +08:00
|
|
|
const size_t buff_remaining_size = buff->len - buff->pos;
|
|
|
|
const size_t wanted_read_size = item_size * item_count;
|
|
|
|
const size_t next_read_size = wanted_read_size <= buff_remaining_size ? wanted_read_size :
|
|
|
|
buff_remaining_size;
|
|
|
|
const size_t next_read_item_count = next_read_size / item_size;
|
|
|
|
|
|
|
|
memcpy(ptr, (const char*)buff->ptr + buff->pos, next_read_item_count * item_size);
|
|
|
|
buff->pos += next_read_item_count * item_size;
|
|
|
|
return next_read_item_count;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-03-28 23:33:35 +08:00
|
|
|
static size_t gmio_stream_buffer_write(void* cookie,
|
2014-02-04 19:41:03 +08:00
|
|
|
const void* ptr,
|
|
|
|
size_t item_size,
|
|
|
|
size_t item_count)
|
|
|
|
{
|
|
|
|
if (item_size > 0 && item_count > 0) {
|
2014-03-28 23:33:35 +08:00
|
|
|
gmio_buffer_t* buff = (gmio_buffer_t*)cookie;
|
2014-02-04 19:41:03 +08:00
|
|
|
const size_t buff_remaining_size = buff->len - buff->pos;
|
|
|
|
const size_t wanted_write_size = item_size * item_count;
|
|
|
|
const size_t next_write_size = wanted_write_size <= buff_remaining_size ? wanted_write_size :
|
|
|
|
buff_remaining_size;
|
|
|
|
const size_t next_write_item_count = next_write_size / item_size;
|
|
|
|
|
|
|
|
memcpy((char*)buff->ptr + buff->pos, ptr, next_write_item_count * item_size);
|
|
|
|
buff->pos += next_write_item_count * item_size;
|
|
|
|
return next_write_item_count;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-03-28 23:33:35 +08:00
|
|
|
void gmio_stream_set_buffer(gmio_stream_t *stream, gmio_buffer_t *buff)
|
2014-02-04 19:41:03 +08:00
|
|
|
{
|
|
|
|
stream->cookie = buff;
|
2014-03-28 23:33:35 +08:00
|
|
|
stream->at_end_func = gmio_stream_buffer_at_end;
|
|
|
|
stream->error_func = gmio_stream_buffer_error;
|
|
|
|
stream->read_func = gmio_stream_buffer_read;
|
|
|
|
stream->write_func = gmio_stream_buffer_write;
|
2014-02-04 19:41:03 +08:00
|
|
|
}
|