mirror of
https://github.com/libretro/RetroArch.git
synced 2024-11-24 00:20:01 +00:00
(VITA) Fix File Reading
This commit is contained in:
parent
62281f88ac
commit
3cf448b6e2
@ -38,22 +38,15 @@
|
|||||||
# include <direct.h>
|
# include <direct.h>
|
||||||
# include <windows.h>
|
# include <windows.h>
|
||||||
# endif
|
# endif
|
||||||
#elif defined(VITA)
|
|
||||||
# include <psp2/io/fcntl.h>
|
|
||||||
# include <psp2/io/dirent.h>
|
|
||||||
|
|
||||||
#define PSP_O_RDONLY SCE_O_RDONLY
|
|
||||||
#define PSP_O_RDWR SCE_O_RDWR
|
|
||||||
#define PSP_O_CREAT SCE_O_CREAT
|
|
||||||
#define PSP_O_WRONLY SCE_O_WRONLY
|
|
||||||
#define PSP_O_TRUNC SCE_O_TRUNC
|
|
||||||
#else
|
#else
|
||||||
# if defined(PSP)
|
# if defined(PSP)
|
||||||
# include <pspiofilemgr.h>
|
# include <pspiofilemgr.h>
|
||||||
# endif
|
# endif
|
||||||
# include <sys/types.h>
|
# include <sys/types.h>
|
||||||
# include <sys/stat.h>
|
# include <sys/stat.h>
|
||||||
|
# if !defined(VITA)
|
||||||
# include <dirent.h>
|
# include <dirent.h>
|
||||||
|
# endif
|
||||||
# include <unistd.h>
|
# include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -74,7 +67,7 @@
|
|||||||
struct RFILE
|
struct RFILE
|
||||||
{
|
{
|
||||||
unsigned hints;
|
unsigned hints;
|
||||||
#if defined(PSP) || defined(VITA)
|
#if defined(PSP)
|
||||||
SceUID fd;
|
SceUID fd;
|
||||||
#else
|
#else
|
||||||
|
|
||||||
@ -130,7 +123,7 @@ RFILE *filestream_open(const char *path, unsigned mode, ssize_t len)
|
|||||||
switch (mode & 0xff)
|
switch (mode & 0xff)
|
||||||
{
|
{
|
||||||
case RFILE_MODE_READ_TEXT:
|
case RFILE_MODE_READ_TEXT:
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
mode_int = 0666;
|
mode_int = 0666;
|
||||||
flags = PSP_O_RDONLY;
|
flags = PSP_O_RDONLY;
|
||||||
#else
|
#else
|
||||||
@ -143,7 +136,7 @@ RFILE *filestream_open(const char *path, unsigned mode, ssize_t len)
|
|||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case RFILE_MODE_READ:
|
case RFILE_MODE_READ:
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
mode_int = 0666;
|
mode_int = 0666;
|
||||||
flags = PSP_O_RDONLY;
|
flags = PSP_O_RDONLY;
|
||||||
#else
|
#else
|
||||||
@ -156,8 +149,8 @@ RFILE *filestream_open(const char *path, unsigned mode, ssize_t len)
|
|||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case RFILE_MODE_WRITE:
|
case RFILE_MODE_WRITE:
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
mode_int = 0777;
|
mode_int = 0666;
|
||||||
flags = PSP_O_CREAT | PSP_O_WRONLY | PSP_O_TRUNC;
|
flags = PSP_O_CREAT | PSP_O_WRONLY | PSP_O_TRUNC;
|
||||||
#else
|
#else
|
||||||
#if defined(HAVE_BUFFERED_IO)
|
#if defined(HAVE_BUFFERED_IO)
|
||||||
@ -174,8 +167,8 @@ RFILE *filestream_open(const char *path, unsigned mode, ssize_t len)
|
|||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case RFILE_MODE_READ_WRITE:
|
case RFILE_MODE_READ_WRITE:
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
mode_int = 0777;
|
mode_int = 0666;
|
||||||
flags = PSP_O_RDWR;
|
flags = PSP_O_RDWR;
|
||||||
#else
|
#else
|
||||||
#if defined(HAVE_BUFFERED_IO)
|
#if defined(HAVE_BUFFERED_IO)
|
||||||
@ -193,7 +186,7 @@ RFILE *filestream_open(const char *path, unsigned mode, ssize_t len)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
stream->fd = sceIoOpen(path, flags, mode_int);
|
stream->fd = sceIoOpen(path, flags, mode_int);
|
||||||
#else
|
#else
|
||||||
#if defined(HAVE_BUFFERED_IO)
|
#if defined(HAVE_BUFFERED_IO)
|
||||||
@ -231,7 +224,7 @@ RFILE *filestream_open(const char *path, unsigned mode, ssize_t len)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
if (stream->fd == -1)
|
if (stream->fd == -1)
|
||||||
goto error;
|
goto error;
|
||||||
#endif
|
#endif
|
||||||
@ -284,7 +277,7 @@ char *filestream_gets(RFILE *stream, char *s, size_t len)
|
|||||||
return NULL;
|
return NULL;
|
||||||
#if defined(HAVE_BUFFERED_IO)
|
#if defined(HAVE_BUFFERED_IO)
|
||||||
return fgets(s, len, stream->fp);
|
return fgets(s, len, stream->fp);
|
||||||
#elif defined(VITA) || defined(PSP)
|
#elif defined(PSP)
|
||||||
if(filestream_read(stream,s,len)==len)
|
if(filestream_read(stream,s,len)==len)
|
||||||
return s;
|
return s;
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -301,7 +294,7 @@ int filestream_getc(RFILE *stream)
|
|||||||
return 0;
|
return 0;
|
||||||
#if defined(HAVE_BUFFERED_IO)
|
#if defined(HAVE_BUFFERED_IO)
|
||||||
return fgetc(stream->fp);
|
return fgetc(stream->fp);
|
||||||
#elif defined(VITA) || defined(PSP)
|
#elif defined(PSP)
|
||||||
if(filestream_read(stream, &c, 1) == 1)
|
if(filestream_read(stream, &c, 1) == 1)
|
||||||
return (int)c;
|
return (int)c;
|
||||||
return EOF;
|
return EOF;
|
||||||
@ -315,7 +308,7 @@ ssize_t filestream_seek(RFILE *stream, ssize_t offset, int whence)
|
|||||||
if (!stream)
|
if (!stream)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
if (sceIoLseek(stream->fd, (SceOff)offset, whence) == -1)
|
if (sceIoLseek(stream->fd, (SceOff)offset, whence) == -1)
|
||||||
goto error;
|
goto error;
|
||||||
#else
|
#else
|
||||||
@ -387,7 +380,7 @@ ssize_t filestream_tell(RFILE *stream)
|
|||||||
{
|
{
|
||||||
if (!stream)
|
if (!stream)
|
||||||
goto error;
|
goto error;
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
if (sceIoLseek(stream->fd, 0, SEEK_CUR) < 0)
|
if (sceIoLseek(stream->fd, 0, SEEK_CUR) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
#else
|
#else
|
||||||
@ -420,7 +413,7 @@ ssize_t filestream_read(RFILE *stream, void *s, size_t len)
|
|||||||
{
|
{
|
||||||
if (!stream || !s)
|
if (!stream || !s)
|
||||||
goto error;
|
goto error;
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
return sceIoRead(stream->fd, s, len);
|
return sceIoRead(stream->fd, s, len);
|
||||||
#else
|
#else
|
||||||
#if defined(HAVE_BUFFERED_IO)
|
#if defined(HAVE_BUFFERED_IO)
|
||||||
@ -453,7 +446,7 @@ ssize_t filestream_write(RFILE *stream, const void *s, size_t len)
|
|||||||
{
|
{
|
||||||
if (!stream)
|
if (!stream)
|
||||||
goto error;
|
goto error;
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
return sceIoWrite(stream->fd, s, len);
|
return sceIoWrite(stream->fd, s, len);
|
||||||
#else
|
#else
|
||||||
#if defined(HAVE_BUFFERED_IO)
|
#if defined(HAVE_BUFFERED_IO)
|
||||||
@ -489,7 +482,7 @@ int filestream_close(RFILE *stream)
|
|||||||
if (!stream)
|
if (!stream)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
#if defined(VITA) || defined(PSP)
|
#if defined(PSP)
|
||||||
if (stream->fd > 0)
|
if (stream->fd > 0)
|
||||||
sceIoClose(stream->fd);
|
sceIoClose(stream->fd);
|
||||||
#else
|
#else
|
||||||
|
Loading…
Reference in New Issue
Block a user