XKeymacs for 64bit Windows
修訂 | b48f885d91b15ee2bccbabaf2793d7b104dd2e04 (tree) |
---|---|
時間 | 2011-05-27 08:38:36 |
作者 | Kazuhiro Fujieda <fujieda@user...> |
Commiter | Kazuhiro Fujieda |
CMainFrame handles notify icons instead of CXkeymacsDll.
CXkeymacsDll changes notify icons through a named pipe.
It changes all modifier icons and the M-x tip at the same time.
CMainFrame creates a thread to receive messages from CXkeymacsDll.
@@ -5,7 +5,6 @@ | ||
5 | 5 | #include <Lmcons.h> |
6 | 6 | #include "xkeymacs.h" |
7 | 7 | #include "Profile.h" |
8 | - | |
9 | 8 | #include "MainFrm.h" |
10 | 9 | |
11 | 10 | #ifdef _DEBUG |
@@ -60,6 +59,8 @@ CMainFrame::CMainFrame() | ||
60 | 59 | } |
61 | 60 | memset(m_nResultKeyboardDlg, -1, sizeof(m_nResultKeyboardDlg)); |
62 | 61 | memset(m_bKeyboardDlgExist, 0, sizeof(m_bKeyboardDlgExist)); |
62 | + memset(m_stOldNtfyIcon, 0, sizeof(m_stOldNtfyIcon)); | |
63 | + memset(m_dwOldMessage, 0, sizeof(m_dwOldMessage)); | |
63 | 64 | |
64 | 65 | // register window class |
65 | 66 | WNDCLASS stWndClass; |
@@ -145,43 +146,56 @@ int CMainFrame::OnCreate(const LPCREATESTRUCT lpCreateStruct) | ||
145 | 146 | sizeof(notifyIconData[ALT_ICON].szTip)); |
146 | 147 | |
147 | 148 | // set notify icon data |
148 | - CXkeymacsDll::SetNotifyIconData(MAIN_ICON, notifyIconData[MAIN_ICON], | |
149 | - (HICON)::LoadImage(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDR_MAINFRAME), IMAGE_ICON, 16, 16, LR_SHARED), | |
150 | - (HICON)::LoadImage(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDR_MAIN_DISABLE_TMP), IMAGE_ICON, 16, 16, LR_SHARED), | |
151 | - (HICON)::LoadImage(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDR_MAIN_DISABLE_WOCQ), IMAGE_ICON, 16, 16, LR_SHARED), // disable without C-q | |
152 | - (HICON)::LoadImage(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDR_MAIN_DISABLE), IMAGE_ICON, 16, 16, LR_SHARED), | |
153 | - AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_MAIN)), 1)); | |
149 | + m_hIcon[MAIN_ICON][STATUS_ENABLE] = (HICON)LoadImage(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDR_MAINFRAME), IMAGE_ICON, 16, 16, LR_SHARED), | |
150 | + m_hIcon[MAIN_ICON][STATUS_DISABLE_TMP] = (HICON)LoadImage(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDR_MAIN_DISABLE_TMP), IMAGE_ICON, 16, 16, LR_SHARED); | |
151 | + m_hIcon[MAIN_ICON][STATUS_DISABLE_WOCQ] = (HICON)LoadImage(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDR_MAIN_DISABLE_WOCQ), IMAGE_ICON, 16, 16, LR_SHARED); | |
152 | + m_hIcon[MAIN_ICON][STATUS_DISABLE] = (HICON)LoadImage(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDR_MAIN_DISABLE), IMAGE_ICON, 16, 16, LR_SHARED); | |
153 | + m_bIcon[MAIN_ICON] = AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_MAIN)), 1); | |
154 | + m_stNtfyIcon[MAIN_ICON] = notifyIconData[MAIN_ICON]; | |
155 | + AddShell_NotifyIcon(MAIN_ICON); | |
154 | 156 | |
155 | 157 | // set notify ^X icon data |
156 | - CXkeymacsDll::SetNotifyIconData(CX_ICON, notifyIconData[CX_ICON], AfxGetApp()->LoadIcon(IDI_CX_ON), | |
157 | - AfxGetApp()->LoadIcon(IDI_CX_OFF), | |
158 | - AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_CX)), 0)); | |
158 | + m_hIcon[CX_ICON][ON_ICON] = AfxGetApp()->LoadIcon(IDI_CX_ON); | |
159 | + m_hIcon[CX_ICON][OFF_ICON] = AfxGetApp()->LoadIcon(IDI_CX_OFF); | |
160 | + m_bIcon[CX_ICON] = AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_CX)), 0); | |
161 | + m_stNtfyIcon[CX_ICON] = notifyIconData[CX_ICON]; | |
162 | + AddShell_NotifyIcon(CX_ICON); | |
159 | 163 | |
160 | 164 | // set notify M-x icon data |
161 | - CXkeymacsDll::SetNotifyIconData(MX_ICON, notifyIconData[MX_ICON], AfxGetApp()->LoadIcon(IDI_MX_ON), | |
162 | - AfxGetApp()->LoadIcon(IDI_MX_OFF), | |
163 | - AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_MX)), 0)); | |
165 | + m_hIcon[MX_ICON][ON_ICON] = AfxGetApp()->LoadIcon(IDI_MX_ON); | |
166 | + m_hIcon[MX_ICON][OFF_ICON] = AfxGetApp()->LoadIcon(IDI_MX_OFF); | |
167 | + m_bIcon[MX_ICON] = AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_MX)), 0); | |
168 | + m_stNtfyIcon[MX_ICON] = notifyIconData[MX_ICON]; | |
169 | + AddShell_NotifyIcon(MX_ICON); | |
164 | 170 | |
165 | 171 | // set notify Meta icon data |
166 | - CXkeymacsDll::SetNotifyIconData(META_ICON, notifyIconData[META_ICON], AfxGetApp()->LoadIcon(IDI_META_ON), | |
167 | - AfxGetApp()->LoadIcon(IDI_META_OFF), | |
168 | - AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_META)), 0)); | |
172 | + m_hIcon[META_ICON][ON_ICON] = AfxGetApp()->LoadIcon(IDI_META_ON); | |
173 | + m_hIcon[META_ICON][OFF_ICON] = AfxGetApp()->LoadIcon(IDI_META_OFF); | |
174 | + m_bIcon[META_ICON] = AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_META)), 0); | |
175 | + m_stNtfyIcon[META_ICON] = notifyIconData[META_ICON]; | |
176 | + AddShell_NotifyIcon(META_ICON); | |
169 | 177 | |
170 | 178 | // set notify Shift icon data |
171 | - CXkeymacsDll::SetNotifyIconData(SHIFT_ICON, notifyIconData[SHIFT_ICON], AfxGetApp()->LoadIcon(IDI_SHIFT_ON), | |
172 | - AfxGetApp()->LoadIcon(IDI_SHIFT_OFF), | |
173 | - AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_SHIFT)), 0)); | |
179 | + m_hIcon[SHIFT_ICON][ON_ICON] = AfxGetApp()->LoadIcon(IDI_SHIFT_ON); | |
180 | + m_hIcon[SHIFT_ICON][OFF_ICON] = AfxGetApp()->LoadIcon(IDI_SHIFT_OFF); | |
181 | + m_bIcon[SHIFT_ICON] = AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_SHIFT)), 0); | |
182 | + m_stNtfyIcon[SHIFT_ICON] = notifyIconData[SHIFT_ICON]; | |
183 | + AddShell_NotifyIcon(SHIFT_ICON); | |
174 | 184 | |
175 | 185 | // set notify Ctrl icon data |
176 | - CXkeymacsDll::SetNotifyIconData(CTRL_ICON, notifyIconData[CTRL_ICON], AfxGetApp()->LoadIcon(IDI_CTRL_ON), | |
177 | - AfxGetApp()->LoadIcon(IDI_CTRL_OFF), | |
178 | - AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_CTRL)), 0)); | |
186 | + m_hIcon[CTRL_ICON][ON_ICON] = AfxGetApp()->LoadIcon(IDI_CTRL_ON); | |
187 | + m_hIcon[CTRL_ICON][OFF_ICON] = AfxGetApp()->LoadIcon(IDI_CTRL_OFF); | |
188 | + m_bIcon[CTRL_ICON] = AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_CTRL)), 0); | |
189 | + m_stNtfyIcon[CTRL_ICON] = notifyIconData[CTRL_ICON]; | |
190 | + AddShell_NotifyIcon(CTRL_ICON); | |
179 | 191 | |
180 | 192 | // set notify Alt icon data |
181 | - CXkeymacsDll::SetNotifyIconData(ALT_ICON, notifyIconData[ALT_ICON], AfxGetApp()->LoadIcon(IDI_ALT_ON), | |
182 | - AfxGetApp()->LoadIcon(IDI_ALT_OFF), | |
183 | - AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_ALT)), 0)); | |
184 | - | |
193 | + m_hIcon[ALT_ICON][ON_ICON] = AfxGetApp()->LoadIcon(IDI_ALT_ON); | |
194 | + m_hIcon[ALT_ICON][OFF_ICON] = AfxGetApp()->LoadIcon(IDI_ALT_OFF); | |
195 | + m_bIcon[ALT_ICON] = AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_ALT)), 0); | |
196 | + m_stNtfyIcon[ALT_ICON] = notifyIconData[ALT_ICON]; | |
197 | + AddShell_NotifyIcon(ALT_ICON); | |
198 | + | |
185 | 199 | CXkeymacsDll::SetKeyboardSpeed(CProfile::GetKeyboardSpeed()); |
186 | 200 | CXkeymacsDll::SetAccelerate(AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_ACCELERATE)), 1)); |
187 | 201 |
@@ -192,10 +206,114 @@ int CMainFrame::OnCreate(const LPCREATESTRUCT lpCreateStruct) | ||
192 | 206 | AfxGetApp()->GetProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_CHANGE_CURSOR)), 0)); |
193 | 207 | |
194 | 208 | CXkeymacsDll::SetHooks(); |
209 | + StartPollThread(); | |
210 | + | |
211 | + return 0; | |
212 | +} | |
213 | + | |
214 | +void CMainFrame::StartPollThread() | |
215 | +{ | |
216 | + m_bPollIconMessage = TRUE; | |
217 | + m_hThread = CreateThread(NULL, 0, PollIconMessage, this, 0, NULL); | |
218 | +} | |
219 | + | |
220 | +void CMainFrame::TerminatePollThread() | |
221 | +{ | |
222 | + m_bPollIconMessage = FALSE; | |
223 | + ICONMSG nul = {MAIN_ICON,}; | |
224 | + if (CXkeymacsDll::SendIconMessage(&nul, 1)) | |
225 | + WaitForSingleObject(m_hThread, 5000); | |
226 | + CloseHandle(m_hThread); | |
227 | +} | |
195 | 228 | |
229 | +DWORD WINAPI CMainFrame::PollIconMessage(LPVOID lpParam) | |
230 | +{ | |
231 | + CMainFrame *pThis = reinterpret_cast<CMainFrame *>(lpParam); | |
232 | + HANDLE hPipe = CreateNamedPipe(ICON_PIPE, PIPE_ACCESS_DUPLEX, PIPE_TYPE_MESSAGE | PIPE_READMODE_MESSAGE, 1, | |
233 | + sizeof(DWORD), sizeof(ICONMSG) * MAX_ICON_TYPE, 0, NULL); | |
234 | + if (hPipe == INVALID_HANDLE_VALUE) | |
235 | + return 1; | |
236 | + for (; ;) { | |
237 | + if (ConnectNamedPipe(hPipe, NULL) ? FALSE : (GetLastError() != ERROR_PIPE_CONNECTED)) | |
238 | + break; | |
239 | + ICONMSG msg[MAX_ICON_TYPE]; | |
240 | + DWORD read; | |
241 | + if (!ReadFile(hPipe, msg, sizeof(msg), &read, NULL)) | |
242 | + break; | |
243 | + DWORD written, ack = 0; | |
244 | + // return ack ASAP to release hooks from blocking state. | |
245 | + if (!WriteFile(hPipe, &ack, sizeof(DWORD), &written, NULL) || written != sizeof(DWORD) || | |
246 | + !FlushFileBuffers(hPipe) || !DisconnectNamedPipe(hPipe)) | |
247 | + break; | |
248 | + if (!pThis->m_bPollIconMessage) | |
249 | + break; | |
250 | + for (DWORD i = 0; i < read / sizeof(ICONMSG); i++) { | |
251 | + pThis->m_stNtfyIcon[msg[i].nType].hIcon = pThis->m_hIcon[msg[i].nType][msg[i].nState]; | |
252 | + if (msg[i].nType == MX_ICON && msg[i].szTip[0] != 0) | |
253 | + memcpy(pThis->m_stNtfyIcon[MX_ICON].szTip, msg[i].szTip, 128); | |
254 | + pThis->DoShell_NotifyIcon(msg[i].nType, NIM_MODIFY); | |
255 | + } | |
256 | + } | |
257 | + CloseHandle(hPipe); | |
196 | 258 | return 0; |
197 | 259 | } |
198 | 260 | |
261 | +BOOL CMainFrame::DoShell_NotifyIcon(ICON_TYPE icon, DWORD dwMessage) | |
262 | +{ | |
263 | + if (m_bIcon[icon] | |
264 | + && (m_dwOldMessage[icon] != dwMessage | |
265 | + || memcmp(&m_stOldNtfyIcon[icon], &m_stNtfyIcon[icon], sizeof(m_stNtfyIcon[icon])))) { | |
266 | + m_dwOldMessage[icon] = dwMessage; | |
267 | + m_stOldNtfyIcon[icon] = m_stNtfyIcon[icon]; | |
268 | + | |
269 | + BOOL rc = FALSE; | |
270 | + for (int retry_count = 0; retry_count < 20; ++retry_count) { // retry for timeout | |
271 | + rc = Shell_NotifyIcon(dwMessage, &m_stNtfyIcon[icon]); | |
272 | + if (dwMessage != NIM_ADD || rc || (GetLastError() != ERROR_TIMEOUT && 5 < retry_count)) { | |
273 | + break; | |
274 | + } | |
275 | + Sleep(1000); // 1sec | |
276 | + if ((rc = Shell_NotifyIcon(NIM_MODIFY, &m_stNtfyIcon[icon])) != FALSE) { | |
277 | + break; // ERROR_TIMEOUT was returned but the icon was also added. | |
278 | + } | |
279 | + } | |
280 | + return rc; | |
281 | + } else { | |
282 | + return TRUE; | |
283 | + } | |
284 | +} | |
285 | + | |
286 | +void CMainFrame::EnableShell_NotifyIcon(ICON_TYPE icon, BOOL bEnable) | |
287 | +{ | |
288 | + DeleteShell_NotifyIcon(icon); | |
289 | + m_bIcon[icon] = bEnable; | |
290 | + AddShell_NotifyIcon(icon); | |
291 | +} | |
292 | + | |
293 | +void CMainFrame::AddShell_NotifyIcon(ICON_TYPE icon) | |
294 | +{ | |
295 | + DoShell_NotifyIcon(icon, NIM_ADD); | |
296 | +} | |
297 | + | |
298 | +void CMainFrame::DeleteShell_NotifyIcon(ICON_TYPE icon) | |
299 | +{ | |
300 | + DoShell_NotifyIcon(icon, NIM_DELETE); | |
301 | +} | |
302 | + | |
303 | +void CMainFrame::DeleteAllShell_NotifyIcon() | |
304 | +{ | |
305 | + for (int icon = 0; icon < MAX_ICON_TYPE; ++icon) { | |
306 | + DeleteShell_NotifyIcon((ICON_TYPE)icon); | |
307 | + } | |
308 | +} | |
309 | + | |
310 | +void CMainFrame::AddAllShell_NotifyIcon() | |
311 | +{ | |
312 | + for (int icon = 0; icon < MAX_ICON_TYPE; ++icon) { | |
313 | + AddShell_NotifyIcon((ICON_TYPE)icon); | |
314 | + } | |
315 | +} | |
316 | + | |
199 | 317 | ///////////////////////////////////////////////////////////////////////////// |
200 | 318 | // CMainFrame diagnostics |
201 | 319 |
@@ -355,7 +473,7 @@ LRESULT CMainFrame::WindowProc(const UINT message, const WPARAM wParam, const LP | ||
355 | 473 | } |
356 | 474 | default: |
357 | 475 | if (message == s_uTaskbarRestart) { |
358 | - CXkeymacsDll::AddAllShell_NotifyIcon(); | |
476 | + AddAllShell_NotifyIcon(); | |
359 | 477 | } |
360 | 478 | break; |
361 | 479 | } |
@@ -408,7 +526,8 @@ void CMainFrame::OnQuit() | ||
408 | 526 | } |
409 | 527 | |
410 | 528 | CXkeymacsDll::ReleaseHooks(); |
411 | - CXkeymacsDll::DeleteAllShell_NotifyIcon(); | |
529 | + TerminatePollThread(); | |
530 | + DeleteAllShell_NotifyIcon(); | |
412 | 531 | |
413 | 532 | PostQuitMessage(0); |
414 | 533 | } |
@@ -457,6 +576,8 @@ void CMainFrame::OnReset() | ||
457 | 576 | { |
458 | 577 | CXkeymacsDll::ReleaseHooks(); |
459 | 578 | CXkeymacsDll::SetHooks(); |
579 | + TerminatePollThread(); | |
580 | + StartPollThread(); | |
460 | 581 | } |
461 | 582 | |
462 | 583 | void CMainFrame::OnHelpFinder() |
@@ -87,6 +87,24 @@ private: | ||
87 | 87 | int m_nResultAboutDlg; |
88 | 88 | int m_nResultPropertiesDlg; |
89 | 89 | CProperties *m_pPropertiesDlg; |
90 | + // notify icons | |
91 | + BOOL m_bIcon[MAX_ICON_TYPE]; | |
92 | + HICON m_hIcon[MAX_ICON_TYPE][MAX_STATUS]; | |
93 | + DWORD m_dwOldMessage[MAX_ICON_TYPE]; | |
94 | + NOTIFYICONDATA m_stNtfyIcon[MAX_ICON_TYPE]; | |
95 | + NOTIFYICONDATA m_stOldNtfyIcon[MAX_ICON_TYPE]; | |
96 | + void AddShell_NotifyIcon(ICON_TYPE icon); | |
97 | + void DeleteShell_NotifyIcon(ICON_TYPE icon); | |
98 | + BOOL DoShell_NotifyIcon(ICON_TYPE icon, DWORD dwMessage); | |
99 | + void DeleteAllShell_NotifyIcon(); | |
100 | + void AddAllShell_NotifyIcon(); | |
101 | + BOOL m_bPollIconMessage; | |
102 | + HANDLE m_hThread; | |
103 | + void StartPollThread(); | |
104 | + void TerminatePollThread(); | |
105 | + static DWORD WINAPI PollIconMessage(LPVOID lpParam); | |
106 | +public: | |
107 | + void EnableShell_NotifyIcon(ICON_TYPE icon, BOOL bEnable); | |
90 | 108 | }; |
91 | 109 | |
92 | 110 | ///////////////////////////////////////////////////////////////////////////// |
@@ -160,12 +160,13 @@ void COptionsDlg::OnOK() | ||
160 | 160 | AfxGetApp()->WriteProfileInt(CString(), CString(MAKEINTRESOURCE(IDS_REG_ENTRY_ALT)), m_cAlt.GetCheck()); |
161 | 161 | |
162 | 162 | // set dll data |
163 | - CXkeymacsDll::EnableShell_NotifyIcon(CX_ICON, m_cCx.GetCheck()); | |
164 | - CXkeymacsDll::EnableShell_NotifyIcon(MX_ICON, m_cMx.GetCheck()); | |
165 | - CXkeymacsDll::EnableShell_NotifyIcon(META_ICON, m_cM_.GetCheck()); | |
166 | - CXkeymacsDll::EnableShell_NotifyIcon(SHIFT_ICON, m_cShift.GetCheck()); | |
167 | - CXkeymacsDll::EnableShell_NotifyIcon(CTRL_ICON, m_cCtrl.GetCheck()); | |
168 | - CXkeymacsDll::EnableShell_NotifyIcon(ALT_ICON, m_cAlt.GetCheck()); | |
163 | + CMainFrame *pMainFrame = static_cast<CMainFrame*>(AfxGetMainWnd()); | |
164 | + pMainFrame->EnableShell_NotifyIcon(CX_ICON, m_cCx.GetCheck()); | |
165 | + pMainFrame->EnableShell_NotifyIcon(MX_ICON, m_cMx.GetCheck()); | |
166 | + pMainFrame->EnableShell_NotifyIcon(META_ICON, m_cM_.GetCheck()); | |
167 | + pMainFrame->EnableShell_NotifyIcon(SHIFT_ICON, m_cShift.GetCheck()); | |
168 | + pMainFrame->EnableShell_NotifyIcon(CTRL_ICON, m_cCtrl.GetCheck()); | |
169 | + pMainFrame->EnableShell_NotifyIcon(ALT_ICON, m_cAlt.GetCheck()); | |
169 | 170 | } |
170 | 171 | |
171 | 172 | CDialog::OnOK(); |
@@ -1600,7 +1600,6 @@ BOOL CCommands::bC_() | ||
1600 | 1600 | void CCommands::bC_(BOOL b) |
1601 | 1601 | { |
1602 | 1602 | m_bC_ = b; |
1603 | - CXkeymacsDll::ModifyShell_NotifyIcon(CTRL_ICON, m_bC_); | |
1604 | 1603 | } |
1605 | 1604 | |
1606 | 1605 | BOOL CCommands::bC_x() |
@@ -1611,7 +1610,6 @@ BOOL CCommands::bC_x() | ||
1611 | 1610 | void CCommands::bC_x(BOOL b) |
1612 | 1611 | { |
1613 | 1612 | m_bC_x = b; |
1614 | - CXkeymacsDll::ModifyShell_NotifyIcon(CX_ICON, m_bC_x); | |
1615 | 1613 | } |
1616 | 1614 | |
1617 | 1615 | BOOL CCommands::bM_x() |
@@ -1624,9 +1622,9 @@ void CCommands::bM_x(const BOOL b) | ||
1624 | 1622 | m_bM_x = b; |
1625 | 1623 | |
1626 | 1624 | if (b) { |
1627 | - CXkeymacsDll::ModifyM_xTip(""); | |
1625 | + CXkeymacsDll::SetM_xTip(""); | |
1628 | 1626 | } else { |
1629 | - CXkeymacsDll::ModifyM_xTip(NULL); | |
1627 | + CXkeymacsDll::SetM_xTip(NULL); | |
1630 | 1628 | } |
1631 | 1629 | } |
1632 | 1630 |
@@ -1804,7 +1802,6 @@ int CCommands::Ignore() | ||
1804 | 1802 | void CCommands::bM_(BOOL b) |
1805 | 1803 | { |
1806 | 1804 | m_bM_ = b; |
1807 | - CXkeymacsDll::ModifyShell_NotifyIcon(META_ICON, m_bM_); | |
1808 | 1805 | } |
1809 | 1806 | |
1810 | 1807 | BOOL CCommands::bM_() |
@@ -0,0 +1,15 @@ | ||
1 | +#ifndef IPC_H_INCLUDED | |
2 | +#define IPC_H_INCLUDED | |
3 | + | |
4 | +#if _MSC_VER > 1000 | |
5 | +#pragma once | |
6 | +#endif // _MSC_VER > 1000 | |
7 | + | |
8 | +struct ICONMSG { | |
9 | + ICON_TYPE nType; | |
10 | + int nState; | |
11 | + TCHAR szTip[128]; | |
12 | +}; | |
13 | + | |
14 | +#define ICON_PIPE _T("\\\\.\\pipe\\XKEYMACS_ICON") | |
15 | +#endif |
@@ -200,6 +200,7 @@ | ||
200 | 200 | <ClInclude Include="ClipboardSnap.h" /> |
201 | 201 | <ClInclude Include="Commands.h" /> |
202 | 202 | <ClInclude Include="FunctionDefinition.h" /> |
203 | + <ClInclude Include="ipc.h" /> | |
203 | 204 | <ClInclude Include="resource.h" /> |
204 | 205 | <ClInclude Include="StdAfx.h" /> |
205 | 206 | <ClInclude Include="Utils.h" /> |
@@ -70,6 +70,9 @@ | ||
70 | 70 | <ClInclude Include="xkeymacsdll.h"> |
71 | 71 | <Filter>Header Files</Filter> |
72 | 72 | </ClInclude> |
73 | + <ClInclude Include="ipc.h"> | |
74 | + <Filter>Header Files</Filter> | |
75 | + </ClInclude> | |
73 | 76 | </ItemGroup> |
74 | 77 | <ItemGroup> |
75 | 78 | <ResourceCompile Include="xkeymacsdll.rc"> |
@@ -152,7 +152,7 @@ DllMain(HINSTANCE hInstance, DWORD dwReason, LPVOID lpReserved) | ||
152 | 152 | switch (dwReason) { |
153 | 153 | case DLL_PROCESS_ATTACH: |
154 | 154 | TRACE0("XKEYMACSDLL.DLL Initializing!\n"); |
155 | - | |
155 | + | |
156 | 156 | // Extension DLL one-time initialization |
157 | 157 | if (!AfxInitExtensionModule(XkeymacsdllDLL, hInstance)) { |
158 | 158 | return 0; |
@@ -211,11 +211,6 @@ DllMain(HINSTANCE hInstance, DWORD dwReason, LPVOID lpReserved) | ||
211 | 211 | BOOL CXkeymacsDll::m_bRightShift = FALSE; |
212 | 212 | BOOL CXkeymacsDll::m_bHook = TRUE; |
213 | 213 | BOOL CXkeymacsDll::m_bDefiningMacro = FALSE; |
214 | - DWORD CXkeymacsDll::m_dwOldMessage[MAX_ICON_TYPE] = {'\0'}; | |
215 | - NOTIFYICONDATA CXkeymacsDll::m_stNtfyIcon[MAX_ICON_TYPE] = {'\0'}; | |
216 | - NOTIFYICONDATA CXkeymacsDll::m_stOldNtfyIcon[MAX_ICON_TYPE] = {'\0'}; | |
217 | - HICON CXkeymacsDll::m_hIcon[MAX_ICON_TYPE][MAX_STATUS] = {'\0'}; | |
218 | - BOOL CXkeymacsDll::m_bIcon[MAX_ICON_TYPE] = {'\0'}; | |
219 | 214 | int CXkeymacsDll::m_nKillRingMax[MAX_APP] = {'\0'}; |
220 | 215 | BOOL CXkeymacsDll::m_bUseDialogSetting[MAX_APP] = {'\0'}; |
221 | 216 | CList<CClipboardSnap *, CClipboardSnap *> CXkeymacsDll::m_oKillRing; |
@@ -238,6 +233,7 @@ DllMain(HINSTANCE hInstance, DWORD dwReason, LPVOID lpReserved) | ||
238 | 233 | BOOL CXkeymacsDll::m_bCursor = FALSE; |
239 | 234 | BOOL CXkeymacsDll::m_b326Compatible[MAX_APP] = {'\0'}; |
240 | 235 | BOOL CXkeymacsDll::m_b106Keyboard = FALSE; |
236 | + TCHAR CXkeymacsDll::m_M_xTip[128] = ""; | |
241 | 237 | #pragma data_seg() |
242 | 238 | |
243 | 239 | ////////////////////////////////////////////////////////////////////// |
@@ -254,81 +250,6 @@ CXkeymacsDll::~CXkeymacsDll() | ||
254 | 250 | |
255 | 251 | } |
256 | 252 | |
257 | -int CXkeymacsDll::ModifyShell_NotifyIcon(ICON_TYPE icon, BOOL bNewStatus, BOOL bForce) | |
258 | -{ | |
259 | - if (m_stNtfyIcon[icon].hIcon == (bNewStatus ? m_hIcon[icon][ON_ICON] : m_hIcon[icon][OFF_ICON])) { | |
260 | - if (!bForce) { | |
261 | - return TRUE; | |
262 | - } | |
263 | - } else { | |
264 | - m_stNtfyIcon[icon].hIcon = (bNewStatus ? m_hIcon[icon][ON_ICON] : m_hIcon[icon][OFF_ICON]); | |
265 | - } | |
266 | - return DoShell_NotifyIcon(icon, NIM_MODIFY); | |
267 | -} | |
268 | - | |
269 | -void CXkeymacsDll::SetNotifyIconData(ICON_TYPE icon, NOTIFYICONDATA stNtfyIcon, HICON hEnable, HICON hDisableTMP, HICON hDisableWOCQ, HICON hDisable, BOOL bEnable) | |
270 | -{ | |
271 | - m_hIcon[icon][STATUS_ENABLE] = hEnable; | |
272 | - m_hIcon[icon][STATUS_DISABLE_TMP] = hDisableTMP; | |
273 | - m_hIcon[icon][STATUS_DISABLE_WOCQ] = hDisableWOCQ; | |
274 | - m_hIcon[icon][STATUS_DISABLE] = hDisable; | |
275 | - m_bIcon[icon] = bEnable; | |
276 | - m_stNtfyIcon[icon] = stNtfyIcon; | |
277 | - AddShell_NotifyIcon(icon); | |
278 | -} | |
279 | - | |
280 | -void CXkeymacsDll::SetNotifyIconData(ICON_TYPE icon, NOTIFYICONDATA stNtfyIcon, HICON hOn, HICON hOff, BOOL bEnable) | |
281 | -{ | |
282 | - m_hIcon[icon][ON_ICON] = hOn; | |
283 | - m_hIcon[icon][OFF_ICON] = hOff; | |
284 | - m_bIcon[icon] = bEnable; | |
285 | - m_stNtfyIcon[icon] = stNtfyIcon; | |
286 | - AddShell_NotifyIcon(icon); | |
287 | -} | |
288 | - | |
289 | -void CXkeymacsDll::EnableShell_NotifyIcon(ICON_TYPE icon, BOOL bEnable) | |
290 | -{ | |
291 | - DeleteShell_NotifyIcon(icon); | |
292 | - m_bIcon[icon] = bEnable; | |
293 | - AddShell_NotifyIcon(icon); | |
294 | -} | |
295 | - | |
296 | - | |
297 | -BOOL CXkeymacsDll::DoShell_NotifyIcon(ICON_TYPE icon, DWORD dwMessage) | |
298 | -{ | |
299 | - if (m_bIcon[icon] | |
300 | - && (m_dwOldMessage[icon] != dwMessage | |
301 | - || memcmp(&m_stOldNtfyIcon[icon], &m_stNtfyIcon[icon], sizeof(m_stNtfyIcon[icon])))) { | |
302 | - m_dwOldMessage[icon] = dwMessage; | |
303 | - m_stOldNtfyIcon[icon] = m_stNtfyIcon[icon]; | |
304 | - | |
305 | - BOOL rc = FALSE; | |
306 | - for (int retry_count = 0; retry_count < 20; ++retry_count) { // retry for timeout | |
307 | - rc = Shell_NotifyIcon(dwMessage, &m_stNtfyIcon[icon]); | |
308 | - if (dwMessage != NIM_ADD || rc || (GetLastError() != ERROR_TIMEOUT && 5 < retry_count)) { | |
309 | - break; | |
310 | - } | |
311 | - Sleep(1000); // 1sec | |
312 | - if ((rc = Shell_NotifyIcon(NIM_MODIFY, &m_stNtfyIcon[icon])) != FALSE) { | |
313 | - break; // ERROR_TIMEOUT was returned but the icon was also added. | |
314 | - } | |
315 | - } | |
316 | - return rc; | |
317 | - } else { | |
318 | - return TRUE; | |
319 | - } | |
320 | -} | |
321 | - | |
322 | -void CXkeymacsDll::AddShell_NotifyIcon(ICON_TYPE icon) | |
323 | -{ | |
324 | - DoShell_NotifyIcon(icon, NIM_ADD); | |
325 | -} | |
326 | - | |
327 | -void CXkeymacsDll::DeleteShell_NotifyIcon(ICON_TYPE icon) | |
328 | -{ | |
329 | - DoShell_NotifyIcon(icon, NIM_DELETE); | |
330 | -} | |
331 | - | |
332 | 253 | // set hooks |
333 | 254 | void CXkeymacsDll::SetHooks() |
334 | 255 | { |
@@ -373,26 +294,25 @@ void CXkeymacsDll::ReleaseKeyboardHook() | ||
373 | 294 | void CXkeymacsDll::SetKeyboardHookFlag(BOOL bFlag) |
374 | 295 | { |
375 | 296 | m_bHook = bFlag; |
376 | - | |
297 | + ICONMSG msg = {MAIN_ICON,}; | |
377 | 298 | if (m_bHook) { |
378 | 299 | if (CCommands::IsTemporarilyDisableXKeymacs()) { |
379 | - m_stNtfyIcon[MAIN_ICON].hIcon = m_hIcon[MAIN_ICON][STATUS_DISABLE_TMP]; | |
300 | + msg.nState = STATUS_DISABLE_TMP; | |
380 | 301 | m_hCurrentCursor = m_hCursor[STATUS_DISABLE_TMP]; |
381 | 302 | } else { |
382 | - m_stNtfyIcon[MAIN_ICON].hIcon = m_hIcon[MAIN_ICON][STATUS_ENABLE]; | |
303 | + msg.nState = STATUS_ENABLE; | |
383 | 304 | m_hCurrentCursor = m_hCursor[STATUS_ENABLE]; |
384 | 305 | } |
385 | 306 | } else { |
386 | - m_stNtfyIcon[MAIN_ICON].hIcon = m_hIcon[MAIN_ICON][STATUS_DISABLE_WOCQ]; | |
387 | - m_hCurrentCursor = m_hCursor[STATUS_DISABLE_WOCQ]; | |
307 | + msg.nState = STATUS_DISABLE_WOCQ; | |
388 | 308 | } |
389 | 309 | if (m_nSettingStyle[m_nApplicationID] == SETTING_DISABLE |
390 | 310 | || (!_tcsicmp(m_szSpecialApp[m_nApplicationID], _T("Default")) |
391 | 311 | && CUtils::IsDefaultIgnoreApplication())) { |
392 | - m_stNtfyIcon[MAIN_ICON].hIcon = m_hIcon[MAIN_ICON][STATUS_DISABLE]; | |
312 | + msg.nState = STATUS_DISABLE; | |
393 | 313 | m_hCurrentCursor = m_hCursor[STATUS_DISABLE]; |
394 | 314 | } |
395 | - DoShell_NotifyIcon(MAIN_ICON, NIM_MODIFY); | |
315 | + SendIconMessage(&msg, 1); | |
396 | 316 | DoSetCursor(); |
397 | 317 | } |
398 | 318 |
@@ -792,9 +712,12 @@ void CXkeymacsDll::InitKeyboardProc(BOOL bImeComposition) | ||
792 | 712 | } |
793 | 713 | } |
794 | 714 | |
795 | - ModifyShell_NotifyIcon(CX_ICON, FALSE); | |
796 | - ModifyShell_NotifyIcon(MX_ICON, FALSE); | |
797 | - ModifyShell_NotifyIcon(META_ICON, FALSE); | |
715 | + ICONMSG msg[3] = { | |
716 | + {CX_ICON, OFF_ICON, ""}, | |
717 | + {MX_ICON, OFF_ICON, ""}, | |
718 | + {META_ICON, OFF_ICON, ""} | |
719 | + }; | |
720 | + SendIconMessage(msg, 3); | |
798 | 721 | CCommands::SetMark(FALSE); |
799 | 722 | CCommands::SetTemporarilyDisableXKeymacs(FALSE); |
800 | 723 | CCommands::Reset(); |
@@ -1025,13 +948,13 @@ LRESULT CALLBACK CXkeymacsDll::KeyboardProc(int nCode, WPARAM wParam, LPARAM lPa | ||
1025 | 948 | if (index) { |
1026 | 949 | --index; |
1027 | 950 | memmove(&szPath[index], &szPath[index + 1], _tcslen(szPath) - index); |
1028 | - ModifyM_xTip(szPath); | |
951 | + SetM_xTip(szPath); | |
1029 | 952 | } |
1030 | 953 | goto HOOKX; |
1031 | 954 | } else if (Commands[m_nCommandID[m_nApplicationID][nCommandType][nKey]].fCommand == CCommands::DeleteChar) { |
1032 | 955 | if (index < _tcslen(szPath)) { |
1033 | 956 | memmove(&szPath[index], &szPath[index + 1], _tcslen(szPath) - index); |
1034 | - ModifyM_xTip(szPath); | |
957 | + SetM_xTip(szPath); | |
1035 | 958 | } |
1036 | 959 | goto HOOKX; |
1037 | 960 | } else if (Commands[m_nCommandID[m_nApplicationID][nCommandType][nKey]].fCommand == CCommands::EndOfLine) { |
@@ -1065,7 +988,7 @@ LRESULT CALLBACK CXkeymacsDll::KeyboardProc(int nCode, WPARAM wParam, LPARAM lPa | ||
1065 | 988 | } |
1066 | 989 | szPath[index++] = nAscii; |
1067 | 990 | // CUtils::Log("M-x: %c(%#04x)", nAscii, nAscii); |
1068 | - ModifyM_xTip(szPath); | |
991 | + SetM_xTip(szPath); | |
1069 | 992 | goto HOOKX; |
1070 | 993 | } |
1071 | 994 | } |
@@ -1225,10 +1148,7 @@ RECURSIVE_COMMAND: | ||
1225 | 1148 | } |
1226 | 1149 | |
1227 | 1150 | DO_NOTHING: |
1228 | - ModifyShell_NotifyIcon(SHIFT_ICON, IsDown(VK_SHIFT)); | |
1229 | - ModifyShell_NotifyIcon(CTRL_ICON, IsControl()); | |
1230 | - ModifyShell_NotifyIcon(ALT_ICON, IsDown(VK_MENU)); | |
1231 | - | |
1151 | + SetModifierIcons(); | |
1232 | 1152 | { |
1233 | 1153 | static BOOL bDefiningMacro = FALSE; |
1234 | 1154 | if (m_bDefiningMacro) { |
@@ -1271,22 +1191,31 @@ DO_NOTHING: | ||
1271 | 1191 | |
1272 | 1192 | RECURSIVE: |
1273 | 1193 | Kdu(RECURSIVE_KEY, 1, FALSE); |
1274 | - ModifyShell_NotifyIcon(SHIFT_ICON, IsDown(VK_SHIFT)); | |
1275 | - ModifyShell_NotifyIcon(CTRL_ICON, IsControl()); | |
1276 | - ModifyShell_NotifyIcon(ALT_ICON, IsDown(VK_MENU)); | |
1277 | - return TRUE; | |
1278 | - | |
1194 | + goto HOOKX; | |
1279 | 1195 | HOOK: |
1280 | 1196 | CCommands::SetLastCommand(fCommand); |
1281 | 1197 | HOOK0_9: |
1282 | 1198 | HOOKX: |
1283 | - ModifyShell_NotifyIcon(SHIFT_ICON, IsDown(VK_SHIFT)); | |
1284 | - ModifyShell_NotifyIcon(CTRL_ICON, IsControl()); | |
1285 | - ModifyShell_NotifyIcon(ALT_ICON, IsDown(VK_MENU)); | |
1199 | + SetModifierIcons(); | |
1286 | 1200 | HOOK_RECURSIVE_KEY: |
1287 | 1201 | return TRUE; |
1288 | 1202 | } |
1289 | 1203 | |
1204 | +void CXkeymacsDll::SetModifierIcons() | |
1205 | +{ | |
1206 | +#define IconState(x) ((x) ? ON_ICON : OFF_ICON) | |
1207 | + ICONMSG msg[6] = { | |
1208 | + {MX_ICON, IconState(CCommands::bM_x()), ""}, | |
1209 | + {CX_ICON, IconState(CCommands::bC_x()), ""}, | |
1210 | + {META_ICON, IconState(CCommands::bM_()), ""}, | |
1211 | + {SHIFT_ICON, IconState(IsDown(VK_SHIFT)), ""}, | |
1212 | + {CTRL_ICON, IconState(IsControl()), ""}, | |
1213 | + {ALT_ICON, IconState(IsDown(VK_MENU)), ""} | |
1214 | + }; | |
1215 | + _tcscpy_s(msg[0].szTip, m_M_xTip); | |
1216 | + SendIconMessage(msg, 6); | |
1217 | +} | |
1218 | + | |
1290 | 1219 | void CXkeymacsDll::SetApplicationName(int nApplicationID, CString szApplicationName) |
1291 | 1220 | { |
1292 | 1221 | ZeroMemory(m_szSpecialApp[nApplicationID], sizeof(m_szSpecialApp[nApplicationID])); |
@@ -2088,20 +2017,6 @@ BYTE CXkeymacsDll::a2v(TCHAR nAscii) | ||
2088 | 2017 | } |
2089 | 2018 | } |
2090 | 2019 | |
2091 | -void CXkeymacsDll::DeleteAllShell_NotifyIcon() | |
2092 | -{ | |
2093 | - for (int icon = 0; icon < MAX_ICON_TYPE; ++icon) { | |
2094 | - DeleteShell_NotifyIcon((ICON_TYPE)icon); | |
2095 | - } | |
2096 | -} | |
2097 | - | |
2098 | -void CXkeymacsDll::AddAllShell_NotifyIcon() | |
2099 | -{ | |
2100 | - for (int icon = 0; icon < MAX_ICON_TYPE; ++icon) { | |
2101 | - AddShell_NotifyIcon((ICON_TYPE)icon); | |
2102 | - } | |
2103 | -} | |
2104 | - | |
2105 | 2020 | BOOL CXkeymacsDll::IsMatchWindowText(CString szWindowText) |
2106 | 2021 | { |
2107 | 2022 | BOOL bIsMatchWindowText = TRUE; |
@@ -2210,17 +2125,15 @@ void CXkeymacsDll::InvokeM_x(const TCHAR *const szPath) | ||
2210 | 2125 | } |
2211 | 2126 | } |
2212 | 2127 | |
2213 | -void CXkeymacsDll::ModifyM_xTip(const TCHAR *const szPath) | |
2128 | +void CXkeymacsDll::SetM_xTip(const TCHAR *const szPath) | |
2214 | 2129 | { |
2215 | - if (szPath) { | |
2216 | - if (_tcslen(szPath) < sizeof(m_stNtfyIcon[MX_ICON].szTip) / sizeof(m_stNtfyIcon[MX_ICON].szTip[0]) - 5) { | |
2217 | - memset(m_stNtfyIcon[MX_ICON].szTip, 0, sizeof(m_stNtfyIcon[MX_ICON].szTip)); | |
2218 | - _stprintf(m_stNtfyIcon[MX_ICON].szTip, "M-x %s", szPath); | |
2219 | - } | |
2220 | - } else { | |
2221 | - memset(m_stNtfyIcon[MX_ICON].szTip, 0, sizeof(m_stNtfyIcon[MX_ICON].szTip)); | |
2222 | - _stprintf(m_stNtfyIcon[MX_ICON].szTip, "M-x LED"); | |
2223 | - } | |
2130 | + _tcscpy_s(m_M_xTip, "M-x LED"); | |
2131 | + if (szPath && _tcslen(szPath) < 128 - 5) | |
2132 | + _stprintf_s(m_M_xTip, "M-x %s", szPath); | |
2133 | +} | |
2224 | 2134 | |
2225 | - ModifyShell_NotifyIcon(MX_ICON, CCommands::bM_x(), TRUE); | |
2135 | +BOOL CXkeymacsDll::SendIconMessage(ICONMSG *pMsg, DWORD num) | |
2136 | +{ | |
2137 | + DWORD ack, read; | |
2138 | + return CallNamedPipe(ICON_PIPE, pMsg, sizeof(ICONMSG) * num, &ack, sizeof(DWORD), &read, NMPWAIT_NOWAIT); | |
2226 | 2139 | } |
@@ -35,6 +35,8 @@ enum { EXTENDED_KEY = 0x01000000 }; | ||
35 | 35 | enum { REPEATED_KEY = 0x40000000 }; |
36 | 36 | enum { BEING_RELEASED = 0x80000000 }; |
37 | 37 | |
38 | +#include "ipc.h" | |
39 | + | |
38 | 40 | struct KeyBind |
39 | 41 | { |
40 | 42 | int nCommandType; |
@@ -51,7 +53,7 @@ struct KeyName | ||
51 | 53 | class AFX_EXT_CLASS CXkeymacsDll |
52 | 54 | { |
53 | 55 | public: |
54 | - static void ModifyM_xTip(const TCHAR *const szPath); | |
56 | + static void SetM_xTip(const TCHAR *const szPath); | |
55 | 57 | static BOOL Get326Compatible(); |
56 | 58 | static void Set326Compatible(int nApplicationID, BOOL b326Compatible); |
57 | 59 | static void SetCursorData(HCURSOR hEnable, HCURSOR hDisableTMP, HCURSOR hDisableWOCQ, HICON hDisable, BOOL bEnable); |
@@ -60,12 +62,7 @@ public: | ||
60 | 62 | static int GetAccelerate(void); |
61 | 63 | static void SetAccelerate(int nAccelerate); |
62 | 64 | static void SetWindowText(int nApplicationID, CString szWindowText); |
63 | - static void AddAllShell_NotifyIcon(); | |
64 | - static void DeleteAllShell_NotifyIcon(); | |
65 | 65 | static void SetKillRingMax(int nApplicationID, int nKillRingMax); |
66 | - static void EnableShell_NotifyIcon(ICON_TYPE icon, BOOL bEnable); | |
67 | - static void SetNotifyIconData(ICON_TYPE icon, NOTIFYICONDATA stNtfyIcon, HICON hEnable, HICON hDisableTMP, HICON hDisableWOCQ, HICON hDisable, BOOL bEnable); | |
68 | - static void SetNotifyIconData(ICON_TYPE icon, NOTIFYICONDATA stNtfyIcon, HICON hOn, HICON hOff, BOOL bEnable); | |
69 | 66 | static void Clear(int nApplicationID); |
70 | 67 | static BOOL IsKeyboardHook(); |
71 | 68 | static void SetCommandID(int nApplicationID, int nCommandType, int nKey, int nCommandID); |
@@ -90,7 +87,6 @@ public: | ||
90 | 87 | static void IncreaseKillRingIndex(int nKillRing = 1); |
91 | 88 | static BOOL IsDown(BYTE bVk, BOOL bPhysicalKey = TRUE); |
92 | 89 | static void Kdu(BYTE bVk, DWORD n = 1, BOOL bOriginal = TRUE); |
93 | - static int ModifyShell_NotifyIcon(ICON_TYPE icon, BOOL bNewStatus, BOOL bForce = TRUE); | |
94 | 90 | static void ReleaseKey(BYTE bVk); |
95 | 91 | static void SetFunctionDefinition(int nFunctionID, CString szDefinition); |
96 | 92 | static void SetFunctionKey(int nFunctionID, int nApplicationID, int nCommandType, int nKey); |
@@ -98,9 +94,11 @@ public: | ||
98 | 94 | static void SetKeyboardHookFlag(BOOL bFlag); |
99 | 95 | static BOOL Is106Keyboard(); |
100 | 96 | static void Set106Keyboard(BOOL b106Keyboard); |
97 | + static BOOL SendIconMessage(ICONMSG *pMsg, DWORD num); | |
101 | 98 | CXkeymacsDll(); |
102 | 99 | virtual ~CXkeymacsDll(); |
103 | 100 | private: |
101 | + static TCHAR m_M_xTip[128]; | |
104 | 102 | static void InvokeM_x(const TCHAR* const szPath); |
105 | 103 | static BOOL m_b326Compatible[MAX_APP]; |
106 | 104 | static void LogCallWndProcMessage(WPARAM wParam, LPARAM lParam); |
@@ -118,11 +116,10 @@ private: | ||
118 | 116 | static HHOOK m_hHookCallWnd; |
119 | 117 | static HHOOK m_hHookGetMessage; |
120 | 118 | static HHOOK m_hHookShell; |
121 | - static void AddShell_NotifyIcon(ICON_TYPE icon); | |
122 | - static void DeleteShell_NotifyIcon(ICON_TYPE icon); | |
123 | 119 | static BOOL DefiningMacro(); |
124 | 120 | static BOOL IsControl(); |
125 | 121 | static BOOL IsMeta(); |
122 | + static void SetModifierIcons(); | |
126 | 123 | static void DoKeybd_event(BYTE bVk, DWORD dwFlags); |
127 | 124 | static LRESULT CALLBACK KeyboardProc(int nCode, WPARAM wParam, LPARAM lParam); |
128 | 125 | static LRESULT CALLBACK CallWndProc(int nCode, WPARAM wParam, LPARAM lParam); |
@@ -145,7 +142,6 @@ private: | ||
145 | 142 | static BOOL m_bDefiningMacro; |
146 | 143 | static void Original(int nCommandType, BYTE bVk, int nOriginal); |
147 | 144 | static int Original(int nCommandType, BYTE bVk); |
148 | - static HICON m_hIcon[MAX_ICON_TYPE][MAX_STATUS]; | |
149 | 145 | static BOOL m_bUseDialogSetting[MAX_APP]; |
150 | 146 | static void InitKeyboardProc(BOOL bImeComposition); |
151 | 147 | static BOOL m_bIgnoreUndefinedC_x[MAX_APP]; |
@@ -157,11 +153,6 @@ private: | ||
157 | 153 | static CList<CClipboardSnap *, CClipboardSnap *> m_oKillRing; |
158 | 154 | static int m_nKillRingMax[MAX_APP]; |
159 | 155 | static int GetMickey(int nDifferential, int nThreshold1, int nThreshold2, int nAcceleration, int nSpeed); |
160 | - static BOOL DoShell_NotifyIcon(ICON_TYPE icon, DWORD dwMessage); | |
161 | - static BOOL m_bIcon[MAX_ICON_TYPE]; | |
162 | - static DWORD m_dwOldMessage[MAX_ICON_TYPE]; | |
163 | - static NOTIFYICONDATA m_stNtfyIcon[MAX_ICON_TYPE]; | |
164 | - static NOTIFYICONDATA m_stOldNtfyIcon[MAX_ICON_TYPE]; | |
165 | 156 | static BOOL m_bHook; |
166 | 157 | static BOOL m_bRightShift; |
167 | 158 | static BOOL m_bRightAlt; |