Diff for /np2/win9x/dialog/dialogs.cpp between versions 1.6 and 1.13

version 1.6, 2005/02/09 20:11:36 version 1.13, 2007/11/11 11:00:02
Line 1 Line 1
 #include        "compiler.h"  #include        "compiler.h"
   #include        "resource.h"
 #include        "strres.h"  #include        "strres.h"
 #include        "bmpdata.h"  #include        "bmpdata.h"
   #include        "oemtext.h"
 #include        "dosio.h"  #include        "dosio.h"
 #include        "commng.h"  #include        "commng.h"
 #include        "dialogs.h"  #include        "dialogs.h"
   #include        "np2.h"
   #if defined(MT32SOUND_DLL)
   #include        "mt32snd.h"
   #endif
   
   
   const TCHAR str_nc[] = _T("N/C");
   
 const OEMCHAR str_nc[] = OEMTEXT("N/C");  
   
 const OEMCHAR str_int0[] = OEMTEXT("INT0");  // ---- enable
 const OEMCHAR str_int1[] = OEMTEXT("INT1");  
 const OEMCHAR str_int2[] = OEMTEXT("INT2");  void dlgs_enablebyautocheck(HWND hWnd, UINT uID, UINT uCheckID)
 const OEMCHAR str_int4[] = OEMTEXT("INT4");  {
 const OEMCHAR str_int5[] = OEMTEXT("INT5");          EnableWindow(GetDlgItem(hWnd, uID),
 const OEMCHAR str_int6[] = OEMTEXT("INT6");                          (SendDlgItemMessage(hWnd, uCheckID, BM_GETCHECK, 0, 0) != 0));
   }
   
   void dlgs_disablebyautocheck(HWND hWnd, UINT uID, UINT uCheckID)
   {
           EnableWindow(GetDlgItem(hWnd, uID),
                           (SendDlgItemMessage(hWnd, uCheckID, BM_GETCHECK, 0, 0) == 0));
   
   }
   
   
 // ---- file select  // ---- file select
   
 BOOL dlgs_selectfile(HWND hWnd, const FILESEL *item,  static BOOL openFileParam(LPOPENFILENAME lpOFN, PCFSPARAM pcParam,
                                                                                 OEMCHAR *path, UINT size, int *ro) {                                                          OEMCHAR *pszPath, UINT uSize,
                                                           BOOL (WINAPI * fnAPI)(LPOPENFILENAME lpofn))
   {
           HINSTANCE       hInstance;
           LPTSTR          lpszTitle;
           LPTSTR          lpszFilter;
           LPTSTR          lpszDefExt;
           LPTSTR          p;
   #if defined(OSLANG_UTF8)
           TCHAR           szPath[MAX_PATH];
   #endif  // defined(OSLANG_UTF8)
           BOOL            bResult;
   
           if ((lpOFN == NULL) || (pcParam == NULL) ||
                   (pszPath == NULL) || (uSize == 0) || (fnAPI == NULL))
           {
                   return FALSE;
           }
   
           hInstance = g_hInstance;
   
           if (!HIWORD(pcParam->lpszTitle))
           {
                   lpszTitle = lockstringresource(hInstance, pcParam->lpszTitle);
                   lpOFN->lpstrTitle = lpszTitle;
           }
           else
           {
                   lpszTitle = NULL;
                   lpOFN->lpstrTitle = pcParam->lpszTitle;
           }
   
           if (!HIWORD(pcParam->lpszFilter))
           {
                   lpszFilter = lockstringresource(hInstance, pcParam->lpszFilter);
                   lpOFN->lpstrFilter = lpszFilter;
           }
           else
           {
                   lpszFilter = NULL;
                   lpOFN->lpstrFilter = pcParam->lpszFilter;
           }
   
           if (!HIWORD(pcParam->lpszDefExt))
           {
                   lpszDefExt = lockstringresource(hInstance, pcParam->lpszDefExt);
                   lpOFN->lpstrDefExt = lpszDefExt;
           }
           else
           {
                   lpszDefExt = NULL;
                   lpOFN->lpstrDefExt = pcParam->lpszDefExt;
           }
   
           lpOFN->nFilterIndex = pcParam->nFilterIndex;
   
   
           p = lpszFilter;
           if (p)
           {
                   while(*p != '\0')
                   {
   #if !defined(_UNICODE)
                           if (IsDBCSLeadByte((BYTE)*p))
                           {
                                   p += 2;
                                   continue;
                           }
   #endif  // !defined(_UNICODE)
                           if (*p == '|')
                           {
                                   *p = '\0';
                           }
                           p++;
                   }
           }
   
   #if defined(OSLANG_UTF8)
           oemtotchar(szPath, NELEMENTS(szPath), pszPath, -1);
           lpOFN->lpstrFile = szPath;
           lpOFN->nMaxFile = NELEMENTS(szPath);
   #else   // defined(OSLANG_UTF8)
           lpOFN->lpstrFile = pszPath;
           lpOFN->nMaxFile = uSize;
   #endif  // defined(OSLANG_UTF8)
   
           bResult = (*fnAPI)(lpOFN);
   
   #if defined(OSLANG_UTF8)
           if (bResult)
           {
                   tchartooem(pszPath, uSize, szPath, -1);
           }
   #endif  // defined(OSLANG_UTF8)
   
           if (lpszTitle)
           {
                   unlockstringresource(lpszTitle);
           }
           if (lpszFilter)
           {
                   unlockstringresource(lpszFilter);
           }
           if (lpszDefExt)
           {
                   unlockstringresource(lpszDefExt);
           }
   
           return bResult;
   }
   
   BOOL dlgs_openfile(HWND hWnd, PCFSPARAM pcParam,
                                                                           OEMCHAR *pszPath, UINT uSize, int *pnRO)
   {
         OPENFILENAME    ofn;          OPENFILENAME    ofn;
           BOOL                    bResult;
   
         if ((item == NULL) || (path == NULL) || (size == 0)) {          ZeroMemory(&ofn, sizeof(ofn));
                 return(FALSE);          ofn.lStructSize = sizeof(ofn);
         }  
         ZeroMemory(&ofn, sizeof(OPENFILENAME));  
         ofn.lStructSize = sizeof(OPENFILENAME);  
         ofn.hwndOwner = hWnd;          ofn.hwndOwner = hWnd;
         ofn.lpstrFilter = item->filter;  
         ofn.nFilterIndex = item->defindex;  
         ofn.lpstrFile = path;  
         ofn.nMaxFile = size;  
         ofn.Flags = OFN_FILEMUSTEXIST;          ofn.Flags = OFN_FILEMUSTEXIST;
         ofn.lpstrDefExt = item->ext;  
         ofn.lpstrTitle = item->title;          if (pnRO == NULL)
         if (!GetOpenFileName(&ofn)) {          {
                 return(FALSE);                  ofn.Flags |= OFN_HIDEREADONLY;
         }          }
         if (ro) {  
                 *ro = ofn.Flags & OFN_READONLY;          bResult = openFileParam(&ofn, pcParam, pszPath, uSize, GetOpenFileName);
   
           if ((bResult) && (pnRO != NULL))
           {
                   *pnRO = ofn.Flags & OFN_READONLY;
         }          }
         return(TRUE);  
 }  
   
 BOOL dlgs_selectwritefile(HWND hWnd, const FILESEL *item,          return bResult;
                                                                                         OEMCHAR *path, UINT size) {  }
   
   BOOL dlgs_createfile(HWND hWnd, PCFSPARAM pcParam,
                                                                                                   OEMCHAR *pszPath, UINT uSize)
   {
         OPENFILENAME    ofn;          OPENFILENAME    ofn;
   
         if ((item == NULL) || (path == NULL) || (size == 0)) {          ZeroMemory(&ofn, sizeof(ofn));
                 return(FALSE);          ofn.lStructSize = sizeof(ofn);
         }  
         ZeroMemory(&ofn, sizeof(OPENFILENAME));  
         ofn.lStructSize = sizeof(OPENFILENAME);  
         ofn.hwndOwner = hWnd;          ofn.hwndOwner = hWnd;
         ofn.lpstrFilter = item->filter;  
         ofn.nFilterIndex = item->defindex;  
         ofn.lpstrFile = path;  
         ofn.nMaxFile = size;  
         ofn.Flags = OFN_OVERWRITEPROMPT | OFN_HIDEREADONLY;          ofn.Flags = OFN_OVERWRITEPROMPT | OFN_HIDEREADONLY;
         ofn.lpstrDefExt = item->ext;          return openFileParam(&ofn, pcParam, pszPath, uSize, GetSaveFileName);
         ofn.lpstrTitle = item->title;  
         if (!GetSaveFileName(&ofn)) {  
                 return(FALSE);  
         }  
         return(TRUE);  
 }  }
   
 BOOL dlgs_selectwritenum(HWND hWnd, const FILESEL *item,  BOOL dlgs_createfilenum(HWND hWnd, PCFSPARAM pcParam,
                                                                                         OEMCHAR *path, UINT size) {                                                                                                  OEMCHAR *pszPath, UINT uSize)
   {
         OEMCHAR *file;          OEMCHAR *pszNum[4];
         OEMCHAR *p;          OEMCHAR *pszFile;
         OEMCHAR *q;          UINT uCount;
         UINT    i;          UINT uPos;
         BOOL    r;  
           if (!pszPath)
         if ((item == NULL) || (path == NULL) || (size == 0)) {          {
                 return(FALSE);                  return FALSE;
         }          }
         file = (OEMCHAR *)_MALLOC((size + 16) * sizeof(OEMCHAR), path);  
         if (file == NULL) {          ZeroMemory(pszNum, sizeof(pszNum));
                 return(FALSE);          pszFile = file_getname(pszPath);
         }          uCount = 0;
         p = file_getname(path);          while(1)
         milstr_ncpy(file, path, size);          {
         file_cutname(file);                  pszFile = milstr_chr(pszPath, '#');
         q = file + OEMSTRLEN(file);                  if (!pszFile)
                   {
         for (i=0; i<10000; i++) {                          break;
                 OEMSPRINTF(q, p, i);                  }
                 if (file_attr(file) == (short)-1) {                  *pszFile = '0';
                   pszNum[uCount] = pszFile;
                   uCount = (uCount + 1) % NELEMENTS(pszNum);
                   pszFile++;
           }
   
           while(file_attr(pszPath) != (short)-1)
           {
                   uPos = max(uCount, NELEMENTS(pszNum));
                   while(uPos)
                   {
                           pszFile = pszNum[(uPos - 1) % NELEMENTS(pszNum)];
                           *pszFile = *pszFile + 1;
                           if (*pszFile < ('0' + 10))
                           {
                                   break;
                           }
                           *pszFile = '0';
                           uPos--;
                   }
                   if (!uPos)
                   {
                         break;                          break;
                 }                  }
         }          }
         r = dlgs_selectwritefile(hWnd, item, file, size);          return dlgs_createfile(hWnd, pcParam, pszPath, uSize);
         if (r) {  
                 milstr_ncpy(path, file, size);  
         }  
         _MFREE(file);  
         return(r);  
 }  }
   
   
 // ---- mimpi def file  // ---- mimpi def file
   
 static const OEMCHAR mimpi_title[] = OEMTEXT("Open MIMPI define file");  static const FSPARAM fpMIMPI =
 static const OEMCHAR mimpi_ext[] = OEMTEXT("def");  {
 static const OEMCHAR mimpi_filter[] = OEMTEXT("MIMPI define file(*.def)\0*.def\0");          MAKEINTRESOURCE(IDS_MIMPITITLE),
 static const FILESEL mimpi = {mimpi_title, mimpi_ext, mimpi_filter, 1};          MAKEINTRESOURCE(IDS_MIMPIEXT),
           MAKEINTRESOURCE(IDS_MIMPIFILTER),
           1
   };
   
 void dlgs_browsemimpidef(HWND hWnd, UINT16 res) {  void dlgs_browsemimpidef(HWND hWnd, UINT16 res) {
   
Line 120  const OEMCHAR *p; Line 253  const OEMCHAR *p;
   
         subwnd = GetDlgItem(hWnd, res);          subwnd = GetDlgItem(hWnd, res);
         GetWindowText(subwnd, path, NELEMENTS(path));          GetWindowText(subwnd, path, NELEMENTS(path));
         if (dlgs_selectfile(hWnd, &mimpi, path, NELEMENTS(path), NULL)) {          if (dlgs_openfile(hWnd, &fpMIMPI, path, NELEMENTS(path), NULL)) {
                 p = path;                  p = path;
         }          }
         else {          else {
Line 132  const OEMCHAR *p; Line 265  const OEMCHAR *p;
   
 // ---- list  // ---- list
   
 void dlgs_setliststr(HWND hWnd, UINT16 res, const OEMCHAR **item, UINT items) {  void dlgs_setliststr(HWND hWnd, UINT16 res, const TCHAR **item, UINT items) {
   
         HWND    wnd;          HWND    wnd;
         UINT    i;          UINT    i;
Line 144  void dlgs_setliststr(HWND hWnd, UINT16 r Line 277  void dlgs_setliststr(HWND hWnd, UINT16 r
 }  }
   
 void dlgs_setlistuint32(HWND hWnd, UINT16 res, const UINT32 *item, UINT items) {  void dlgs_setlistuint32(HWND hWnd, UINT16 res, const UINT32 *item, UINT items) {
   
         HWND    wnd;          HWND    wnd;
         UINT    i;          UINT    i;
         OEMCHAR str[16];          OEMCHAR str[16];
Line 156  void dlgs_setlistuint32(HWND hWnd, UINT1 Line 288  void dlgs_setlistuint32(HWND hWnd, UINT1
         }          }
 }  }
   
   void dlgs_setcbitem(HWND hWnd, UINT uID, PCCBPARAM pItem, UINT uItems)
   {
           HWND    hItem;
           UINT    i;
           LPCTSTR lpcszStr;
           TCHAR   szString[128];
           int             nIndex;
   
           hItem = GetDlgItem(hWnd, uID);
           for (i=0; i<uItems; i++)
           {
                   lpcszStr = pItem[i].lpcszString;
                   if (!HIWORD(lpcszStr))
                   {
                           if (!loadstringresource(g_hInstance, LOWORD(lpcszStr),
                                                                                           szString, NELEMENTS(szString)))
                           {
                                   continue;
                           }
                           lpcszStr = szString;
                   }
                   nIndex = SendMessage(hItem, CB_ADDSTRING, 0, (LPARAM)lpcszStr);
                   if (nIndex >= 0)
                   {
                           SendMessage(hItem, CB_SETITEMDATA,
                                                                   (WPARAM)nIndex, (LPARAM)pItem[i].nItemData);
                   }
           }
   }
   
   void dlgs_setcbcur(HWND hWnd, UINT uID, int nItemData)
   {
           HWND    hItem;
           int             nItems;
           int             i;
   
           hItem = GetDlgItem(hWnd, uID);
           nItems = SendMessage(hItem, CB_GETCOUNT, 0, 0);
           for (i=0; i<nItems; i++)
           {
                   if (SendMessage(hItem, CB_GETITEMDATA, (WPARAM)i, 0) == nItemData)
                   {
                           SendMessage(hItem, CB_SETCURSEL, (WPARAM)i, 0);
                           break;
                   }
           }
   }
   
   int dlgs_getcbcur(HWND hWnd, UINT uID, int nDefault)
   {
           HWND    hItem;
           int             nPos;
   
           hItem = GetDlgItem(hWnd, uID);
           nPos = SendMessage(hItem, CB_GETCURSEL, 0, 0);
           if (nPos >= 0)
           {
                   return SendMessage(hItem, CB_GETITEMDATA, (WPARAM)nPos, 0);
           }
           return nDefault;
   }
   
   
 // ---- MIDIデバイスのリスト  // ---- MIDIデバイスのリスト
   
Line 184  void dlgs_setlistmidiout(HWND hWnd, UINT Line 378  void dlgs_setlistmidiout(HWND hWnd, UINT
         }          }
         num++;          num++;
 #endif  #endif
   #if defined(MT32SOUND_DLL)
           if (mt32sound_isenable()) {
                   SendMessage(wnd, CB_INSERTSTRING, (WPARAM)num,
                                                                                                           (LPARAM)cmmidi_mt32sound);
                   if (!milstr_cmp(defname, cmmidi_mt32sound)) {
                           defcur = num;
                   }
                   num++;
           }
   #endif
         for (i=0; i<devs; i++) {          for (i=0; i<devs; i++) {
                 if (midiOutGetDevCaps(i, &moc, sizeof(moc)) == MMSYSERR_NOERROR) {                  if (midiOutGetDevCaps(i, &moc, sizeof(moc)) == MMSYSERR_NOERROR) {
                         SendMessage(wnd, CB_INSERTSTRING,                          SendMessage(wnd, CB_INSERTSTRING,
Line 222  void dlgs_setlistmidiin(HWND hWnd, UINT1 Line 426  void dlgs_setlistmidiin(HWND hWnd, UINT1
 }  }
   
   
   
 // ---- draw  // ---- draw
   
 void dlgs_drawbmp(HDC hdc, UINT8 *bmp) {  void dlgs_drawbmp(HDC hdc, UINT8 *bmp) {
Line 261  dsdb_err1: Line 466  dsdb_err1:
         _MFREE(bmp);          _MFREE(bmp);
 }  }
   
   
   // ----
   
   BOOL dlgs_getitemrect(HWND hWnd, UINT uID, RECT *pRect)
   {
           HWND    hItem;
           POINT   pt;
   
           if (pRect == NULL)
           {
                   return FALSE;
           }
           hItem = GetDlgItem(hWnd, uID);
           if (!GetWindowRect(hItem, pRect))
           {
                   return FALSE;
           }
           ZeroMemory(&pt, sizeof(pt));
           if (!ClientToScreen(hWnd, &pt))
           {
                   return FALSE;
           }
           pRect->left -= pt.x;
           pRect->top -= pt.y;
           pRect->right -= pt.x;
           pRect->bottom -= pt.y;
           return TRUE;
   }
   

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


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