#include "compiler.h"
#include "dosio.h"
static char curpath[MAX_PATH];
static char *curfilep = curpath;
void dosio_init(void) {
}
void dosio_term(void) {
}
/* ファイル操作 */
#if defined(TARGET_MONA)
FILEH file_open(const char *path) {
return(OpenFile(path));
}
FILEH file_open_rb(const char *path) {
return(OpenFile(path));
}
FILEH file_create(const char *path) {
return(FILEH_INVALID);
}
long file_seek(FILEH handle, long pointer, int method) {
return(file_seek(handle, pointer, method));
}
UINT file_read(FILEH handle, void *data, UINT length) {
return(ReadFile(handle, data, length));
}
UINT file_write(FILEH handle, const void *data, UINT length) {
return(0);
}
short file_close(FILEH handle) {
CloseFile(handle);
return(0);
}
UINT file_getsize(FILEH handle) {
return(GetFileSize(handle));
}
short file_getdatetime(FILEH handle, DOSDATE *dosdate, DOSTIME *dostime) {
return(-1);
}
short file_delete(const char *path) {
return(-1);
}
short file_attr(const char *path) {
return(-1);
}
short file_dircreate(const char *path) {
return(-1);
}
#else
FILEH file_open(const char *path) {
FILEH ret;
if ((ret = CreateFile(path, GENERIC_READ | GENERIC_WRITE,
0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL))
== INVALID_HANDLE_VALUE) {
if ((ret = CreateFile(path, GENERIC_READ,
0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL))
== INVALID_HANDLE_VALUE) {
return(FILEH_INVALID);
}
}
return(ret);
}
FILEH file_open_rb(const char *path) {
FILEH ret;
if ((ret = CreateFile(path, GENERIC_READ, FILE_SHARE_READ, 0,
OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL))
== INVALID_HANDLE_VALUE) {
return(FILEH_INVALID);
}
return(ret);
}
FILEH file_create(const char *path) {
FILEH ret;
if ((ret = CreateFile(path, GENERIC_READ | GENERIC_WRITE,
0, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL))
== INVALID_HANDLE_VALUE) {
return(FILEH_INVALID);
}
return(ret);
}
long file_seek(FILEH handle, long pointer, int method) {
return(SetFilePointer(handle, pointer, 0, method));
}
UINT file_read(FILEH handle, void *data, UINT length) {
DWORD readsize;
if (!ReadFile(handle, data, length, &readsize, NULL)) {
return(0);
}
return(readsize);
}
UINT file_write(FILEH handle, const void *data, UINT length) {
DWORD writesize;
if (length) {
if (WriteFile(handle, data, length, &writesize, NULL)) {
return(writesize);
}
}
else {
SetEndOfFile(handle);
}
return(0);
}
short file_close(FILEH handle) {
CloseHandle(handle);
return(0);
}
UINT file_getsize(FILEH handle) {
return(GetFileSize(handle, NULL));
}
static BOOL cnvdatetime(FILETIME *file, DOSDATE *dosdate, DOSTIME *dostime) {
FILETIME localtime;
SYSTEMTIME systime;
if ((FileTimeToLocalFileTime(file, &localtime) == 0) ||
(FileTimeToSystemTime(&localtime, &systime) == 0)) {
return(FAILURE);
}
if (dosdate) {
dosdate->year = (UINT16)systime.wYear;
dosdate->month = (UINT8)systime.wMonth;
dosdate->day = (UINT8)systime.wDay;
}
if (dostime) {
dostime->hour = (UINT8)systime.wHour;
dostime->minute = (UINT8)systime.wMinute;
dostime->second = (UINT8)systime.wSecond;
}
return(SUCCESS);
}
short file_getdatetime(FILEH handle, DOSDATE *dosdate, DOSTIME *dostime) {
FILETIME lastwrite;
if ((GetFileTime(handle, NULL, NULL, &lastwrite) == 0) ||
(cnvdatetime(&lastwrite, dosdate, dostime) != SUCCESS)) {
return(-1);
}
return(0);
}
short file_delete(const char *path) {
return(DeleteFile(path)?0:-1);
}
short file_attr(const char *path) {
return((short)GetFileAttributes(path));
}
short file_dircreate(const char *path) {
return(CreateDirectory(path, NULL)?0:-1);
}
#endif
/* カレントファイル操作 */
void file_setcd(const char *exepath) {
file_cpyname(curpath, exepath, sizeof(curpath));
curfilep = file_getname(curpath);
*curfilep = '\0';
}
char *file_getcd(const char *path) {
file_cpyname(curfilep, path, sizeof(curpath) - (curfilep - curpath));
return(curpath);
}
FILEH file_open_c(const char *path) {
file_cpyname(curfilep, path, sizeof(curpath) - (curfilep - curpath));
return(file_open(curpath));
}
FILEH file_open_rb_c(const char *path) {
file_cpyname(curfilep, path, sizeof(curpath) - (curfilep - curpath));
return(file_open_rb(curpath));
}
FILEH file_create_c(const char *path) {
file_cpyname(curfilep, path, sizeof(curpath) - (curfilep - curpath));
return(file_create(curpath));
}
short file_delete_c(const char *path) {
file_cpyname(curfilep, path, sizeof(curpath) - (curfilep - curpath));
return(file_delete(curpath));
}
short file_attr_c(const char *path) {
file_cpyname(curfilep, path, sizeof(curpath) - (curfilep - curpath));
return(file_attr_c(curpath));
}
#if defined(TARGET_MONA)
FLISTH file_list1st(const char *dir, FLINFO *fli) {
return(FLISTH_INVALID);
}
BOOL file_listnext(FLISTH hdl, FLINFO *fli) {
return(FAILURE);
}
void file_listclose(FLISTH hdl) {
}
#else
static BOOL setflist(WIN32_FIND_DATA *w32fd, FLINFO *fli) {
if ((w32fd->dwFileAttributes & FILEATTR_DIRECTORY) &&
((!file_cmpname(w32fd->cFileName, ".")) ||
(!file_cmpname(w32fd->cFileName, "..")))) {
return(FAILURE);
}
fli->caps = FLICAPS_SIZE | FLICAPS_ATTR;
fli->size = w32fd->nFileSizeLow;
fli->attr = w32fd->dwFileAttributes;
if (cnvdatetime(&w32fd->ftLastWriteTime, &fli->date, &fli->time)
== SUCCESS) {
fli->caps |= FLICAPS_DATE | FLICAPS_TIME;
}
file_cpyname(fli->path, w32fd->cFileName, sizeof(fli->path));
return(SUCCESS);
}
FLISTH file_list1st(const char *dir, FLINFO *fli) {
char path[MAX_PATH];
HANDLE hdl;
WIN32_FIND_DATA w32fd;
file_cpyname(path, dir, sizeof(path));
file_setseparator(path, sizeof(path));
file_catname(path, "*.*", sizeof(path));
hdl = FindFirstFile(path, &w32fd);
if (hdl != INVALID_HANDLE_VALUE) {
do {
if (setflist(&w32fd, fli) == SUCCESS) {
return(hdl);
}
} while(FindNextFile(hdl, &w32fd));
FindClose(hdl);
}
return(FLISTH_INVALID);
}
BOOL file_listnext(FLISTH hdl, FLINFO *fli) {
WIN32_FIND_DATA w32fd;
while(FindNextFile(hdl, &w32fd)) {
if (setflist(&w32fd, fli) == SUCCESS) {
return(SUCCESS);
}
}
return(FAILURE);
}
void file_listclose(FLISTH hdl) {
FindClose(hdl);
}
#endif
void file_catname(char *path, const char *name, int maxlen) {
int csize;
while(maxlen > 0) {
if (*path == '\0') {
break;
}
path++;
maxlen--;
}
file_cpyname(path, name, maxlen);
while((csize = milstr_charsize(path)) != 0) {
if ((csize == 1) && (*path == '\\')) {
*path = '/';
}
path += csize;
}
}
char *file_getname(const char *path) {
const char *ret;
int csize;
ret = path;
while((csize = milstr_charsize(path)) != 0) {
if ((csize == 1) && (*path == '/')) {
ret = path + 1;
}
path += csize;
}
return((char *)ret);
}
void file_cutname(char *path) {
char *p;
p = file_getname(path);
*p = '\0';
}
char *file_getext(const char *path) {
const char *p;
const char *q;
p = file_getname(path);
q = NULL;
while(*p != '\0') {
if (*p == '.') {
q = p + 1;
}
p++;
}
if (q == NULL) {
q = p;
}
return((char *)q);
}
void file_cutext(char *path) {
char *p;
char *q;
p = file_getname(path);
q = NULL;
while(*p != '\0') {
if (*p == '.') {
q = p;
}
p++;
}
if (q != NULL) {
*q = '\0';
}
}
void file_cutseparator(char *path) {
int pos;
pos = strlen(path) - 1;
if ((pos > 0) && // 2文字以上でー
(path[pos] == '/') && // ケツが \ でー
((pos != 1) || (path[0] != '.'))) { // './' ではなかったら
path[pos] = '\0';
}
}
void file_setseparator(char *path, int maxlen) {
int pos;
pos = strlen(path);
if ((pos) && (path[pos-1] != '/') && ((pos + 2) < maxlen)) {
path[pos++] = '/';
path[pos] = '\0';
}
}
RetroPC.NET-CVS <cvs@retropc.net>