* Get rid of RFILE_MODE_READ_TEXT

* Get rid of PSP ifdef sinside file_stream.c
This commit is contained in:
twinaphex 2017-12-10 22:05:24 +01:00
parent 40f82c26f7
commit a8e031777e
3 changed files with 7 additions and 75 deletions

View File

@ -41,7 +41,6 @@ typedef struct RFILE RFILE;
enum enum
{ {
RFILE_MODE_READ = 0, RFILE_MODE_READ = 0,
RFILE_MODE_READ_TEXT,
RFILE_MODE_WRITE, RFILE_MODE_WRITE,
RFILE_MODE_READ_WRITE, RFILE_MODE_READ_WRITE,

View File

@ -86,9 +86,6 @@ struct RFILE
char *ext; char *ext;
int64_t size; int64_t size;
FILE *fp; FILE *fp;
#if defined(PSP)
SceUID fd;
#else
#define HAVE_BUFFERED_IO 1 #define HAVE_BUFFERED_IO 1
@ -110,7 +107,6 @@ struct RFILE
uint64_t mapsize; uint64_t mapsize;
#endif #endif
int fd; int fd;
#endif
char *buf; char *buf;
}; };
@ -185,36 +181,22 @@ RFILE *filestream_open(const char *path, unsigned mode, ssize_t unused)
switch (mode & 0xff) switch (mode & 0xff)
{ {
case RFILE_MODE_READ_TEXT: case RFILE_MODE_READ_TEXT:
#if defined(PSP)
mode_int = 0666;
flags = PSP_O_RDONLY;
#else
#if defined(HAVE_BUFFERED_IO) #if defined(HAVE_BUFFERED_IO)
if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0) if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0)
mode_str = MODE_STR_READ; mode_str = MODE_STR_READ;
#endif #endif
/* No "else" here */ /* No "else" here */
flags = O_RDONLY; flags = O_RDONLY;
#endif
break; break;
case RFILE_MODE_READ: case RFILE_MODE_READ:
#if defined(PSP)
mode_int = 0666;
flags = PSP_O_RDONLY;
#else
#if defined(HAVE_BUFFERED_IO) #if defined(HAVE_BUFFERED_IO)
if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0) if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0)
mode_str = MODE_STR_READ_UNBUF; mode_str = MODE_STR_READ_UNBUF;
#endif #endif
/* No "else" here */ /* No "else" here */
flags = O_RDONLY; flags = O_RDONLY;
#endif
break; break;
case RFILE_MODE_WRITE: case RFILE_MODE_WRITE:
#if defined(PSP)
mode_int = 0666;
flags = PSP_O_CREAT | PSP_O_WRONLY | PSP_O_TRUNC;
#else
#if defined(HAVE_BUFFERED_IO) #if defined(HAVE_BUFFERED_IO)
if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0) if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0)
mode_str = MODE_STR_WRITE_UNBUF; mode_str = MODE_STR_WRITE_UNBUF;
@ -226,13 +208,8 @@ RFILE *filestream_open(const char *path, unsigned mode, ssize_t unused)
flags |= S_IRUSR | S_IWUSR; flags |= S_IRUSR | S_IWUSR;
#endif #endif
} }
#endif
break; break;
case RFILE_MODE_READ_WRITE: case RFILE_MODE_READ_WRITE:
#if defined(PSP)
mode_int = 0666;
flags = PSP_O_RDWR;
#else
#if defined(HAVE_BUFFERED_IO) #if defined(HAVE_BUFFERED_IO)
if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0) if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0)
mode_str = MODE_STR_WRITE_PLUS; mode_str = MODE_STR_WRITE_PLUS;
@ -244,16 +221,9 @@ RFILE *filestream_open(const char *path, unsigned mode, ssize_t unused)
flags |= O_BINARY; flags |= O_BINARY;
#endif #endif
} }
#endif
break; break;
} }
#if defined(PSP)
stream->fd = sceIoOpen(path, flags, mode_int);
if (stream->fd < 0)
goto error;
#else
#if defined(HAVE_BUFFERED_IO) #if defined(HAVE_BUFFERED_IO)
if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0 && mode_str) if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0 && mode_str)
{ {
@ -335,7 +305,6 @@ RFILE *filestream_open(const char *path, unsigned mode, ssize_t unused)
} }
#endif #endif
} }
#endif
{ {
const char *ld = (const char*)strrchr(path, '.'); const char *ld = (const char*)strrchr(path, '.');
@ -391,15 +360,7 @@ char *filestream_gets(RFILE *stream, char *s, size_t len)
{ {
if (!stream) if (!stream)
return NULL; return NULL;
#if defined(HAVE_BUFFERED_IO)
return fgets(s, (int)len, stream->fp); return fgets(s, (int)len, stream->fp);
#elif defined(PSP)
if(filestream_read(stream,s,len)==len)
return s;
return NULL;
#else
return gets(s);
#endif
} }
int filestream_getc(RFILE *stream) int filestream_getc(RFILE *stream)
@ -408,15 +369,7 @@ int filestream_getc(RFILE *stream)
(void)c; (void)c;
if (!stream) if (!stream)
return 0; return 0;
#if defined(HAVE_BUFFERED_IO)
return fgetc(stream->fp); return fgetc(stream->fp);
#elif defined(PSP)
if(filestream_read(stream, &c, 1) == 1)
return (int)c;
return EOF;
#else
return getc(stream->fd);
#endif
} }
ssize_t filestream_seek(RFILE *stream, ssize_t offset, int whence) ssize_t filestream_seek(RFILE *stream, ssize_t offset, int whence)
@ -424,11 +377,6 @@ ssize_t filestream_seek(RFILE *stream, ssize_t offset, int whence)
if (!stream) if (!stream)
goto error; goto error;
#if defined(PSP)
if (sceIoLseek(stream->fd, (SceOff)offset, whence) == -1)
goto error;
#else
#if defined(HAVE_BUFFERED_IO) #if defined(HAVE_BUFFERED_IO)
if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0) if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0)
return fseek(stream->fp, (long)offset, whence); return fseek(stream->fp, (long)offset, whence);
@ -472,8 +420,6 @@ ssize_t filestream_seek(RFILE *stream, ssize_t offset, int whence)
if (lseek(stream->fd, offset, whence) < 0) if (lseek(stream->fd, offset, whence) < 0)
goto error; goto error;
#endif
return 0; return 0;
error: error:
@ -508,10 +454,7 @@ ssize_t filestream_tell(RFILE *stream)
{ {
if (!stream) if (!stream)
goto error; goto error;
#if defined(PSP)
if (sceIoLseek(stream->fd, 0, SEEK_CUR) < 0)
goto error;
#else
#if defined(HAVE_BUFFERED_IO) #if defined(HAVE_BUFFERED_IO)
if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0) if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0)
return ftell(stream->fp); return ftell(stream->fp);
@ -524,7 +467,6 @@ ssize_t filestream_tell(RFILE *stream)
#endif #endif
if (lseek(stream->fd, 0, SEEK_CUR) < 0) if (lseek(stream->fd, 0, SEEK_CUR) < 0)
goto error; goto error;
#endif
return 0; return 0;
@ -541,13 +483,12 @@ ssize_t filestream_read(RFILE *stream, void *s, size_t len)
{ {
if (!stream || !s) if (!stream || !s)
goto error; goto error;
#if defined(PSP)
return sceIoRead(stream->fd, s, len);
#else
#if defined(HAVE_BUFFERED_IO) #if defined(HAVE_BUFFERED_IO)
if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0) if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0)
return fread(s, 1, len, stream->fp); return fread(s, 1, len, stream->fp);
#endif #endif
#ifdef HAVE_MMAP #ifdef HAVE_MMAP
if (stream->hints & RFILE_HINT_MMAP) if (stream->hints & RFILE_HINT_MMAP)
{ {
@ -563,8 +504,8 @@ ssize_t filestream_read(RFILE *stream, void *s, size_t len)
return len; return len;
} }
#endif #endif
return read(stream->fd, s, len); return read(stream->fd, s, len);
#endif
error: error:
return -1; return -1;
@ -583,9 +524,7 @@ ssize_t filestream_write(RFILE *stream, const void *s, size_t len)
{ {
if (!stream) if (!stream)
goto error; goto error;
#if defined(PSP)
return sceIoWrite(stream->fd, s, len);
#else
#if defined(HAVE_BUFFERED_IO) #if defined(HAVE_BUFFERED_IO)
if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0) if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0)
return fwrite(s, 1, len, stream->fp); return fwrite(s, 1, len, stream->fp);
@ -595,7 +534,6 @@ ssize_t filestream_write(RFILE *stream, const void *s, size_t len)
goto error; goto error;
#endif #endif
return write(stream->fd, s, len); return write(stream->fd, s, len);
#endif
error: error:
return -1; return -1;
@ -655,10 +593,6 @@ int filestream_close(RFILE *stream)
if (!string_is_empty(stream->ext)) if (!string_is_empty(stream->ext))
free(stream->ext); free(stream->ext);
#if defined(PSP)
if (stream->fd > 0)
sceIoClose(stream->fd);
#else
#if defined(HAVE_BUFFERED_IO) #if defined(HAVE_BUFFERED_IO)
if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0) if ((stream->hints & RFILE_HINT_UNBUFFERED) == 0)
{ {
@ -674,7 +608,6 @@ int filestream_close(RFILE *stream)
if (stream->fd > 0) if (stream->fd > 0)
close(stream->fd); close(stream->fd);
#endif
if (stream->buf) if (stream->buf)
free(stream->buf); free(stream->buf);
free(stream); free(stream);

View File

@ -26,7 +26,7 @@
RFILE* rfopen(const char *path, const char *mode) RFILE* rfopen(const char *path, const char *mode)
{ {
unsigned int retro_mode = RFILE_MODE_READ_TEXT; unsigned int retro_mode = 0;
if (strstr(mode, "r")) if (strstr(mode, "r"))
if (strstr(mode, "b")) if (strstr(mode, "b"))
retro_mode = RFILE_MODE_READ; retro_mode = RFILE_MODE_READ;