Split up file extract zlib driver code to separate file
This commit is contained in:
parent
9561332295
commit
78feccd0a3
|
@ -796,6 +796,7 @@ endif
|
||||||
|
|
||||||
ifeq ($(HAVE_ZLIB), 1)
|
ifeq ($(HAVE_ZLIB), 1)
|
||||||
OBJ += libretro-common/file/file_extract.o \
|
OBJ += libretro-common/file/file_extract.o \
|
||||||
|
libretro-common/file/file_extract_zlib.o \
|
||||||
tasks/task_decompress.o
|
tasks/task_decompress.o
|
||||||
OBJ += $(ZLIB_OBJS)
|
OBJ += $(ZLIB_OBJS)
|
||||||
DEFINES += -DHAVE_ZLIB
|
DEFINES += -DHAVE_ZLIB
|
||||||
|
|
|
@ -42,6 +42,7 @@ CONSOLE EXTENSIONS
|
||||||
|
|
||||||
#ifdef HAVE_ZLIB
|
#ifdef HAVE_ZLIB
|
||||||
#include "../libretro-common/file/file_extract.c"
|
#include "../libretro-common/file/file_extract.c"
|
||||||
|
#include "../libretro-common/file/file_extract_zlib.c"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*============================================================
|
/*============================================================
|
||||||
|
|
|
@ -20,11 +20,12 @@
|
||||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <compat/zlib.h>
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <compat/zlib.h>
|
|
||||||
#include <compat/strl.h>
|
#include <compat/strl.h>
|
||||||
|
|
||||||
#include <file/file_extract.h>
|
#include <file/file_extract.h>
|
||||||
|
@ -34,19 +35,6 @@
|
||||||
#include <retro_miscellaneous.h>
|
#include <retro_miscellaneous.h>
|
||||||
#include <string/string_list.h>
|
#include <string/string_list.h>
|
||||||
|
|
||||||
/* File backends. Can be fleshed out later, but keep it simple for now.
|
|
||||||
* The file is mapped to memory directly (via mmap() or just
|
|
||||||
* plain retro_read_file()).
|
|
||||||
*/
|
|
||||||
|
|
||||||
struct zlib_file_backend
|
|
||||||
{
|
|
||||||
void *(*open)(const char *path);
|
|
||||||
const uint8_t *(*data)(void *handle);
|
|
||||||
size_t (*size)(void *handle);
|
|
||||||
void (*free)(void *handle); /* Closes, unmaps and frees. */
|
|
||||||
};
|
|
||||||
|
|
||||||
#ifndef CENTRAL_FILE_HEADER_SIGNATURE
|
#ifndef CENTRAL_FILE_HEADER_SIGNATURE
|
||||||
#define CENTRAL_FILE_HEADER_SIGNATURE 0x02014b50
|
#define CENTRAL_FILE_HEADER_SIGNATURE 0x02014b50
|
||||||
#endif
|
#endif
|
||||||
|
@ -55,154 +43,11 @@ struct zlib_file_backend
|
||||||
#define END_OF_CENTRAL_DIR_SIGNATURE 0x06054b50
|
#define END_OF_CENTRAL_DIR_SIGNATURE 0x06054b50
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_MMAP
|
|
||||||
#include <fcntl.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
|
|
||||||
#include <sys/mman.h>
|
|
||||||
#include <sys/stat.h>
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
int fd;
|
|
||||||
void *data;
|
|
||||||
size_t size;
|
|
||||||
} zlib_file_data_t;
|
|
||||||
|
|
||||||
static void zlib_file_free(void *handle)
|
|
||||||
{
|
|
||||||
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
|
||||||
|
|
||||||
if (!data)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (data->data)
|
|
||||||
munmap(data->data, data->size);
|
|
||||||
if (data->fd >= 0)
|
|
||||||
close(data->fd);
|
|
||||||
free(data);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const uint8_t *zlib_file_data(void *handle)
|
|
||||||
{
|
|
||||||
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
|
||||||
if (!data)
|
|
||||||
return NULL;
|
|
||||||
return (const uint8_t*)data->data;
|
|
||||||
}
|
|
||||||
|
|
||||||
static size_t zlib_file_size(void *handle)
|
|
||||||
{
|
|
||||||
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
|
||||||
if (!data)
|
|
||||||
return 0;
|
|
||||||
return data->size;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void *zlib_file_open(const char *path)
|
|
||||||
{
|
|
||||||
zlib_file_data_t *data = (zlib_file_data_t*)calloc(1, sizeof(*data));
|
|
||||||
|
|
||||||
if (!data)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
data->fd = open(path, O_RDONLY);
|
|
||||||
|
|
||||||
/* Failed to open archive. */
|
|
||||||
if (data->fd < 0)
|
|
||||||
goto error;
|
|
||||||
|
|
||||||
data->size = path_get_size(path);
|
|
||||||
if (!data->size)
|
|
||||||
return data;
|
|
||||||
|
|
||||||
data->data = mmap(NULL, data->size, PROT_READ, MAP_SHARED, data->fd, 0);
|
|
||||||
if (data->data == MAP_FAILED)
|
|
||||||
{
|
|
||||||
data->data = NULL;
|
|
||||||
|
|
||||||
/* Failed to mmap() file */
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
|
|
||||||
return data;
|
|
||||||
|
|
||||||
error:
|
|
||||||
zlib_file_free(data);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
void *data;
|
|
||||||
size_t size;
|
|
||||||
} zlib_file_data_t;
|
|
||||||
|
|
||||||
static void zlib_file_free(void *handle)
|
|
||||||
{
|
|
||||||
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
|
||||||
if (!data)
|
|
||||||
return;
|
|
||||||
free(data->data);
|
|
||||||
free(data);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const uint8_t *zlib_file_data(void *handle)
|
|
||||||
{
|
|
||||||
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
|
||||||
if (!data)
|
|
||||||
return NULL;
|
|
||||||
return (const uint8_t*)data->data;
|
|
||||||
}
|
|
||||||
|
|
||||||
static size_t zlib_file_size(void *handle)
|
|
||||||
{
|
|
||||||
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
|
||||||
if (!data)
|
|
||||||
return 0;
|
|
||||||
return data->size;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void *zlib_file_open(const char *path)
|
|
||||||
{
|
|
||||||
ssize_t ret = -1;
|
|
||||||
bool read_from_file = false;
|
|
||||||
zlib_file_data_t *data = (zlib_file_data_t*)calloc(1, sizeof(*data));
|
|
||||||
|
|
||||||
if (!data)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
read_from_file = retro_read_file(path, &data->data, &ret);
|
|
||||||
|
|
||||||
if (!read_from_file || ret < 0)
|
|
||||||
{
|
|
||||||
/* Failed to open archive. */
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
|
|
||||||
data->size = ret;
|
|
||||||
return data;
|
|
||||||
|
|
||||||
error:
|
|
||||||
zlib_file_free(data);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static const struct zlib_file_backend zlib_backend = {
|
|
||||||
zlib_file_open,
|
|
||||||
zlib_file_data,
|
|
||||||
zlib_file_size,
|
|
||||||
zlib_file_free,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct zlib_file_backend *zlib_get_default_file_backend(void)
|
static const struct zlib_file_backend *zlib_get_default_file_backend(void)
|
||||||
{
|
{
|
||||||
return &zlib_backend;
|
return &zlib_backend;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#undef GOTO_END_ERROR
|
#undef GOTO_END_ERROR
|
||||||
#define GOTO_END_ERROR() do { \
|
#define GOTO_END_ERROR() do { \
|
||||||
ret = false; \
|
ret = false; \
|
||||||
|
|
|
@ -0,0 +1,171 @@
|
||||||
|
/* Copyright (C) 2010-2015 The RetroArch team
|
||||||
|
*
|
||||||
|
* ---------------------------------------------------------------------------------------
|
||||||
|
* The following license statement only applies to this file (file_extract_zlib.c).
|
||||||
|
* ---------------------------------------------------------------------------------------
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge,
|
||||||
|
* to any person obtaining a copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation the rights to
|
||||||
|
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software,
|
||||||
|
* and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
|
||||||
|
* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||||
|
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#ifdef HAVE_MMAP
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include <sys/mman.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <compat/zlib.h>
|
||||||
|
#include <file/file_extract.h>
|
||||||
|
#include <retro_file.h>
|
||||||
|
|
||||||
|
#ifdef HAVE_MMAP
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
int fd;
|
||||||
|
void *data;
|
||||||
|
size_t size;
|
||||||
|
} zlib_file_data_t;
|
||||||
|
|
||||||
|
static void zlib_file_free(void *handle)
|
||||||
|
{
|
||||||
|
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
||||||
|
|
||||||
|
if (!data)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (data->data)
|
||||||
|
munmap(data->data, data->size);
|
||||||
|
if (data->fd >= 0)
|
||||||
|
close(data->fd);
|
||||||
|
free(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
static const uint8_t *zlib_file_data(void *handle)
|
||||||
|
{
|
||||||
|
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
||||||
|
if (!data)
|
||||||
|
return NULL;
|
||||||
|
return (const uint8_t*)data->data;
|
||||||
|
}
|
||||||
|
|
||||||
|
static size_t zlib_file_size(void *handle)
|
||||||
|
{
|
||||||
|
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
||||||
|
if (!data)
|
||||||
|
return 0;
|
||||||
|
return data->size;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void *zlib_file_open(const char *path)
|
||||||
|
{
|
||||||
|
zlib_file_data_t *data = (zlib_file_data_t*)calloc(1, sizeof(*data));
|
||||||
|
|
||||||
|
if (!data)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
data->fd = open(path, O_RDONLY);
|
||||||
|
|
||||||
|
/* Failed to open archive. */
|
||||||
|
if (data->fd < 0)
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
data->size = path_get_size(path);
|
||||||
|
if (!data->size)
|
||||||
|
return data;
|
||||||
|
|
||||||
|
data->data = mmap(NULL, data->size, PROT_READ, MAP_SHARED, data->fd, 0);
|
||||||
|
if (data->data == MAP_FAILED)
|
||||||
|
{
|
||||||
|
data->data = NULL;
|
||||||
|
|
||||||
|
/* Failed to mmap() file */
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
return data;
|
||||||
|
|
||||||
|
error:
|
||||||
|
zlib_file_free(data);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
void *data;
|
||||||
|
size_t size;
|
||||||
|
} zlib_file_data_t;
|
||||||
|
|
||||||
|
static void zlib_file_free(void *handle)
|
||||||
|
{
|
||||||
|
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
||||||
|
if (!data)
|
||||||
|
return;
|
||||||
|
free(data->data);
|
||||||
|
free(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
static const uint8_t *zlib_file_data(void *handle)
|
||||||
|
{
|
||||||
|
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
||||||
|
if (!data)
|
||||||
|
return NULL;
|
||||||
|
return (const uint8_t*)data->data;
|
||||||
|
}
|
||||||
|
|
||||||
|
static size_t zlib_file_size(void *handle)
|
||||||
|
{
|
||||||
|
zlib_file_data_t *data = (zlib_file_data_t*)handle;
|
||||||
|
if (!data)
|
||||||
|
return 0;
|
||||||
|
return data->size;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void *zlib_file_open(const char *path)
|
||||||
|
{
|
||||||
|
ssize_t ret = -1;
|
||||||
|
bool read_from_file = false;
|
||||||
|
zlib_file_data_t *data = (zlib_file_data_t*)calloc(1, sizeof(*data));
|
||||||
|
|
||||||
|
if (!data)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
read_from_file = retro_read_file(path, &data->data, &ret);
|
||||||
|
|
||||||
|
if (!read_from_file || ret < 0)
|
||||||
|
{
|
||||||
|
/* Failed to open archive. */
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
data->size = ret;
|
||||||
|
return data;
|
||||||
|
|
||||||
|
error:
|
||||||
|
zlib_file_free(data);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
const struct zlib_file_backend zlib_backend = {
|
||||||
|
zlib_file_open,
|
||||||
|
zlib_file_data,
|
||||||
|
zlib_file_size,
|
||||||
|
zlib_file_free,
|
||||||
|
};
|
|
@ -55,6 +55,19 @@ typedef struct zlib_transfer
|
||||||
const struct zlib_file_backend *backend;
|
const struct zlib_file_backend *backend;
|
||||||
} zlib_transfer_t;
|
} zlib_transfer_t;
|
||||||
|
|
||||||
|
/* File backends. Can be fleshed out later, but keep it simple for now.
|
||||||
|
* The file is mapped to memory directly (via mmap() or just
|
||||||
|
* plain retro_read_file()).
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct zlib_file_backend
|
||||||
|
{
|
||||||
|
void *(*open)(const char *path);
|
||||||
|
const uint8_t *(*data)(void *handle);
|
||||||
|
size_t (*size)(void *handle);
|
||||||
|
void (*free)(void *handle); /* Closes, unmaps and frees. */
|
||||||
|
};
|
||||||
|
|
||||||
/* Returns true when parsing should continue. False to stop. */
|
/* Returns true when parsing should continue. False to stop. */
|
||||||
typedef int (*zlib_file_cb)(const char *name, const char *valid_exts,
|
typedef int (*zlib_file_cb)(const char *name, const char *valid_exts,
|
||||||
const uint8_t *cdata, unsigned cmode, uint32_t csize, uint32_t size,
|
const uint8_t *cdata, unsigned cmode, uint32_t csize, uint32_t size,
|
||||||
|
@ -173,5 +186,7 @@ uint64_t zlib_stream_get_total_out(void *data);
|
||||||
void zlib_stream_decrement_total_out(void *data,
|
void zlib_stream_decrement_total_out(void *data,
|
||||||
unsigned subtraction);
|
unsigned subtraction);
|
||||||
|
|
||||||
|
const struct zlib_file_backend zlib_backend;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue