|
|
| version 1.1.1.1, 2003/10/16 17:59:32 | version 1.6, 2004/06/20 02:57:47 |
|---|---|
| Line 2 | Line 2 |
| #include "dosio.h" | #include "dosio.h" |
| static char curpath[MAX_PATH]; | static OEMCHAR curpath[MAX_PATH]; |
| static char *curfilep = curpath; | static OEMCHAR *curfilep = curpath; |
| #define ISKANJI(c) (((((c) ^ 0x20) - 0xa1) & 0xff) < 0x3c) | // #define ISKANJI(c) (((((c) ^ 0x20) - 0xa1) & 0xff) < 0x3c) |
| #if defined(UNICODE) | #if defined(UNICODE) |
| Line 17 static HANDLE CreateFile_A(LPCSTR lpFile | Line 17 static HANDLE CreateFile_A(LPCSTR lpFile |
| DWORD dwFlagsAndAttributes, | DWORD dwFlagsAndAttributes, |
| HANDLE hTemplateFile) { | HANDLE hTemplateFile) { |
| TCHAR FileNameW[MAX_PATH*2]; | UINT16 FileNameW[MAX_PATH]; |
| #if defined(OSLANG_SJIS) | |
| MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, lpFileName, -1, | MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, lpFileName, -1, |
| FileNameW, sizeof(FileNameW)/sizeof(TCHAR)); | FileNameW, sizeof(FileNameW)/sizeof(UINT16)); |
| #else | |
| ucscnv_utf8toucs2(FileNameW, sizeof(FileNameW)/sizeof(UINT16), | |
| lpFileName, (UINT)-1); | |
| #endif | |
| return(CreateFile(FileNameW, dwDesiredAccess, dwShareMode, | return(CreateFile(FileNameW, dwDesiredAccess, dwShareMode, |
| lpSecurityAttributes, dwCreationDisposition, | lpSecurityAttributes, dwCreationDisposition, |
| dwFlagsAndAttributes, hTemplateFile)); | dwFlagsAndAttributes, hTemplateFile)); |
| Line 28 static HANDLE CreateFile_A(LPCSTR lpFile | Line 33 static HANDLE CreateFile_A(LPCSTR lpFile |
| static inline BOOL DeleteFile_A(LPCSTR lpFileName) { | static inline BOOL DeleteFile_A(LPCSTR lpFileName) { |
| TCHAR FileNameW[MAX_PATH*2]; | UINT16 FileNameW[MAX_PATH]; |
| #if defined(OSLANG_SJIS) | |
| MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, lpFileName, -1, | MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, lpFileName, -1, |
| FileNameW, sizeof(FileNameW)/sizeof(TCHAR)); | FileNameW, sizeof(FileNameW)/sizeof(UINT16)); |
| #else | |
| ucscnv_utf8toucs2(FileNameW, sizeof(FileNameW)/sizeof(UINT16), | |
| lpFileName, (UINT)-1); | |
| #endif | |
| return(DeleteFile(FileNameW)); | return(DeleteFile(FileNameW)); |
| } | } |
| static inline DWORD GetFileAttributes_A(LPCSTR lpFileName) { | static inline DWORD GetFileAttributes_A(LPCSTR lpFileName) { |
| TCHAR FileNameW[MAX_PATH*2]; | UINT16 FileNameW[MAX_PATH]; |
| #if defined(OSLANG_SJIS) | |
| MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, lpFileName, -1, | MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, lpFileName, -1, |
| FileNameW, sizeof(FileNameW)/sizeof(TCHAR)); | FileNameW, sizeof(FileNameW)/sizeof(UINT16)); |
| #else | |
| ucscnv_utf8toucs2(FileNameW, sizeof(FileNameW)/sizeof(UINT16), | |
| lpFileName, (UINT)-1); | |
| #endif | |
| return(GetFileAttributes(FileNameW)); | return(GetFileAttributes(FileNameW)); |
| } | } |
| static inline BOOL CreateDirectory_A(LPCSTR lpFileName, | static inline BOOL CreateDirectory_A(LPCSTR lpFileName, |
| LPSECURITY_ATTRIBUTES atr) { | LPSECURITY_ATTRIBUTES atr) { |
| TCHAR FileNameW[MAX_PATH*2]; | UINT16 FileNameW[MAX_PATH]; |
| #if defined(OSLANG_SJIS) | |
| MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, lpFileName, -1, | MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, lpFileName, -1, |
| FileNameW, sizeof(FileNameW)/sizeof(TCHAR)); | FileNameW, sizeof(FileNameW)/sizeof(UINT16)); |
| #else | |
| ucscnv_utf8toucs2(FileNameW, sizeof(FileNameW)/sizeof(UINT16), | |
| lpFileName, (UINT)-1); | |
| #endif | |
| return(CreateDirectory(FileNameW, atr)); | return(CreateDirectory(FileNameW, atr)); |
| } | } |
| static inline HANDLE FindFirstFile_A(LPCSTR lpFileName, | static inline HANDLE FindFirstFile_A(LPCSTR lpFileName, |
| WIN32_FIND_DATA *w32fd) { | WIN32_FIND_DATA *w32fd) { |
| TCHAR FileNameW[MAX_PATH*2]; | UINT16 FileNameW[MAX_PATH]; |
| #if defined(OSLANG_SJIS) | |
| MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, lpFileName, -1, | MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, lpFileName, -1, |
| FileNameW, sizeof(FileNameW)/sizeof(TCHAR)); | FileNameW, sizeof(FileNameW)/sizeof(UINT16)); |
| #else | |
| ucscnv_utf8toucs2(FileNameW, sizeof(FileNameW)/sizeof(UINT16), | |
| lpFileName, (UINT)-1); | |
| #endif | |
| return(FindFirstFile(FileNameW, w32fd)); | return(FindFirstFile(FileNameW, w32fd)); |
| } | } |
| #else | #else |
| Line 162 UINT file_getsize(FILEH handle) { | Line 187 UINT file_getsize(FILEH handle) { |
| return(GetFileSize(handle, NULL)); | return(GetFileSize(handle, NULL)); |
| } | } |
| short file_getdatetime(FILEH handle, DOSDATE *dosdate, DOSTIME *dostime) { | static BOOL cnvdatetime(FILETIME *file, DOSDATE *dosdate, DOSTIME *dostime) { |
| FILETIME lastwrite; | FILETIME localtime; |
| FILETIME localwrite; | SYSTEMTIME systime; |
| SYSTEMTIME syswrite; | |
| if ((GetFileTime(handle, NULL, NULL, &lastwrite) == 0) || | if ((FileTimeToLocalFileTime(file, &localtime) == 0) || |
| (FileTimeToLocalFileTime(&lastwrite, &localwrite) == 0) || | (FileTimeToSystemTime(&localtime, &systime) == 0)) { |
| (FileTimeToSystemTime(&localwrite, &syswrite) == 0)) { | return(FAILURE); |
| return(-1); | |
| } | } |
| if (dosdate) { | if (dosdate) { |
| dosdate->year = (WORD)syswrite.wYear; | dosdate->year = (UINT16)systime.wYear; |
| dosdate->month = (BYTE)syswrite.wMonth; | dosdate->month = (UINT8)systime.wMonth; |
| dosdate->day = (BYTE)syswrite.wDay; | dosdate->day = (UINT8)systime.wDay; |
| } | } |
| if (dostime) { | if (dostime) { |
| dostime->hour = (BYTE)syswrite.wHour; | dostime->hour = (UINT8)systime.wHour; |
| dostime->minute = (BYTE)syswrite.wMinute; | dostime->minute = (UINT8)systime.wMinute; |
| dostime->second = (BYTE)syswrite.wSecond; | 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); | return(0); |
| } | } |
| Line 253 short file_attr_c(const char *path) { | Line 287 short file_attr_c(const char *path) { |
| } | } |
| FILEFINDH file_find1st(const char *path, FILEFINDT *fft) { | static BOOL setflist(WIN32_FIND_DATA *w32fd, FLINFO *fli) { |
| #if defined(UNICODE) && defined(OSLANG_SJIS) | |
| WideCharToMultiByte(CP_ACP, 0, w32fd->cFileName, -1, | |
| fli->path, sizeof(fli->path), NULL, NULL); | |
| #elif defined(UNICODE) && defined(OSLANG_UTF8) | |
| ucscnv_ucs2toutf8(fli->path, sizeof(fli->path), w32fd->cFileName, -1); | |
| #else | |
| milstr_ncpy(fli->path, w32fd->cFileName, sizeof(fli->path)); | |
| #endif | |
| #if !defined(_WIN32_WCE) | |
| if ((w32fd->dwFileAttributes & FILEATTR_DIRECTORY) && | |
| ((!file_cmpname(fli->path, ".")) || | |
| (!file_cmpname(fli->path, "..")))) { | |
| return(FAILURE); | |
| } | |
| #endif | |
| fli->caps = FLICAPS_SIZE | FLICAPS_ATTR | FLICAPS_DATE | FLICAPS_TIME; | |
| fli->size = w32fd->nFileSizeLow; | |
| fli->attr = w32fd->dwFileAttributes; | |
| cnvdatetime(&w32fd->ftLastWriteTime, &fli->date, &fli->time); | |
| return(SUCCESS); | |
| } | |
| FLISTH file_list1st(const char *dir, FLINFO *fli) { | |
| char path[MAX_PATH]; | |
| HANDLE hdl; | HANDLE hdl; |
| WIN32_FIND_DATA w32fd; | WIN32_FIND_DATA w32fd; |
| milsjis_ncpy(path, dir, sizeof(path)); | |
| file_setseparator(path, sizeof(path)); | |
| milsjis_ncat(path, "*.*", sizeof(path)); | |
| TRACEOUT(("file_list1st %s", path)); | |
| hdl = FindFirstFile_A(path, &w32fd); | hdl = FindFirstFile_A(path, &w32fd); |
| if (hdl == INVALID_HANDLE_VALUE) { | if (hdl != INVALID_HANDLE_VALUE) { |
| return(FILEFINDH_INVALID); | do { |
| } | if (setflist(&w32fd, fli) == SUCCESS) { |
| if (fft) { | return(hdl); |
| #if defined(UNICODE) | } |
| WideCharToMultiByte(CP_ACP, 0, w32fd.cFileName, -1, | } while(FindNextFile(hdl, &w32fd)); |
| fft->path, sizeof(fft->path), NULL, NULL); | FindClose(hdl); |
| #else | |
| milstr_ncpy(fft->path, w32fd.cFileName, sizeof(fft->path)); | |
| #endif | |
| fft->size = w32fd.nFileSizeLow; | |
| fft->attr = w32fd.dwFileAttributes; | |
| } | } |
| return(hdl); | return(FLISTH_INVALID); |
| } | } |
| BOOL file_findnext(FILEFINDH hdl, FILEFINDT *fft) { | BOOL file_listnext(FLISTH hdl, FLINFO *fli) { |
| WIN32_FIND_DATA w32fd; | WIN32_FIND_DATA w32fd; |
| if (!FindNextFile(hdl, &w32fd)) { | while(FindNextFile(hdl, &w32fd)) { |
| return(FAILURE); | if (setflist(&w32fd, fli) == SUCCESS) { |
| } | return(SUCCESS); |
| if (fft) { | } |
| #if defined(UNICODE) | |
| WideCharToMultiByte(CP_ACP, 0, w32fd.cFileName, -1, | |
| fft->path, sizeof(fft->path), NULL, NULL); | |
| #else | |
| milstr_ncpy(fft->path, w32fd.cFileName, sizeof(fft->path)); | |
| #endif | |
| fft->size = w32fd.nFileSizeLow; | |
| fft->attr = w32fd.dwFileAttributes; | |
| } | } |
| return(SUCCESS); | return(FAILURE); |
| } | } |
| void file_findclose(FILEFINDH hdl) { | void file_listclose(FLISTH hdl) { |
| if (hdl) { | FindClose(hdl); |
| FindClose(hdl); | |
| } | |
| } | } |
| char *file_getname(char *path) { | OEMCHAR *file_getname(const OEMCHAR *path) { |
| char *ret; | int csize; |
| const OEMCHAR *ret; | |
| ret = path; | ret = path; |
| while(*path != '\0') { | while((csize = milstr_charsize(path)) != 0) { |
| if (!ISKANJI(*path)) { | if ((csize == 1) && |
| if ((*path == '\\') || (*path == '/') || (*path == ':')) { | ((*path == '\\') || (*path == '/') || (*path == ':'))) { |
| ret = path + 1; | ret = path + 1; |
| } | |
| } | } |
| else { | path += csize; |
| if (path[1]) { | |
| path++; | |
| } | |
| } | |
| path++; | |
| } | } |
| return(ret); | return((OEMCHAR *)ret); |
| } | } |
| void file_cutname(char *path) { | void file_cutname(OEMCHAR *path) { |
| char *p; | OEMCHAR *p; |
| p = file_getname(path); | p = file_getname(path); |
| p[0] = '\0'; | p[0] = '\0'; |
| } | } |
| char *file_getext(char *path) { | OEMCHAR *file_getext(const OEMCHAR *path) { |
| char *p; | OEMCHAR *p; |
| char *q; | OEMCHAR *q; |
| int csize; | |
| p = file_getname(path); | p = file_getname(path); |
| q = NULL; | q = NULL; |
| while((csize = milstr_charsize(p)) != 0) { | |
| while(*p != '\0') { | if ((csize == 1) && (*p == '.')) { |
| if (!ISKANJI(*p)) { | q = p + 1; |
| if (*p == '.') { | |
| q = p + 1; | |
| } | |
| } | |
| else { | |
| if (p[1]) { | |
| p++; | |
| } | |
| } | } |
| p++; | p += csize; |
| } | } |
| if (!q) { | if (!q) { |
| q = p; | q = p; |
| } | } |
| return(q); | return((OEMCHAR *)q); |
| } | } |
| void file_cutext(char *path) { | void file_cutext(OEMCHAR *path) { |
| char *p; | OEMCHAR *p; |
| char *q; | OEMCHAR *q; |
| int csize; | |
| p = file_getname(path); | p = file_getname(path); |
| q = NULL; | q = NULL; |
| while((csize = milstr_charsize(p)) != 0) { | |
| while(*p != '\0') { | if ((csize == 1) && (*p == '.')) { |
| if (!ISKANJI(*p)) { | q = p + 1; |
| if (*p == '.') { | |
| q = p; | |
| } | |
| } | |
| else { | |
| if (p[1]) { | |
| p++; | |
| } | |
| } | } |
| p++; | p += csize; |
| } | } |
| if (q) { | if (q) { |
| *q = '\0'; | *q = '\0'; |
| } | } |
| } | } |
| void file_cutseparator(char *path) { | void file_cutseparator(OEMCHAR *path) { |
| int pos; | int pos; |
| Line 399 void file_cutseparator(char *path) { | Line 428 void file_cutseparator(char *path) { |
| } | } |
| } | } |
| void file_setseparator(char *path, int maxlen) { | void file_setseparator(OEMCHAR *path, int maxlen) { |
| int pos; | int pos; |