Diff for /np2/wince/dosio.cpp between versions 1.1.1.1 and 1.6

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;
   

Removed from v.1.1.1.1  
changed lines
  Added in v.1.6


RetroPC.NET-CVS <cvs@retropc.net>