Bug fixes to GFILE.

This commit is contained in:
inmarket 2014-02-07 18:43:39 +10:00
parent da122c6d48
commit f7d6b9b58e
4 changed files with 31 additions and 19 deletions

View File

@ -16,7 +16,7 @@
#include <stdio.h> #include <stdio.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> //#include <unistd.h>
static GFILE NativeStdIn; static GFILE NativeStdIn;
static GFILE NativeStdOut; static GFILE NativeStdOut;
@ -50,7 +50,7 @@ static const GFILEVMT FsNativeVMT = {
#undef GFILE_CHAINHEAD #undef GFILE_CHAINHEAD
#define GFILE_CHAINHEAD &FsNativeVMT #define GFILE_CHAINHEAD &FsNativeVMT
static char *flags2mode(char *buf, uint16_t flags) { static void flags2mode(char *buf, uint16_t flags) {
if (flags & GFILEFLG_MUSTEXIST) if (flags & GFILEFLG_MUSTEXIST)
*buf = 'r'; *buf = 'r';
else if (flags & GFILEFLG_APPEND) else if (flags & GFILEFLG_APPEND)
@ -67,32 +67,36 @@ static char *flags2mode(char *buf, uint16_t flags) {
*buf++ = 0; *buf++ = 0;
} }
static bool_t NativeDel(const char *fname) { return remove(fname) ? FALSE : TRUE; } static bool_t NativeDel(const char *fname) { return remove(fname) ? FALSE : TRUE; }
static bool_t NativeExists(const char *fname) { return access(fname, 0) ? FALSE : TRUE; } static void NativeClose(GFILE *f) { fclose((FILE *)f->obj); }
static int NativeRead(GFILE *f, void *buf, int size) { return fread(buf, 1, size, (FILE *)f->obj); }
static int NativeWrite(GFILE *f, const void *buf, int size) { return fwrite(buf, 1, size, (FILE *)f->obj); }
static bool_t NativeSetpos(GFILE *f, long int pos) { return fseek((FILE *)f->obj, pos, SEEK_SET) ? FALSE : TRUE; }
static bool_t NativeEof(GFILE *f) { return feof((FILE *)f->obj) ? TRUE : FALSE; }
static bool_t NativeRen(const char *oldname, const char *newname) { return rename(oldname, newname) ? FALSE : TRUE; }
static bool_t NativeExists(const char *fname) {
// We define access this way so we don't have to include <unistd.h> which may
// (and does under windows) contain conflicting definitions for types such as uint16_t.
extern int access(const char *pathname, int mode);
return access(fname, 0) ? FALSE : TRUE;
}
static long int NativeFilesize(const char *fname) { static long int NativeFilesize(const char *fname) {
struct stat st; struct stat st;
if (stat(fname, &st)) return -1; if (stat(fname, &st)) return -1;
return st.st_size; return st.st_size;
} }
static bool_t NativeRen(const char *oldname, const char *newname) { return rename(oldname, newname) ? FALSE : TRUE };
static bool_t NativeOpen(GFILE *f, const char *fname) { static bool_t NativeOpen(GFILE *f, const char *fname) {
FILE *fd; FILE *fd;
char mode[5]; char mode[5];
flags2mode(mode, f->flags);
if (!(fd = fopen(fname, mode))) if (!(fd = fopen(fname, mode)))
return FALSE; return FALSE;
f->obj = (void *)fd; f->obj = (void *)fd;
return TRUE; return TRUE;
} }
static void NativeClose(GFILE *f) { fclose((FILE *)f->obj); }
static int NativeRead(GFILE *f, void *buf, int size) { return fread(buf, 1, size, (FILE *)f->obj); }
static int NativeWrite(GFILE *f, const void *buf, int size) { return fwrite(buf, 1, size, (FILE *)f->obj); }
static bool_t NativeSetpos(GFILE *f, long int pos) {
return fseek((FILE *)f->obj, pos, SEEK_SET) ? FALSE : TRUE;
}
static long int NativeGetsize(GFILE *f) { static long int NativeGetsize(GFILE *f) {
struct stat st; struct stat st;
if (fstat(fileno((FILE *)f->obj), &st)) return -1; if (fstat(fileno((FILE *)f->obj), &st)) return -1;
return st.st_size; return st.st_size;
} }
static bool_t NativeEof(GFILE *f) { return feof((FILE *)f->obj) ? TRUE : FALSE; }

View File

@ -15,11 +15,19 @@
#include <string.h> #include <string.h>
// What directory file formats do we understand
#define ROMFS_DIR_VER_MAX 0x0000
// Compression Formats
#define ROMFS_CMP_UNCOMPRESSED 0
typedef struct ROMFS_DIRENTRY { typedef struct ROMFS_DIRENTRY {
const struct ROMFS_DIRENTRY * next; uint16_t ver; // Directory Entry Version
const char * name; uint16_t cmp; // Compression format
long int size; const struct ROMFS_DIRENTRY * next; // The next entry
const char * file; const char * name; // The file name
long int size; // The file size
const char * file; // The file data
} ROMFS_DIRENTRY; } ROMFS_DIRENTRY;
#define ROMFS_DIRENTRY_HEAD 0 #define ROMFS_DIRENTRY_HEAD 0
@ -48,11 +56,11 @@ static const GFILEVMT FsROMVMT = {
#undef GFILE_CHAINHEAD #undef GFILE_CHAINHEAD
#define GFILE_CHAINHEAD &FsROMVMT #define GFILE_CHAINHEAD &FsROMVMT
static ROMFS_DIRENTRY *ROMFindFile(const char *fname) { static const ROMFS_DIRENTRY *ROMFindFile(const char *fname) {
const ROMFS_DIRENTRY *p; const ROMFS_DIRENTRY *p;
for(p = FsROMHead; p; p = p->next) { for(p = FsROMHead; p; p = p->next) {
if (!strcmp(p->name, fname)) if (p->ver <= ROMFS_DIR_VER_MAX && p->cmp == ROMFS_CMP_UNCOMPRESSED && !strcmp(p->name, fname))
break; break;
} }
return p; return p;

View File

@ -195,7 +195,7 @@ size_t i;
/* Add the directory entry if required */ /* Add the directory entry if required */
if (opt_romdir) { if (opt_romdir) {
fprintf(f_output, "\n#ifdef ROMFS_DIRENTRY_HEAD\n"); fprintf(f_output, "\n#ifdef ROMFS_DIRENTRY_HEAD\n");
fprintf(f_output, "\t%s%sROMFS_DIRENTRY %s_dir = { ROMFS_DIRENTRY_HEAD, \"%s\", %u, %s };\n", opt_static, opt_const, opt_arrayname, opt_dirname, totallen, opt_arrayname); fprintf(f_output, "\t%s%sROMFS_DIRENTRY %s_dir = { 0, 0, ROMFS_DIRENTRY_HEAD, \"%s\", %u, %s };\n", opt_static, opt_const, opt_arrayname, opt_dirname, totallen, opt_arrayname);
fprintf(f_output, "\t#undef ROMFS_DIRENTRY_HEAD\n\t#define ROMFS_DIRENTRY_HEAD &%s_dir\n#endif\n", opt_arrayname); fprintf(f_output, "\t#undef ROMFS_DIRENTRY_HEAD\n\t#define ROMFS_DIRENTRY_HEAD &%s_dir\n#endif\n", opt_arrayname);
} }