diff options
author | George Hazan <ghazan@miranda.im> | 2018-02-13 14:36:04 +0300 |
---|---|---|
committer | George Hazan <ghazan@miranda.im> | 2018-02-13 14:36:04 +0300 |
commit | bce245873c196325b25490f00180783167549392 (patch) | |
tree | cb688141bd9bf770829ddc1853ef0f1ba740d377 | |
parent | b832f0db06aa2798d676337932b7f88770d79933 (diff) |
fixes #1145 (StartupStatus: crash in CMDL options)
strong type check rulez
-rw-r--r-- | plugins/StatusManager/src/StartupStatus/ss_options.cpp | 153 |
1 files changed, 65 insertions, 88 deletions
diff --git a/plugins/StatusManager/src/StartupStatus/ss_options.cpp b/plugins/StatusManager/src/StartupStatus/ss_options.cpp index 338839197d..a95e6c4c4e 100644 --- a/plugins/StatusManager/src/StartupStatus/ss_options.cpp +++ b/plugins/StatusManager/src/StartupStatus/ss_options.cpp @@ -134,104 +134,84 @@ static wchar_t* GetLinkDescription(TProtoSettings& protoSettings) return mir_wstrndup(result, result.GetLength()); } -HRESULT CreateLink(TProtoSettings& protoSettings) +class CCmdlDlg : public CDlgBase { - wchar_t savePath[MAX_PATH]; - if (SHGetSpecialFolderPath(nullptr, savePath, 0x10, FALSE)) - wcsncat_s(savePath, SHORTCUT_FILENAME, _countof(savePath) - mir_wstrlen(savePath)); - else - mir_snwprintf(savePath, L".\\%s", SHORTCUT_FILENAME); - - // Get a pointer to the IShellLink interface. - IShellLink *psl; - HRESULT hres = CoCreateInstance(CLSID_ShellLink, nullptr, CLSCTX_INPROC_SERVER, IID_IShellLink, (void**)&psl); - if (SUCCEEDED(hres)) { - char *args = GetCMDLArguments(protoSettings); - wchar_t *desc = GetLinkDescription(protoSettings); - - // Set the path to the shortcut target, and add the - // description. - wchar_t path[MAX_PATH]; - GetModuleFileName(nullptr, path, _countof(path)); - psl->SetPath(path); - psl->SetDescription(desc); - psl->SetArguments(_A2T(args)); - - // Query IShellLink for the IPersistFile interface for saving the - // shortcut in persistent storage. - IPersistFile *ppf; - hres = psl->QueryInterface(IID_IPersistFile, (void**)&ppf); + TProtoSettings ps; - if (SUCCEEDED(hres)) { - // Save the link by calling IPersistFile::Save. - hres = ppf->Save(savePath, TRUE); - ppf->Release(); - } - psl->Release(); - mir_free(args); - mir_free(desc); - } + CCtrlButton btnLink, btnCopy; - return hres; -} +public: + CCmdlDlg(int iProfileNo) + : CDlgBase(hInst, IDD_CMDLOPTIONS), + btnCopy(this, IDC_COPY), + btnLink(this, IDC_SHORTCUT), + ps(protoList) + { + GetProfile(iProfileNo, ps); + } -INT_PTR CALLBACK CmdlOptionsDlgProc(HWND hwndDlg, UINT msg, WPARAM wParam, LPARAM lParam) -{ - static TProtoSettings* optionsProtoSettings; + void OnInitDialog() override + { + char* cmdl = GetCMDL(ps); + SetDlgItemTextA(m_hwnd, IDC_CMDL, cmdl); + mir_free(cmdl); + } - switch (msg) { - case WM_INITDIALOG: - TranslateDialogDefault(hwndDlg); - { - optionsProtoSettings = (TProtoSettings*)lParam; - char* cmdl = GetCMDL(*optionsProtoSettings); - SetDlgItemTextA(hwndDlg, IDC_CMDL, cmdl); - mir_free(cmdl); - } - break; + void onClick_Copy(CCtrlButton*) + { + if (OpenClipboard(m_hwnd)) { + EmptyClipboard(); - case WM_COMMAND: - switch (LOWORD(wParam)) { - case IDC_COPY: - if (OpenClipboard(hwndDlg)) { - EmptyClipboard(); - - char cmdl[2048]; - GetDlgItemTextA(hwndDlg, IDC_CMDL, cmdl, _countof(cmdl)); - HGLOBAL cmdlGlob = GlobalAlloc(GMEM_MOVEABLE, sizeof(cmdl)); - if (cmdlGlob == nullptr) { - CloseClipboard(); - break; - } + char cmdl[2048]; + GetDlgItemTextA(m_hwnd, IDC_CMDL, cmdl, _countof(cmdl)); + HGLOBAL cmdlGlob = GlobalAlloc(GMEM_MOVEABLE, sizeof(cmdl)); + if (cmdlGlob != nullptr) { LPTSTR cmdlStr = (LPTSTR)GlobalLock(cmdlGlob); memcpy(cmdlStr, &cmdl, sizeof(cmdl)); GlobalUnlock(cmdlGlob); SetClipboardData(CF_TEXT, cmdlGlob); - CloseClipboard(); } - break; - - case IDC_SHORTCUT: - CreateLink(*optionsProtoSettings); - break; - - case IDC_OK: - DestroyWindow(hwndDlg); - break; + CloseClipboard(); } - break; + } - case WM_CLOSE: - DestroyWindow(hwndDlg); - break; + void onClick_Link(CCtrlButton*) + { + wchar_t savePath[MAX_PATH]; + if (SHGetSpecialFolderPath(nullptr, savePath, 0x10, FALSE)) + wcsncat_s(savePath, SHORTCUT_FILENAME, _countof(savePath) - mir_wstrlen(savePath)); + else + mir_snwprintf(savePath, L".\\%s", SHORTCUT_FILENAME); - case WM_DESTROY: - delete optionsProtoSettings; optionsProtoSettings = nullptr; - break; + // Get a pointer to the IShellLink interface. + IShellLink *psl; + HRESULT hres = CoCreateInstance(CLSID_ShellLink, nullptr, CLSCTX_INPROC_SERVER, IID_IShellLink, (void**)&psl); + if (SUCCEEDED(hres)) { + ptrA args(GetCMDLArguments(ps)); + ptrW desc(GetLinkDescription(ps)); + + // Set the path to the shortcut target, and add the + // description. + wchar_t path[MAX_PATH]; + GetModuleFileName(nullptr, path, _countof(path)); + psl->SetPath(path); + psl->SetDescription(desc); + psl->SetArguments(_A2T(args)); + + // Query IShellLink for the IPersistFile interface for saving the + // shortcut in persistent storage. + IPersistFile *ppf; + hres = psl->QueryInterface(IID_IPersistFile, (void**)&ppf); + + if (SUCCEEDED(hres)) { + // Save the link by calling IPersistFile::Save. + hres = ppf->Save(savePath, TRUE); + ppf->Release(); + } + psl->Release(); + } } - - return 0; -} +}; static INT_PTR CALLBACK StartupStatusOptDlgProc(HWND hwndDlg, UINT msg, WPARAM wParam, LPARAM lParam) { @@ -396,11 +376,8 @@ static INT_PTR CALLBACK StartupStatusOptDlgProc(HWND hwndDlg, UINT msg, WPARAM w { int defProfile = (int)SendDlgItemMessage(hwndDlg, IDC_PROFILE, CB_GETITEMDATA, SendDlgItemMessage(hwndDlg, IDC_PROFILE, CB_GETCURSEL, 0, 0), 0); - - TProtoSettings ps = protoList; - GetProfile(defProfile, ps); - - CreateDialogParam(hInst, MAKEINTRESOURCE(IDD_CMDLOPTIONS), hwndDlg, CmdlOptionsDlgProc, (LPARAM)&ps); + CCmdlDlg *pDlg = new CCmdlDlg(defProfile); + pDlg->Show(); break; } } |