mirror of
https://github.com/libretro/RetroArch
synced 2025-03-23 19:21:03 +00:00
Update memory_stream.c with FCEUmm update code
This commit is contained in:
parent
a8144abbce
commit
f0a1b94a11
libretro-common
@ -28,7 +28,7 @@
|
||||
|
||||
typedef struct memstream memstream_t;
|
||||
|
||||
memstream_t *memstream_open(void);
|
||||
memstream_t *memstream_open(unsigned writing);
|
||||
|
||||
void memstream_close(memstream_t *stream);
|
||||
|
||||
@ -38,6 +38,8 @@ size_t memstream_write(memstream_t *stream, const void *data, size_t bytes);
|
||||
|
||||
int memstream_getc(memstream_t *stream);
|
||||
|
||||
void memstream_putc(memstream_t *stream, int c);
|
||||
|
||||
char *memstream_gets(memstream_t *stream, char *buffer, size_t len);
|
||||
|
||||
size_t memstream_pos(memstream_t *stream);
|
||||
|
@ -81,7 +81,7 @@ bool intfstream_open(intfstream_internal_t *intf, const char *path,
|
||||
return false;
|
||||
break;
|
||||
case INTFSTREAM_MEMORY:
|
||||
intf->memory.fp = memstream_open();
|
||||
intf->memory.fp = memstream_open(0);
|
||||
if (!intf->memory.fp)
|
||||
return false;
|
||||
break;
|
||||
|
@ -35,8 +35,16 @@ struct memstream
|
||||
uint8_t *buf;
|
||||
size_t size;
|
||||
size_t ptr;
|
||||
size_t max_ptr;
|
||||
unsigned writing;
|
||||
};
|
||||
|
||||
static void memstream_update_pos(memstream_t *stream)
|
||||
{
|
||||
if (stream->ptr > stream->max_ptr)
|
||||
stream->max_ptr = stream->ptr;
|
||||
}
|
||||
|
||||
void memstream_set_buffer(uint8_t *buffer, size_t size)
|
||||
{
|
||||
g_buffer = buffer;
|
||||
@ -49,24 +57,26 @@ size_t memstream_get_last_size(void)
|
||||
}
|
||||
|
||||
static void memstream_init(memstream_t *stream,
|
||||
uint8_t *buffer, size_t max_size)
|
||||
uint8_t *buffer, size_t max_size, unsigned writing)
|
||||
{
|
||||
if (!stream)
|
||||
return;
|
||||
|
||||
stream->buf = buffer;
|
||||
stream->size = max_size;
|
||||
stream->ptr = 0;
|
||||
stream->buf = buffer;
|
||||
stream->size = max_size;
|
||||
stream->ptr = 0;
|
||||
stream->max_ptr = 0;
|
||||
stream->writing = writing;
|
||||
}
|
||||
|
||||
memstream_t *memstream_open(void)
|
||||
memstream_t *memstream_open(unsigned writing)
|
||||
{
|
||||
memstream_t *stream;
|
||||
if (!g_buffer || !g_size)
|
||||
return NULL;
|
||||
|
||||
stream = (memstream_t*)calloc(1, sizeof(*stream));
|
||||
memstream_init(stream, g_buffer, g_size);
|
||||
memstream_init(stream, g_buffer, g_size, writing);
|
||||
|
||||
g_buffer = NULL;
|
||||
g_size = 0;
|
||||
@ -78,7 +88,7 @@ void memstream_close(memstream_t *stream)
|
||||
if (!stream)
|
||||
return;
|
||||
|
||||
last_file_size = stream->ptr;
|
||||
last_file_size = stream->writing ? stream->max_ptr : stream->size;
|
||||
free(stream);
|
||||
}
|
||||
|
||||
@ -95,6 +105,7 @@ size_t memstream_read(memstream_t *stream, void *data, size_t bytes)
|
||||
|
||||
memcpy(data, stream->buf + stream->ptr, bytes);
|
||||
stream->ptr += bytes;
|
||||
memstream_update_pos(stream);
|
||||
return bytes;
|
||||
}
|
||||
|
||||
@ -111,6 +122,7 @@ size_t memstream_write(memstream_t *stream, const void *data, size_t bytes)
|
||||
|
||||
memcpy(stream->buf + stream->ptr, data, bytes);
|
||||
stream->ptr += bytes;
|
||||
memstream_update_pos(stream);
|
||||
return bytes;
|
||||
}
|
||||
|
||||
@ -127,7 +139,7 @@ int memstream_seek(memstream_t *stream, int offset, int whence)
|
||||
ptr = stream->ptr + offset;
|
||||
break;
|
||||
case SEEK_END:
|
||||
ptr = stream->size + offset;
|
||||
ptr = (stream->writing ? stream->max_ptr : stream->size) + offset;
|
||||
break;
|
||||
default:
|
||||
return -1;
|
||||
@ -159,7 +171,20 @@ char *memstream_gets(memstream_t *stream, char *buffer, size_t len)
|
||||
|
||||
int memstream_getc(memstream_t *stream)
|
||||
{
|
||||
int ret = 0;
|
||||
if (stream->ptr >= stream->size)
|
||||
return EOF;
|
||||
return stream->buf[stream->ptr++];
|
||||
ret = stream->buf[stream->ptr++];
|
||||
|
||||
memstream_update_pos(stream);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
void memstream_putc(memstream_t *stream, int c)
|
||||
{
|
||||
if (stream->ptr < stream->size)
|
||||
stream->buf[stream->ptr++] = c;
|
||||
|
||||
memstream_update_pos(stream);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user