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