Diff for /np2/win9xc/dialog/dialogs.cpp between versions 1.1 and 1.4

version 1.1, 2003/10/16 17:59:29 version 1.4, 2005/03/20 08:58:20
Line 1 Line 1
 #include        "compiler.h"  #include        "compiler.h"
 #include        "strres.h"  #include        "strres.h"
   #include        "bmpdata.h"
 #include        "dosio.h"  #include        "dosio.h"
 #include        "commng.h"  #include        "commng.h"
 #include        "sysmng.h"  #include        "sysmng.h"
 #include        "dialogs.h"  #include        "dialogs.h"
   
   
 static const char str_nc[] = "N/C";  static const TCHAR str_nc[] = _T("N/C");
   
 static  char    pathname[MAX_PATH];  const TCHAR str_int0[] = _T("INT0");
 static  char    filename[MAX_PATH];  const TCHAR str_int1[] = _T("INT1");
   const TCHAR str_int2[] = _T("INT2");
 const char str_int0[] = "INT0";  const TCHAR str_int4[] = _T("INT4");
 const char str_int1[] = "INT1";  const TCHAR str_int5[] = _T("INT5");
 const char str_int2[] = "INT2";  const TCHAR str_int6[] = _T("INT6");
 const char str_int4[] = "INT4";  
 const char str_int5[] = "INT5";  
 const char str_int6[] = "INT6";  
   
   
 // ---- file select  // ---- file select
   
 const char *dlgs_selectfile(HWND hWnd, const FILESEL *item,  BOOL dlgs_selectfile(HWND hWnd, const FILESEL *item,
                                         const char *defname, char *folder, UINT size, int *ro) {                                                                                          TCHAR *path, UINT size, int *ro) {
   
         OPENFILENAME    ofn;          OPENFILENAME    ofn;
   
         if ((defname) && (defname[0])) {          if ((item == NULL) || (path == NULL) || (size == 0)) {
                 milstr_ncpy(pathname, defname, sizeof(pathname));                  return(FALSE);
         }  
         else if (folder) {  
                 milstr_ncpy(pathname, folder, sizeof(pathname));  
         }  
         else {  
                 pathname[0] = '\0';  
         }          }
         filename[0] = '\0';  
   
         ZeroMemory(&ofn, sizeof(OPENFILENAME));          ZeroMemory(&ofn, sizeof(OPENFILENAME));
         ofn.lStructSize = sizeof(OPENFILENAME);          ofn.lStructSize = sizeof(OPENFILENAME);
         ofn.hwndOwner = hWnd;          ofn.hwndOwner = hWnd;
         ofn.lpstrFilter = item->filter;          ofn.lpstrFilter = item->filter;
         ofn.nFilterIndex = item->defindex;          ofn.nFilterIndex = item->defindex;
         ofn.lpstrFile = pathname;          ofn.lpstrFile = path;
         ofn.lpstrFileTitle = filename;          ofn.nMaxFile = size;
         ofn.nMaxFile = MAX_PATH;  
         ofn.Flags = OFN_FILEMUSTEXIST;          ofn.Flags = OFN_FILEMUSTEXIST;
         ofn.lpstrDefExt = item->ext;          ofn.lpstrDefExt = item->ext;
         ofn.lpstrTitle = item->title;          ofn.lpstrTitle = item->title;
         if (!GetOpenFileName(&ofn)) {          if (!GetOpenFileName(&ofn)) {
                 return(NULL);                  return(FALSE);
         }  
         if (folder) {  
                 milstr_ncpy(folder, pathname, size);  
                 sysmng_update(SYS_UPDATEOSCFG);  
         }          }
         if (ro) {          if (ro) {
                 *ro = ofn.Flags & OFN_READONLY;                  *ro = ofn.Flags & OFN_READONLY;
         }          }
         return(pathname);          return(TRUE);
 }  }
   
 const char *dlgs_selectwritefile(HWND hWnd, const FILESEL *item,  BOOL dlgs_selectwritefile(HWND hWnd, const FILESEL *item,
                                         const char *defname, char *folder, UINT size) {                                                                                          TCHAR *path, UINT size) {
   
         OPENFILENAME    ofn;          OPENFILENAME    ofn;
   
         if (defname) {          if ((item == NULL) || (path == NULL) || (size == 0)) {
                 milstr_ncpy(pathname, defname, sizeof(pathname));                  return(FALSE);
         }          }
         else {  
                 pathname[0] = '\0';  
         }  
         filename[0] = '\0';  
   
         ZeroMemory(&ofn, sizeof(OPENFILENAME));          ZeroMemory(&ofn, sizeof(OPENFILENAME));
         ofn.lStructSize = sizeof(OPENFILENAME);          ofn.lStructSize = sizeof(OPENFILENAME);
         ofn.hwndOwner = hWnd;          ofn.hwndOwner = hWnd;
         ofn.lpstrFilter = item->filter;          ofn.lpstrFilter = item->filter;
         ofn.lpstrFile = pathname;  
         ofn.lpstrFileTitle = filename;  
         ofn.nFilterIndex = item->defindex;          ofn.nFilterIndex = item->defindex;
         ofn.nMaxFile = MAX_PATH;          ofn.lpstrFile = path;
         ofn.nMaxFileTitle = sizeof(filename);          ofn.nMaxFile = size;
         ofn.Flags = OFN_OVERWRITEPROMPT | OFN_HIDEREADONLY;          ofn.Flags = OFN_OVERWRITEPROMPT | OFN_HIDEREADONLY;
         ofn.lpstrDefExt = item->ext;          ofn.lpstrDefExt = item->ext;
         ofn.lpstrTitle = item->title;          ofn.lpstrTitle = item->title;
         if (!GetSaveFileName(&ofn)) {          if (!GetSaveFileName(&ofn)) {
                 return(NULL);                  return(FALSE);
         }          }
         if (folder) {          return(TRUE);
                 milstr_ncpy(folder, pathname, size);  
                 sysmng_update(SYS_UPDATEOSCFG);  
         }  
         return(pathname);  
 }  }
   
 const char *dlgs_selectwritenum(HWND hWnd, const FILESEL *item,  BOOL dlgs_selectwritenum(HWND hWnd, const FILESEL *item,
                                         const char *defname, char *folder, UINT size) {                                                                                          TCHAR *path, UINT size) {
   
         char    numfile[MAX_PATH];          TCHAR   *file;
         char    *p;          TCHAR   *p;
         int             i;          TCHAR   *q;
           UINT    i;
           BOOL    r;
   
         if (folder) {          if ((item == NULL) || (path == NULL) || (size == 0)) {
                 milstr_ncpy(numfile, folder, sizeof(numfile));                  return(FALSE);
         }          }
         else {          file = (TCHAR *)_MALLOC((size + 16) * sizeof(TCHAR), path);
                 numfile[0] = '\0';          if (file == NULL) {
         }                  return(FALSE);
         file_cutname(numfile);          }
         p = numfile + strlen(numfile);          p = file_getname(path);
           milstr_ncpy(file, path, size);
           file_cutname(file);
           q = file + lstrlen(file);
   
         for (i=0; i<10000; i++) {          for (i=0; i<10000; i++) {
                 wsprintf(p, defname, i);                  wsprintf(q, p, i);
                 if (file_attr(numfile) == -1) {                  if (file_attr(file) == (short)-1) {
                         break;                          break;
                 }                  }
         }          }
         return(dlgs_selectwritefile(hWnd, item, numfile, folder, size));          r = dlgs_selectwritefile(hWnd, item, file, size);
           if (r) {
                   milstr_ncpy(path, file, size);
           }
           _MFREE(file);
           return(r);
 }  }
   
   
 // ---- list  // ---- list
   
 void dlgs_setliststr(HWND hWnd, WORD res, const char **item, UINT items) {  void dlgs_setliststr(HWND hWnd, UINT res, const TCHAR **item, UINT items) {
   
         HWND    wnd;          HWND    wnd;
         UINT    i;          UINT    i;
Line 134  void dlgs_setliststr(HWND hWnd, WORD res Line 119  void dlgs_setliststr(HWND hWnd, WORD res
         }          }
 }  }
   
 void dlgs_setlistuint32(HWND hWnd, WORD res, const UINT32 *item, UINT items) {  void dlgs_setlistuint32(HWND hWnd, UINT res, const UINT32 *item, UINT items) {
   
         HWND    wnd;          HWND    wnd;
         UINT    i;          UINT    i;
         char    str[16];          TCHAR   str[16];
   
         wnd = GetDlgItem(hWnd, res);          wnd = GetDlgItem(hWnd, res);
         for (i=0; i<items; i++) {          for (i=0; i<items; i++) {
Line 150  void dlgs_setlistuint32(HWND hWnd, WORD  Line 135  void dlgs_setlistuint32(HWND hWnd, WORD 
   
 // ---- draw  // ---- draw
   
 void dlgs_linex(BYTE *image, int x, int y, int l, int align, BYTE c) {  void dlgs_drawbmp(HDC hdc, UINT8 *bmp) {
   
         image -= y * align;  
         while(l--) {  
                 if (x & 1) {  
                         image[x/2] &= 0xf0;  
                         image[x/2] |= c;  
                 }  
                 else {  
                         image[x/2] &= 0x0f;  
                         image[x/2] |= (c << 4);  
                 }  
                 x++;  
         }  
 }  
   
 void dlgs_liney(BYTE *image, int x, int y, int l, int align, BYTE c) {          BMPFILE         *bf;
           BMPINFO         *bi;
           BMPDATA         inf;
           HBITMAP         hbmp;
           UINT8           *image;
           HDC                     hmdc;
   
           if (bmp == NULL) {
                   return;
           }
           bf = (BMPFILE *)bmp;
           bi = (BMPINFO *)(bf + 1);
           if (bmpdata_getinfo(bi, &inf) != SUCCESS) {
                   goto dsdb_err1;
           }
           hbmp = CreateDIBSection(hdc, (BITMAPINFO *)bi, DIB_RGB_COLORS,
                                                                                                   (void **)&image, NULL, 0);
           if (hbmp == NULL) {
                   goto dsdb_err1;
           }
           CopyMemory(image, bmp + (LOADINTELDWORD(bf->bfOffBits)),
                                                                                                           bmpdata_getdatasize(bi));
           hmdc = CreateCompatibleDC(hdc);
           SelectObject(hmdc, hbmp);
           if (inf.height < 0) {
                   inf.height *= -1;
           }
           BitBlt(hdc, 0, 0, inf.width, inf.height, hmdc, 0, 0, SRCCOPY);
           DeleteDC(hmdc);
           DeleteObject(hbmp);
   
         image += (x / 2) - y * align;  dsdb_err1:
         if (x & 1) {          _MFREE(bmp);
                 while(l--) {  
                         *image &= 0xf0;  
                         *image |= c;  
                         image -= align;  
                 }  
         }  
         else {  
                 c <<= 4;  
                 while(l--) {  
                         *image &= 0x0f;  
                         *image |= c;  
                         image -= align;  
                 }  
         }  
 }  
   
   
 // ---- jumper  
   
 void dlgs_setjumperx(BYTE *image, int x, int y, int align) {  
   
         int             i;  
   
         x *= 9;  
         y *= 9;  
         for (i=0; i<2; i++) {  
                 dlgs_linex(image, x, y+0+i, 19, align, 0);  
                 dlgs_linex(image, x, y+8+i, 19, align, 0);  
                 dlgs_liney(image, x+ 0+i, y, 9, align, 0);  
                 dlgs_liney(image, x+17+i, y, 9, align, 0);  
         }  
 }  
   
 void dlgs_setjumpery(BYTE *image, int x, int y, int align) {  
   
         int             i;  
   
         x *= 9;  
         y *= 9;  
         for (i=0; i<2; i++) {  
                 dlgs_linex(image, x, y+ 0+i, 9, align, 0);  
                 dlgs_linex(image, x, y+17+i, 9, align, 0);  
                 dlgs_liney(image, x+0+i, y, 19, align, 0);  
                 dlgs_liney(image, x+8+i, y, 19, align, 0);  
         }  
 }  }
   

Removed from v.1.1  
changed lines
  Added in v.1.4


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