| version 1.5, 2005/02/07 15:39:28 | version 1.11, 2007/10/26 14:38:34 | 
| Line 1 | Line 1 | 
 | #include        "compiler.h" | #include        "compiler.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" | 
 |  | #if defined(MT32SOUND_DLL) | 
 |  | #include        "mt32snd.h" | 
 |  | #endif | 
 |  |  | 
 |  | extern HINSTANCE hInst; | 
 |  |  | 
 |  |  | 
| static const char str_nc[] = "N/C"; | const TCHAR str_nc[] = _T("N/C"); | 
 |  |  | 
| const char str_int0[] = "INT0"; | const TCHAR str_int0[] = _T("INT0"); | 
| const char str_int1[] = "INT1"; | const TCHAR str_int1[] = _T("INT1"); | 
| const char str_int2[] = "INT2"; | const TCHAR str_int2[] = _T("INT2"); | 
| const char str_int4[] = "INT4"; | const TCHAR str_int4[] = _T("INT4"); | 
| const char str_int5[] = "INT5"; | const TCHAR str_int5[] = _T("INT5"); | 
| const char str_int6[] = "INT6"; | const TCHAR str_int6[] = _T("INT6"); | 
|  |  | 
|  |  | 
|  | // ---- enable | 
|  |  | 
|  | void dlgs_enablebyautocheck(HWND hWnd, UINT uID, UINT uCheckID) | 
|  | { | 
|  | EnableWindow(GetDlgItem(hWnd, uID), | 
|  | (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, | BOOL dlgs_selectfile(HWND hWnd, const FILESEL *item, | 
| char *path, UINT size, int *ro) { | OEMCHAR *path, UINT size, int *ro) { | 
 |  |  | 
 |  | TCHAR                   *pszTitle; | 
 | OPENFILENAME    ofn; | OPENFILENAME    ofn; | 
 |  | #if defined(OSLANG_UTF8) | 
 |  | TCHAR                   _path[MAX_PATH]; | 
 |  | #endif | 
 |  | BOOL                    bResult; | 
 |  |  | 
 | if ((item == NULL) || (path == NULL) || (size == 0)) { | if ((item == NULL) || (path == NULL) || (size == 0)) { | 
 | return(FALSE); | return(FALSE); | 
 | } | } | 
 |  | pszTitle = lockstringresource(hInst, item->title); | 
 |  |  | 
 | 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; | 
 |  | #if defined(OSLANG_UTF8) | 
 |  | oemtotchar(_path, NELEMENTS(_path), path, -1); | 
 |  | ofn.lpstrFile = _path; | 
 |  | ofn.nMaxFile = NELEMENTS(_path); | 
 |  | #else | 
 | ofn.lpstrFile = path; | ofn.lpstrFile = path; | 
 | ofn.nMaxFile = size; | ofn.nMaxFile = size; | 
 |  | #endif | 
 | ofn.Flags = OFN_FILEMUSTEXIST; | ofn.Flags = OFN_FILEMUSTEXIST; | 
 | ofn.lpstrDefExt = item->ext; | ofn.lpstrDefExt = item->ext; | 
| ofn.lpstrTitle = item->title; | ofn.lpstrTitle = pszTitle; | 
| if (!GetOpenFileName(&ofn)) { |  | 
| return(FALSE); | bResult = GetOpenFileName(&ofn); | 
| } | unlockstringresource(pszTitle); | 
| if (ro) { |  | 
| *ro = ofn.Flags & OFN_READONLY; | if (bResult) { | 
|  | #if defined(OSLANG_UTF8) | 
|  | tchartooem(path, NELEMENTS(path), _path, -1); | 
|  | #endif | 
|  | if (ro) { | 
|  | *ro = ofn.Flags & OFN_READONLY; | 
|  | } | 
 | } | } | 
| return(TRUE); | return(bResult); | 
 | } | } | 
 |  |  | 
 | BOOL dlgs_selectwritefile(HWND hWnd, const FILESEL *item, | BOOL dlgs_selectwritefile(HWND hWnd, const FILESEL *item, | 
| char *path, UINT size) { | OEMCHAR *path, UINT size) { | 
 |  |  | 
 | OPENFILENAME    ofn; | OPENFILENAME    ofn; | 
 |  | TCHAR                   *pszTitle; | 
 |  | #if defined(OSLANG_UTF8) | 
 |  | TCHAR                   _path[MAX_PATH]; | 
 |  | #endif | 
 |  | BOOL                    bResult; | 
 |  |  | 
 | if ((item == NULL) || (path == NULL) || (size == 0)) { | if ((item == NULL) || (path == NULL) || (size == 0)) { | 
 | return(FALSE); | return(FALSE); | 
 | } | } | 
 |  |  | 
 |  | pszTitle = lockstringresource(hInst, item->title); | 
 |  |  | 
 | 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; | 
 |  | #if defined(OSLANG_UTF8) | 
 |  | oemtotchar(_path, NELEMENTS(_path), path, -1); | 
 |  | ofn.lpstrFile = _path; | 
 |  | ofn.nMaxFile = NELEMENTS(_path); | 
 |  | #else | 
 | ofn.lpstrFile = path; | ofn.lpstrFile = path; | 
 | ofn.nMaxFile = size; | ofn.nMaxFile = size; | 
 |  | #endif | 
 | 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 = pszTitle; | 
| if (!GetSaveFileName(&ofn)) { |  | 
| return(FALSE); | bResult = GetSaveFileName(&ofn); | 
|  |  | 
|  | unlockstringresource(pszTitle); | 
|  |  | 
|  | #if defined(OSLANG_UTF8) | 
|  | if (bResult) { | 
|  | tchartooem(path, NELEMENTS(path), _path, -1); | 
 | } | } | 
| return(TRUE); | #endif | 
|  | return(bResult); | 
 | } | } | 
 |  |  | 
 | BOOL dlgs_selectwritenum(HWND hWnd, const FILESEL *item, | BOOL dlgs_selectwritenum(HWND hWnd, const FILESEL *item, | 
| char *path, UINT size) { | OEMCHAR *path, UINT size) { | 
 |  |  | 
| char    *file; | OEMCHAR *file; | 
| char    *p; | OEMCHAR *p; | 
| char    *q; | OEMCHAR *q; | 
 | UINT    i; | UINT    i; | 
 | BOOL    r; | BOOL    r; | 
 |  |  | 
 | if ((item == NULL) || (path == NULL) || (size == 0)) { | if ((item == NULL) || (path == NULL) || (size == 0)) { | 
 | return(FALSE); | return(FALSE); | 
 | } | } | 
| file = (char *)_MALLOC(size + 16, path); | file = (OEMCHAR *)_MALLOC((size + 16) * sizeof(OEMCHAR), path); | 
 | if (file == NULL) { | if (file == NULL) { | 
 | return(FALSE); | return(FALSE); | 
 | } | } | 
 | p = file_getname(path); | p = file_getname(path); | 
 | milstr_ncpy(file, path, size); | milstr_ncpy(file, path, size); | 
 | file_cutname(file); | file_cutname(file); | 
| q = file + strlen(file); | q = file + OEMSTRLEN(file); | 
 |  |  | 
 | for (i=0; i<10000; i++) { | for (i=0; i<10000; i++) { | 
| SPRINTF(q, p, i); | OEMSPRINTF(q, p, i); | 
 | if (file_attr(file) == (short)-1) { | if (file_attr(file) == (short)-1) { | 
 | break; | break; | 
 | } | } | 
| Line 107  BOOL dlgs_selectwritenum(HWND hWnd, cons | Line 169  BOOL dlgs_selectwritenum(HWND hWnd, cons | 
 |  |  | 
 | // ---- mimpi def file | // ---- mimpi def file | 
 |  |  | 
| static const char mimpi_title[] = "Open MIMPI define file"; | static const TCHAR mimpi_title[] = _T("Open MIMPI define file"); | 
| static const char mimpi_ext[] = "def"; | static const TCHAR mimpi_ext[] = _T("def"); | 
| static const char mimpi_filter[] = "MIMPI define file(*.def)\0*.def\0"; | static const TCHAR mimpi_filter[] = _T("MIMPI define file(*.def)\0*.def\0"); | 
 | static const FILESEL mimpi = {mimpi_title, mimpi_ext, mimpi_filter, 1}; | static const FILESEL mimpi = {mimpi_title, mimpi_ext, mimpi_filter, 1}; | 
 |  |  | 
 | void dlgs_browsemimpidef(HWND hWnd, UINT16 res) { | void dlgs_browsemimpidef(HWND hWnd, UINT16 res) { | 
 |  |  | 
| HWND    subwnd; | HWND            subwnd; | 
| char    path[MAX_PATH]; | OEMCHAR         path[MAX_PATH]; | 
| const char      *p; | const OEMCHAR   *p; | 
 |  |  | 
 | subwnd = GetDlgItem(hWnd, res); | subwnd = GetDlgItem(hWnd, res); | 
| GetWindowText(subwnd, path, sizeof(path)); | GetWindowText(subwnd, path, NELEMENTS(path)); | 
| if (dlgs_selectfile(hWnd, &mimpi, path, sizeof(path), NULL)) { | if (dlgs_selectfile(hWnd, &mimpi, path, NELEMENTS(path), NULL)) { | 
 | p = path; | p = path; | 
 | } | } | 
 | else { | else { | 
| Line 132  const char *p; | Line 194  const char *p; | 
 |  |  | 
 | // ---- list | // ---- list | 
 |  |  | 
| void dlgs_setliststr(HWND hWnd, UINT16 res, const char **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 206  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; | 
| char    str[16]; | OEMCHAR str[16]; | 
 |  |  | 
 | wnd = GetDlgItem(hWnd, res); | wnd = GetDlgItem(hWnd, res); | 
 | for (i=0; i<items; i++) { | for (i=0; i<items; i++) { | 
| wsprintf(str, str_u, item[i]); | OEMSPRINTF(str, str_u, item[i]); | 
 | SendMessage(wnd, CB_INSERTSTRING, (WPARAM)i, (LPARAM)str); | SendMessage(wnd, CB_INSERTSTRING, (WPARAM)i, (LPARAM)str); | 
 | } | } | 
 | } | } | 
 |  |  | 
 |  |  | 
 |  | void dlgs_setdroplistitem(HWND hWnd, UINT uID, | 
 |  | const TCHAR **ppszItem, UINT uItems) | 
 |  | { | 
 |  | HWND    hItem; | 
 |  | UINT    uPos; | 
 |  | UINT    i; | 
 |  | TCHAR   szString[128]; | 
 |  |  | 
 |  | hItem = GetDlgItem(hWnd, uID); | 
 |  | uPos = 0; | 
 |  | for (i=0; i<uItems; i++) { | 
 |  | LPCTSTR lpcszStr = ppszItem[i]; | 
 |  | if (!HIWORD(lpcszStr)) | 
 |  | { | 
 |  | if (!loadstringresource(hInst, LOWORD(lpcszStr), | 
 |  | szString, NELEMENTS(szString))) | 
 |  | { | 
 |  | continue; | 
 |  | } | 
 |  | lpcszStr = szString; | 
 |  | } | 
 |  | SendMessage(hItem, CB_INSERTSTRING, (WPARAM)uPos, (LPARAM)lpcszStr); | 
 |  | SendMessage(hItem, CB_SETITEMDATA, (WPARAM)uPos, (LPARAM)i); | 
 |  | uPos++; | 
 |  | } | 
 |  | } | 
 |  |  | 
 |  | void dlgs_setdroplistnumber(HWND hWnd, UINT uID, int nNumber) | 
 |  | { | 
 |  | 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) == nNumber) | 
 |  | { | 
 |  | SendMessage(hItem, CB_SETCURSEL, (WPARAM)i, 0); | 
 |  | break; | 
 |  | } | 
 |  | } | 
 |  | } | 
 |  |  | 
 |  | int dlgs_getdroplistnumber(HWND hWnd, UINT uID) | 
 |  | { | 
 |  | 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 -1; | 
 |  | } | 
 |  |  | 
 |  |  | 
 | // ---- MIDIデバイスのリスト | // ---- MIDIデバイスのリスト | 
 |  |  | 
| void dlgs_setlistmidiout(HWND hWnd, UINT16 res, const char *defname) { | void dlgs_setlistmidiout(HWND hWnd, UINT16 res, const OEMCHAR *defname) { | 
 |  |  | 
 | HWND            wnd; | HWND            wnd; | 
 | UINT            defcur; | UINT            defcur; | 
| Line 184  void dlgs_setlistmidiout(HWND hWnd, UINT | Line 305  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 197  void dlgs_setlistmidiout(HWND hWnd, UINT | Line 328  void dlgs_setlistmidiout(HWND hWnd, UINT | 
 | SendMessage(wnd, CB_SETCURSEL, (WPARAM)defcur, (LPARAM)0); | SendMessage(wnd, CB_SETCURSEL, (WPARAM)defcur, (LPARAM)0); | 
 | } | } | 
 |  |  | 
| void dlgs_setlistmidiin(HWND hWnd, UINT16 res, const char *defname) { | void dlgs_setlistmidiin(HWND hWnd, UINT16 res, const OEMCHAR *defname) { | 
 |  |  | 
 | HWND            wnd; | HWND            wnd; | 
 | UINT            defcur; | UINT            defcur; | 
| Line 222  void dlgs_setlistmidiin(HWND hWnd, UINT1 | Line 353  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 393  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; | 
 |  | } | 
 |  |  |