Develop and Download Open Source Software

Browse Subversion Repository

Annotation of /branches/ttcomtester/teraterm/teraterm/vtwin.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 8546 - (hide annotations) (download) (as text)
Tue Feb 18 16:50:50 2020 UTC (4 years, 1 month ago) by zmatsuo
Original Path: trunk/teraterm/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 186353 byte(s)
ブロードキャストダイアログの文字化けを修正

- dlglib_cpp.cpp内の不要コードを削除
- layer_for_unicode にダイアログボックス系を追加
  - _CreateDialogIndirectParamW()
  - _DialogBoxIndirectParamW()
1 doda 6806 /*
2     * Copyright (C) 1994-1998 T. Teranishi
3 zmatsuo 8479 * (C) 2004-2020 TeraTerm Project
4 doda 6806 * All rights reserved.
5     *
6 doda 6841 * Redistribution and use in source and binary forms, with or without
7     * modification, are permitted provided that the following conditions
8     * are met:
9 doda 6806 *
10 doda 6841 * 1. Redistributions of source code must retain the above copyright
11     * notice, this list of conditions and the following disclaimer.
12     * 2. Redistributions in binary form must reproduce the above copyright
13     * notice, this list of conditions and the following disclaimer in the
14     * documentation and/or other materials provided with the distribution.
15     * 3. The name of the author may not be used to endorse or promote products
16     * derived from this software without specific prior written permission.
17 doda 6806 *
18 doda 6841 * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR
19     * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20     * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21     * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT,
22     * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23     * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24     * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25     * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26     * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27     * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 doda 6806 */
29 maya 3227 /* IPv6 modification is Copyright(C) 2000 Jun-ya Kato <kato@win6.jp> */
30    
31     /* TERATERM.EXE, VT window */
32    
33 zmatsuo 7554 #include "teraterm_conf.h"
34 maya 3227 #include "teraterm.h"
35     #include "tttypes.h"
36    
37     #include "ttcommon.h"
38     #include "ttwinman.h"
39     #include "ttsetup.h"
40     #include "keyboard.h"
41     #include "buffer.h"
42     #include "vtterm.h"
43     #include "vtdisp.h"
44     #include "ttdialog.h"
45     #include "ttime.h"
46     #include "commlib.h"
47     #include "clipboar.h"
48     #include "ttftypes.h"
49     #include "filesys.h"
50     #include "telnet.h"
51     #include "tektypes.h"
52     #include "ttdde.h"
53     #include "ttlib.h"
54 zmatsuo 7528 #include "dlglib.h"
55 maya 3227 #include "helpid.h"
56     #include "teraprn.h"
57     #include <winsock2.h>
58     #include <ws2tcpip.h>
59     #include "ttplug.h" /* TTPLUG */
60 zmatsuo 7589 #include "teraterml.h"
61 maya 3227
62     #include <stdio.h>
63 zmatsuo 8463 #define _CRTDBG_MAP_ALLOC
64 maya 3227 #include <stdlib.h>
65 zmatsuo 8463 #include <crtdbg.h>
66 maya 3227 #include <string.h>
67     #include <locale.h>
68    
69     #include <shlobj.h>
70     #include <io.h>
71     #include <errno.h>
72     #include <imagehlp.h>
73    
74     #include <windowsx.h>
75 yutakapon 3898 #include <imm.h>
76 zmatsuo 7542 #include <dbt.h>
77 zmatsuo 7487 #include <assert.h>
78 doda 8445 #include <wchar.h>
79 maya 3227
80     #include "tt_res.h"
81     #include "vtwin.h"
82     #include "addsetting.h"
83 yutakapon 4385 #include "winjump.h"
84 doda 7089 #include "sizetip.h"
85 zmatsuo 7148 #include "dnddlg.h"
86 zmatsuo 7527 #include "tekwin.h"
87 zmatsuo 7528 #include <htmlhelp.h>
88 zmatsuo 7457 #include "compat_win.h"
89 doda 8445 #include "unicode_test.h"
90     #if UNICODE_DEBUG
91 zmatsuo 8122 #include "tipwin.h"
92 doda 8445 #endif
93     #include "codeconv.h"
94     #include "layer_for_unicode.h"
95     #include "sendmem.h"
96 maya 3227
97 salarm 6100 #include "initguid.h"
98 maya 6101 //#include "Usbiodef.h"
99     DEFINE_GUID(GUID_DEVINTERFACE_USB_DEVICE, 0xA5DCBF10L, 0x6530, 0x11D2, 0x90, 0x1F, 0x00, \
100     0xC0, 0x4F, 0xB9, 0x51, 0xED);
101 salarm 6100
102 zmatsuo 8519 #define VTClassName L"VTWin32"
103 zmatsuo 7528
104 maya 3227 // �E�B���h�E�������{�^�����L�������� (2005.1.15 yutaka)
105     #define WINDOW_MAXMIMUM_ENABLED 1
106    
107     // WM_COPYDATA�������v���Z�X�����M������ (2005.1.22 yutaka)
108     #define IPC_BROADCAST_COMMAND 1 // �S�[�������M
109     #define IPC_MULTICAST_COMMAND 2 // �C�����[���Q�����M
110    
111     #define BROADCAST_LOGFILE "broadcast.log"
112    
113 doda 3580 static BOOL TCPLocalEchoUsed = FALSE;
114     static BOOL TCPCRSendUsed = FALSE;
115    
116 doda 5341 static BOOL IgnoreRelease = FALSE;
117    
118 salarm 6100 static HDEVNOTIFY hDevNotify = NULL;
119    
120 salarm 6076 static int AutoDisconnectedPort = -1;
121    
122 zmatsuo 7485 #ifndef WM_IME_COMPOSITION
123     #define WM_IME_COMPOSITION 0x010F
124     #endif
125    
126 doda 8445 #if UNICODE_INTERNAL_BUFF
127     CUnicodeDebugParam UnicodeDebugParam;
128     #endif
129    
130 maya 3227 /////////////////////////////////////////////////////////////////////////////
131     // CVTWindow
132    
133     // Tera Term�N������URL������mouse over������������ (2005.4.2 yutaka)
134 zmatsuo 7528 static void SetMouseCursor(const char *cursor)
135 maya 3227 {
136     HCURSOR hc;
137     LPCTSTR name = NULL;
138     int i;
139    
140     for (i = 0 ; MouseCursor[i].name ; i++) {
141     if (_stricmp(cursor, MouseCursor[i].name) == 0) {
142     name = MouseCursor[i].id;
143     break;
144     }
145     }
146 maya 3392 if (name == NULL) {
147 maya 3227 return;
148 maya 3392 }
149 maya 3227
150 yutakapon 6286 hc = (HCURSOR)LoadImage(NULL, name, IMAGE_CURSOR,
151 maya 3227 0, 0, LR_DEFAULTSIZE | LR_SHARED);
152    
153     if (hc != NULL) {
154     SetClassLongPtr(HVTWin, GCLP_HCURSOR, (LONG_PTR)hc);
155     }
156     }
157    
158 zmatsuo 7390 /**
159     * @param[in] alpha 0-255
160     */
161     void CVTWindow::SetWindowAlpha(BYTE alpha)
162 maya 3227 {
163 zmatsuo 7457 if (pSetLayeredWindowAttributes == NULL) {
164     return; // ���C���[�h�E�C���h�E���T�|�[�g����
165     }
166 zmatsuo 7390 if (Alpha == alpha) {
167     return; // ����������������������
168     }
169 zmatsuo 7528 LONG_PTR lp = GetWindowLongPtr(GWL_EXSTYLE);
170 zmatsuo 7390 if (lp == 0) {
171     return;
172     }
173 maya 3227
174     // 2006/03/16 by 337: BGUseAlphaBlendAPI��On������Layered����������
175     //if (ts->EtermLookfeel.BGUseAlphaBlendAPI) {
176     // �A���t�@�l��255�������A�����������������}�����������������������������B(2006.4.1 yutaka)
177     // �����o�������A�l�����X�����������������������f�����B(2007.10.19 maya)
178 zmatsuo 7390 if (alpha < 255) {
179     ::SetWindowLongPtr(HVTWin, GWL_EXSTYLE, lp | WS_EX_LAYERED);
180 zmatsuo 7457 pSetLayeredWindowAttributes(HVTWin, 0, alpha, LWA_ALPHA);
181 maya 3227 }
182     else {
183 zmatsuo 7390 // �A���t�@�l�� 255 �������A�����������������������`�������B(2007.10.22 maya)
184     ::SetWindowLongPtr(HVTWin, GWL_EXSTYLE, lp & ~WS_EX_LAYERED);
185     ::RedrawWindow(HVTWin, NULL, NULL, RDW_ERASE | RDW_INVALIDATE | RDW_FRAME);
186 maya 3227 }
187 zmatsuo 7390 Alpha = alpha;
188 maya 3227 }
189    
190 salarm 6100 void RegDeviceNotify(HWND hWnd)
191     {
192     typedef HDEVNOTIFY (WINAPI *PRegisterDeviceNotification)(HANDLE hRecipient, LPVOID NotificationFilter, DWORD Flags);
193     HMODULE h;
194     PRegisterDeviceNotification pRegisterDeviceNotification;
195     DEV_BROADCAST_DEVICEINTERFACE filter;
196 maya 3227
197 salarm 6100 if (((h = GetModuleHandle("user32.dll")) == NULL) ||
198     ((pRegisterDeviceNotification = (PRegisterDeviceNotification)GetProcAddress(h, "RegisterDeviceNotificationA")) == NULL)) {
199     return;
200     }
201    
202     ZeroMemory(&filter, sizeof(filter));
203     filter.dbcc_size = sizeof(filter);
204     filter.dbcc_devicetype = DBT_DEVTYP_DEVICEINTERFACE;
205     filter.dbcc_classguid = GUID_DEVINTERFACE_USB_DEVICE;
206     hDevNotify = pRegisterDeviceNotification(hWnd, &filter, DEVICE_NOTIFY_WINDOW_HANDLE);
207     }
208    
209     void UnRegDeviceNotify(HWND hWnd)
210     {
211     typedef BOOL (WINAPI *PUnregisterDeviceNotification)(HDEVNOTIFY Handle);
212     HMODULE h;
213     PUnregisterDeviceNotification pUnregisterDeviceNotification;
214    
215     if (((h = GetModuleHandle("user32.dll")) == NULL) ||
216     ((pUnregisterDeviceNotification = (PUnregisterDeviceNotification)GetProcAddress(h, "UnregisterDeviceNotification")) == NULL)) {
217     return;
218     }
219    
220     pUnregisterDeviceNotification(hDevNotify);
221     }
222    
223 salarm 6347 void SetAutoConnectPort(int port)
224     {
225     AutoDisconnectedPort = port;
226     }
227    
228 maya 3227 //
229     // ���O�n���h�����t�b�N�i�X�^�b�N�g���[�X���_���v�j
230     //
231     // cf. http://svn.collab.net/repos/svn/trunk/subversion/libsvn_subr/win32_crashrpt.c
232     // (2007.9.30 yutaka)
233     //
234     // ���O�R�[�h������������������
235 zmatsuo 7896 #if !defined(_M_X64)
236 zmatsuo 7541 static const char *GetExceptionString(DWORD exception)
237 maya 3227 {
238     #define EXCEPTION(x) case EXCEPTION_##x: return (#x);
239     static char buf[16];
240    
241     switch (exception)
242     {
243     EXCEPTION(ACCESS_VIOLATION)
244     EXCEPTION(DATATYPE_MISALIGNMENT)
245     EXCEPTION(BREAKPOINT)
246     EXCEPTION(SINGLE_STEP)
247     EXCEPTION(ARRAY_BOUNDS_EXCEEDED)
248     EXCEPTION(FLT_DENORMAL_OPERAND)
249     EXCEPTION(FLT_DIVIDE_BY_ZERO)
250     EXCEPTION(FLT_INEXACT_RESULT)
251     EXCEPTION(FLT_INVALID_OPERATION)
252     EXCEPTION(FLT_OVERFLOW)
253     EXCEPTION(FLT_STACK_CHECK)
254     EXCEPTION(FLT_UNDERFLOW)
255     EXCEPTION(INT_DIVIDE_BY_ZERO)
256     EXCEPTION(INT_OVERFLOW)
257     EXCEPTION(PRIV_INSTRUCTION)
258     EXCEPTION(IN_PAGE_ERROR)
259     EXCEPTION(ILLEGAL_INSTRUCTION)
260     EXCEPTION(NONCONTINUABLE_EXCEPTION)
261     EXCEPTION(STACK_OVERFLOW)
262     EXCEPTION(INVALID_DISPOSITION)
263     EXCEPTION(GUARD_PAGE)
264     EXCEPTION(INVALID_HANDLE)
265    
266     default:
267     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "0x%x", exception);
268     return buf;
269     //return "UNKNOWN_ERROR";
270     }
271     #undef EXCEPTION
272     }
273    
274     /* ���O�������������������o���������\�������A���O�t�B���^���� */
275     static LONG CALLBACK ApplicationFaultHandler(EXCEPTION_POINTERS *ExInfo)
276     {
277     HGLOBAL gptr;
278     STACKFRAME sf;
279     BOOL bResult;
280     PIMAGEHLP_SYMBOL pSym;
281     DWORD Disp;
282     HANDLE hProcess = GetCurrentProcess();
283     HANDLE hThread = GetCurrentThread();
284     IMAGEHLP_MODULE ih_module;
285     IMAGEHLP_LINE ih_line;
286     int frame;
287     char msg[3072], buf[256];
288     HMODULE h, h2;
289 maya 4134 char imagehlp_dll[MAX_PATH];
290 maya 3227
291     // Windows98/Me/NT4�����������������X�L�b�v�����B(2007.10.9 yutaka)
292 maya 4134 GetSystemDirectory(imagehlp_dll, sizeof(imagehlp_dll));
293     strncat_s(imagehlp_dll, sizeof(imagehlp_dll), "\\imagehlp.dll", _TRUNCATE);
294     h2 = LoadLibrary(imagehlp_dll);
295     if (((h = GetModuleHandle(imagehlp_dll)) == NULL) ||
296 maya 3227 (GetProcAddress(h, "SymGetLineFromAddr") == NULL)) {
297     FreeLibrary(h2);
298     goto error;
299     }
300     FreeLibrary(h2);
301    
302     /* �V���{�������i�[�p�o�b�t�@�������� */
303     gptr = GlobalAlloc(GMEM_FIXED, 10000);
304 maya 3392 if (gptr == NULL) {
305 maya 3227 goto error;
306 maya 3392 }
307 maya 3227 pSym = (PIMAGEHLP_SYMBOL)GlobalLock(gptr);
308     ZeroMemory(pSym, sizeof(IMAGEHLP_SYMBOL));
309     pSym->SizeOfStruct = 10000;
310     pSym->MaxNameLength = 10000 - sizeof(IMAGEHLP_SYMBOL);
311    
312     /* �X�^�b�N�t���[���������� */
313     ZeroMemory(&sf, sizeof(sf));
314     sf.AddrPC.Offset = ExInfo->ContextRecord->Eip;
315     sf.AddrStack.Offset = ExInfo->ContextRecord->Esp;
316     sf.AddrFrame.Offset = ExInfo->ContextRecord->Ebp;
317     sf.AddrPC.Mode = AddrModeFlat;
318     sf.AddrStack.Mode = AddrModeFlat;
319     sf.AddrFrame.Mode = AddrModeFlat;
320    
321     /* �V���{���n���h���������� */
322     SymInitialize(hProcess, NULL, TRUE);
323 doda 6435
324 maya 3227 // ���W�X�^�_���v
325     msg[0] = '\0';
326     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "eax=%08X ebx=%08X ecx=%08X edx=%08X esi=%08X edi=%08X\r\n"
327     "ebp=%08X esp=%08X eip=%08X efl=%08X\r\n"
328     "cs=%04X ss=%04X ds=%04X es=%04X fs=%04X gs=%04X\r\n",
329 doda 6435 ExInfo->ContextRecord->Eax,
330     ExInfo->ContextRecord->Ebx,
331     ExInfo->ContextRecord->Ecx,
332     ExInfo->ContextRecord->Edx,
333     ExInfo->ContextRecord->Esi,
334     ExInfo->ContextRecord->Edi,
335     ExInfo->ContextRecord->Ebp,
336     ExInfo->ContextRecord->Esp,
337 maya 3227 ExInfo->ContextRecord->Eip,
338     ExInfo->ContextRecord->EFlags,
339     ExInfo->ContextRecord->SegCs,
340     ExInfo->ContextRecord->SegSs,
341     ExInfo->ContextRecord->SegDs,
342     ExInfo->ContextRecord->SegEs,
343     ExInfo->ContextRecord->SegFs,
344     ExInfo->ContextRecord->SegGs
345     );
346     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
347    
348     if (ExInfo->ExceptionRecord != NULL) {
349     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "Exception: %s\r\n", GetExceptionString(ExInfo->ExceptionRecord->ExceptionCode));
350     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
351     }
352    
353     /* �X�^�b�N�t���[���������\���������� */
354     frame = 0;
355     for (;;) {
356     /* �����X�^�b�N�t���[�������� */
357     bResult = StackWalk(
358     IMAGE_FILE_MACHINE_I386,
359     hProcess,
360     hThread,
361     &sf,
362     NULL,
363 doda 6435 NULL,
364 maya 3227 SymFunctionTableAccess,
365     SymGetModuleBase,
366     NULL);
367    
368     /* ���s�������A���[�v�������� */
369 doda 6435 if (!bResult || sf.AddrFrame.Offset == 0)
370 maya 3227 break;
371 doda 6435
372 maya 3227 frame++;
373    
374     /* �v���O�����J�E���^�i���z�A�h���X�j�������������I�t�Z�b�g������ */
375     bResult = SymGetSymFromAddr(hProcess, sf.AddrPC.Offset, &Disp, pSym);
376 doda 6435
377 maya 3227 /* �����������\�� */
378     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "#%d 0x%08x in ", frame, sf.AddrPC.Offset);
379     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
380     if (bResult) {
381     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%s() + 0x%x ", pSym->Name, Disp);
382     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
383     } else {
384     _snprintf_s(buf, sizeof(buf), _TRUNCATE, " --- ");
385     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
386     }
387 doda 6435
388 maya 3227 // ���s�t�@�C����������
389     ZeroMemory( &(ih_module), sizeof(ih_module) );
390     ih_module.SizeOfStruct = sizeof(ih_module);
391     bResult = SymGetModuleInfo( hProcess, sf.AddrPC.Offset, &(ih_module) );
392     strncat_s(msg, sizeof(msg), "at ", _TRUNCATE);
393     if (bResult) {
394     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%s ", ih_module.ImageName );
395     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
396     } else {
397     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%s ", "<Unknown Module>" );
398     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
399     }
400 doda 6435
401 maya 3227 // �t�@�C�������s����������
402     ZeroMemory( &(ih_line), sizeof(ih_line) );
403     ih_line.SizeOfStruct = sizeof(ih_line);
404     bResult = SymGetLineFromAddr( hProcess, sf.AddrPC.Offset, &Disp, &ih_line );
405     if (bResult)
406     {
407     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%s:%lu", ih_line.FileName, ih_line.LineNumber );
408     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
409     }
410 doda 6435
411 maya 3352 strncat_s(msg, sizeof(msg), "\n", _TRUNCATE);
412 maya 3227 }
413    
414     /* ������ */
415     SymCleanup(hProcess);
416     GlobalUnlock(pSym);
417     GlobalFree(pSym);
418    
419 zmatsuo 8487 // ���O�������������AAPI�����������o��
420     ::MessageBoxA(NULL, msg, "Tera Term: Application fault", MB_OK | MB_ICONEXCLAMATION);
421 maya 3227
422     error:
423     // return (EXCEPTION_EXECUTE_HANDLER); /* ���������v���Z�X���I�������� */
424     return (EXCEPTION_CONTINUE_SEARCH); /* ���������m�A�v���P�[�V�����G���[�n�|�b�v�A�b�v���b�Z�[�W�{�b�N�X�������o�� */
425     }
426 zmatsuo 7896 #endif // !defined(_M_X64 )
427 maya 3227
428    
429 yutakapon 6130 // Virtual Store���L���������������������������B
430     //
431     // [Windows 95-XP]
432     // return FALSE (always)
433     //
434     // [Windows Vista-10]
435     // return TRUE: Virtual Store Enabled
436     // FALSE: Virtual Store Disabled or Unknown
437     //
438     BOOL GetVirtualStoreEnvironment(void)
439     {
440 yutakapon 6131 #if _MSC_VER == 1400 // VSC2005(VC8.0)
441     typedef struct _TOKEN_ELEVATION {
442     DWORD TokenIsElevated;
443     } TOKEN_ELEVATION, *PTOKEN_ELEVATION;
444     int TokenElevation = 20;
445     #endif
446 yutakapon 6130 BOOL ret = FALSE;
447     int flag = 0;
448     HANDLE hToken;
449     DWORD dwLength;
450     TOKEN_ELEVATION tokenElevation;
451     LONG lRet;
452     HKEY hKey;
453 zmatsuo 8489 char lpData[256];
454 yutakapon 6130 DWORD dwDataSize;
455     DWORD dwType;
456     BYTE bValue;
457    
458     // Windows Vista���O�����������B
459 yutakapon 6286 if (!IsWindowsVistaOrLater())
460 yutakapon 6130 goto error;
461    
462     // UAC���L�����������B
463     // HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System��EnableLUA(DWORD�l)��0�������������f��������(0��UAC�����A1��UAC�L��)�B
464     flag = 0;
465     lRet = RegOpenKeyEx(HKEY_LOCAL_MACHINE,
466     TEXT("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Policies\\System"),
467     NULL, KEY_QUERY_VALUE, &hKey
468     );
469     if (lRet == ERROR_SUCCESS) {
470     dwDataSize = sizeof(lpData) / sizeof(lpData[0]);
471     lRet = RegQueryValueEx(
472     hKey,
473     TEXT("EnableLUA"),
474     0,
475     &dwType,
476     (LPBYTE)lpData,
477     &dwDataSize);
478     if (lRet == ERROR_SUCCESS) {
479     bValue = ((LPBYTE)lpData)[0];
480     if (bValue == 1)
481     // UAC���L���������AVirtual Store�������B
482     flag = 1;
483     }
484     RegCloseKey(hKey);
485     }
486     if (flag == 0)
487     goto error;
488    
489     // UAC���L�����A�v���Z�X�����������������i�����������B
490     flag = 0;
491     if (OpenProcessToken(GetCurrentProcess(), TOKEN_QUERY | TOKEN_ADJUST_DEFAULT, &hToken)) {
492     if (GetTokenInformation(hToken, (TOKEN_INFORMATION_CLASS)TokenElevation, &tokenElevation, sizeof(TOKEN_ELEVATION), &dwLength)) {
493     // (0�����i�����������A��0�����i��������)�B
494     if (tokenElevation.TokenIsElevated == 0) {
495     // �����������������������������AVirtual Store�������B
496     flag = 1;
497     }
498     }
499     CloseHandle(hToken);
500     }
501     if (flag == 0)
502     goto error;
503    
504     ret = TRUE;
505     return (ret);
506    
507     error:
508     return (ret);
509     }
510    
511 doda 6782 /////////////////////////////////////////////////////////////////////////////
512     // CVTWindow constructor
513    
514 zmatsuo 7916 CVTWindow::CVTWindow(HINSTANCE hInstance)
515 maya 3227 {
516 zmatsuo 8519 WNDCLASSW wc;
517 maya 3227 RECT rect;
518     DWORD Style;
519     char *Param;
520     int CmdShow;
521 maya 5784 #ifdef SHARED_KEYMAP
522     char Temp[MAX_PATH];
523 maya 3227 PKeyMap tempkm;
524 maya 5784 #endif
525 maya 3227 int fuLoad = LR_DEFAULTCOLOR;
526 doda 6790 BOOL isFirstInstance;
527 zmatsuo 7916 m_hInst = hInstance;
528 maya 3227
529 maya 3392 // ���O�n���h�����t�b�N (2007.9.30 yutaka)
530 zmatsuo 7896 #if !defined(_M_X64)
531 maya 3227 SetUnhandledExceptionFilter(ApplicationFaultHandler);
532 zmatsuo 7896 #endif
533 maya 3227
534 doda 6790 CommInit(&cv);
535     isFirstInstance = StartTeraTerm(&ts);
536    
537 maya 3227 TTXInit(&ts, &cv); /* TTPLUG */
538    
539     MsgDlgHelp = RegisterWindowMessage(HELPMSGSTRING);
540    
541 doda 6790 if (isFirstInstance) {
542 maya 3227 /* first instance */
543     if (LoadTTSET()) {
544     /* read setup info from "teraterm.ini" */
545     (*ReadIniFile)(ts.SetupFName, &ts);
546 maya 5784 #ifdef SHARED_KEYMAP
547 maya 3227 /* read keycode map from "keyboard.cnf" */
548     tempkm = (PKeyMap)malloc(sizeof(TKeyMap));
549     if (tempkm!=NULL) {
550     strncpy_s(Temp, sizeof(Temp), ts.HomeDir, _TRUNCATE);
551     AppendSlash(Temp,sizeof(Temp));
552     strncat_s(Temp,sizeof(Temp),"KEYBOARD.CNF",_TRUNCATE);
553     (*ReadKeyboardCnf)(Temp,tempkm,TRUE);
554     }
555 maya 5784 #endif
556 maya 3227 FreeTTSET();
557 maya 5784 #ifdef SHARED_KEYMAP
558 maya 3227 /* store default sets in TTCMN */
559     #if 0
560     ChangeDefaultSet(&ts,tempkm);
561     #else
562     ChangeDefaultSet(NULL,tempkm);
563     #endif
564     if (tempkm!=NULL) free(tempkm);
565 maya 5784 #endif
566 maya 3227 }
567 doda 6783 else {
568     abort();
569     }
570 maya 3227
571     } else {
572     // 2�������~���v���Z�X�����������A�f�B�X�N���� TERATERM.INI �������B(2004.11.4 yutaka)
573     if (LoadTTSET()) {
574     /* read setup info from "teraterm.ini" */
575     (*ReadIniFile)(ts.SetupFName, &ts);
576 maya 5784 #ifdef SHARED_KEYMAP
577 maya 3227 /* read keycode map from "keyboard.cnf" */
578     tempkm = (PKeyMap)malloc(sizeof(TKeyMap));
579     if (tempkm!=NULL) {
580 doda 5345 strncpy_s(Temp, sizeof(Temp), ts.HomeDir, _TRUNCATE);
581 maya 3227 AppendSlash(Temp,sizeof(Temp));
582     strncat_s(Temp,sizeof(Temp),"KEYBOARD.CNF",_TRUNCATE);
583     (*ReadKeyboardCnf)(Temp,tempkm,TRUE);
584     }
585 maya 5784 #endif
586 maya 3227 FreeTTSET();
587 maya 5784 #ifdef SHARED_KEYMAP
588 maya 3227 /* store default sets in TTCMN */
589 maya 3392 if (tempkm!=NULL) {
590     free(tempkm);
591     }
592 maya 5784 #endif
593 maya 3227 }
594 doda 6783 else {
595     abort();
596     }
597 maya 3227 }
598    
599     /* Parse command line parameters*/
600     // 256�o�C�g�������R�}���h���C���p�����[�^�w�����������ABOF(Buffer Over Flow)��
601     // �������o�O���C���B(2007.6.12 maya)
602     Param = GetCommandLine();
603 maya 3392 if (LoadTTSET()) {
604 maya 3227 (*ParseParam)(Param, &ts, &(TopicName[0]));
605 maya 3392 }
606 maya 3227 FreeTTSET();
607    
608 zmatsuo 7594 // DPI Aware (��DPI����)
609 zmatsuo 7715 if (pIsValidDpiAwarenessContext != NULL && pSetThreadDpiAwarenessContext != NULL) {
610     char Temp[4];
611     GetPrivateProfileString("Tera Term", "DPIAware", NULL, Temp, sizeof(Temp), ts.SetupFName);
612     if (_stricmp(Temp, "on") == 0) {
613     if (pIsValidDpiAwarenessContext(DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE_V2) == TRUE) {
614 zmatsuo 7594 pSetThreadDpiAwarenessContext(DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE_V2);
615     }
616     }
617     }
618    
619 maya 3227 // duplicate session���w�������������A���L�����������R�s�[���� (2004.12.7 yutaka)
620     if (ts.DuplicateSession == 1) {
621     CopyShmemToTTSet(&ts);
622     }
623    
624     InitKeyboard();
625     SetKeyMap();
626    
627     /* window status */
628     AdjustSize = TRUE;
629     Minimized = FALSE;
630     LButton = FALSE;
631     MButton = FALSE;
632     RButton = FALSE;
633     DblClk = FALSE;
634     AfterDblClk = FALSE;
635     TplClk = FALSE;
636     Hold = FALSE;
637     FirstPaint = TRUE;
638     ScrollLock = FALSE; // �����l������ (2006.11.14 yutaka)
639 zmatsuo 7390 Alpha = 255;
640 zmatsuo 7717 IgnoreSizeMessage = FALSE;
641 doda 8445 #if UNICODE_DEBUG
642     TipWinCodeDebug = NULL;
643     #endif
644 maya 3227
645     /* Initialize scroll buffer */
646     InitBuffer();
647    
648     InitDisp();
649    
650     if (ts.HideTitle>0) {
651     Style = WS_VSCROLL | WS_HSCROLL |
652     WS_BORDER | WS_THICKFRAME | WS_POPUP;
653    
654     #ifdef ALPHABLEND_TYPE2
655     if(BGNoFrame)
656     Style &= ~(WS_BORDER | WS_THICKFRAME);
657     #endif
658     }
659     else
660     #ifdef WINDOW_MAXMIMUM_ENABLED
661     Style = WS_VSCROLL | WS_HSCROLL |
662     WS_BORDER | WS_THICKFRAME |
663     WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX | WS_MAXIMIZEBOX;
664     #else
665     Style = WS_VSCROLL | WS_HSCROLL |
666     WS_BORDER | WS_THICKFRAME |
667     WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX;
668     #endif
669    
670     wc.style = CS_DBLCLKS | CS_HREDRAW | CS_VREDRAW;
671 zmatsuo 7528 wc.lpfnWndProc = (WNDPROC)ProcStub;
672 maya 3227 wc.cbClsExtra = 0;
673     wc.cbWndExtra = 0;
674 zmatsuo 7916 wc.hInstance = hInstance;
675 maya 3227 wc.hIcon = NULL;
676     //wc.hCursor = LoadCursor(NULL,IDC_IBEAM);
677     wc.hCursor = NULL; // �}�E�X�J�[�\�������I�����X���� (2005.4.2 yutaka)
678     wc.hbrBackground = NULL;
679     wc.lpszMenuName = NULL;
680     wc.lpszClassName = VTClassName;
681    
682 zmatsuo 8519 _RegisterClassW(&wc);
683 zmatsuo 7916 m_hAccel = ::LoadAccelerators(hInstance, MAKEINTRESOURCE(IDR_ACC));
684 maya 3227
685 maya 3392 if (ts.VTPos.x==CW_USEDEFAULT) {
686 maya 3227 rect = rectDefault;
687 maya 3392 }
688 maya 3227 else {
689     rect.left = ts.VTPos.x;
690     rect.top = ts.VTPos.y;
691     rect.right = rect.left + 100;
692     rect.bottom = rect.top + 100;
693     }
694 zmatsuo 8519 CreateW(hInstance, VTClassName, L"Tera Term", Style, rect, NULL, NULL);
695 maya 3227
696     /*--------- Init2 -----------------*/
697     HVTWin = GetSafeHwnd();
698     if (HVTWin == NULL) return;
699     // register this window to the window list
700     SerialNo = RegWin(HVTWin,NULL);
701    
702     logfile_lock_initialize();
703 zmatsuo 7390 SetMouseCursor(ts.MouseCursorName);
704 maya 3227 // ���P�[��������
705     // wctomb ������
706     setlocale(LC_ALL, ts.Locale);
707    
708     #ifdef ALPHABLEND_TYPE2
709     //<!--by AKASI
710     if(BGNoFrame && ts.HideTitle > 0) {
711 doda 8445 DWORD ExStyle = (DWORD)::GetWindowLongPtr(HVTWin,GWL_EXSTYLE);
712 maya 3227 ExStyle &= ~WS_EX_CLIENTEDGE;
713 zmatsuo 7528 ::SetWindowLongPtr(HVTWin,GWL_EXSTYLE,ExStyle);
714 maya 3227 }
715     //-->
716     #endif
717    
718 salarm 6100 // USB�f�o�C�X�������m�o�^
719     RegDeviceNotify(HVTWin);
720    
721 yutakapon 6286 if (IsWindowsNT4()) {
722 maya 3227 fuLoad = LR_VGACOLOR;
723     }
724     ::PostMessage(HVTWin,WM_SETICON,ICON_SMALL,
725 zmatsuo 7916 (LPARAM)LoadImage(hInstance,
726 maya 3227 MAKEINTRESOURCE((ts.VTIcon!=IdIconDefault)?ts.VTIcon:IDI_VT),
727     IMAGE_ICON,16,16,fuLoad));
728     // Vista �� Aero �������� Alt+Tab �����������\���������A�C�R����
729     // 16x16 �A�C�R�����g���������������������A�������A�C�R����
730     // �Z�b�g���� (2008.9.3 maya)
731     ::PostMessage(HVTWin,WM_SETICON,ICON_BIG,
732 zmatsuo 7916 (LPARAM)LoadImage(hInstance,
733 maya 3227 MAKEINTRESOURCE((ts.VTIcon!=IdIconDefault)?ts.VTIcon:IDI_VT),
734     IMAGE_ICON, 0, 0, fuLoad));
735    
736 doda 6690 SetCustomNotifyIcon(
737     (HICON)LoadImage(
738 zmatsuo 7916 hInstance,
739 doda 6690 MAKEINTRESOURCE((ts.VTIcon!=IdIconDefault)?ts.VTIcon:IDI_VT),
740     IMAGE_ICON, 16, 16, LR_VGACOLOR|LR_SHARED));
741    
742 maya 3227 MainMenu = NULL;
743     WinMenu = NULL;
744     if ((ts.HideTitle==0) && (ts.PopupMenu==0)) {
745     InitMenu(&MainMenu);
746     ::SetMenu(HVTWin,MainMenu);
747     }
748    
749     /* Reset Terminal */
750     ResetTerminal();
751    
752 maya 3392 if ((ts.PopupMenu>0) || (ts.HideTitle>0)) {
753 maya 3227 ::PostMessage(HVTWin,WM_USER_CHANGEMENU,0,0);
754 maya 3392 }
755 maya 3227
756     ChangeFont();
757    
758     ResetIME();
759    
760     BuffChangeWinSize(NumOfColumns,NumOfLines);
761    
762     ChangeTitle();
763     /* Enable drag-drop */
764     ::DragAcceptFiles(HVTWin,TRUE);
765    
766     if (ts.HideWindow>0) {
767     if (strlen(TopicName)>0) {
768     InitDDE();
769     SendDDEReady();
770     }
771     FirstPaint = FALSE;
772     Startup();
773     return;
774     }
775 maya 3392 CmdShow = SW_SHOWDEFAULT;
776     if (ts.Minimize>0) {
777 maya 3227 CmdShow = SW_SHOWMINIMIZED;
778 maya 3392 }
779 zmatsuo 7390 SetWindowAlpha(ts.AlphaBlendActive);
780 maya 3227 ShowWindow(CmdShow);
781     ChangeCaret();
782 yutakapon 6130
783     // Tera Term���N�����AVirtual Store�����������������o���������B
784     // (2015.11.14 yutaka)
785     cv.VirtualStoreEnabled = GetVirtualStoreEnvironment();
786 zmatsuo 7148
787     DropLists = NULL;
788     DropListCount = 0;
789 yasuhide 8143
790 doda 8445 #if UNICODE_DEBUG
791     CtrlKeyState = 0;
792     #endif
793    
794 yasuhide 8143 // TipWin
795 yasuhide 8268 TipWin = new CTipWin(hInstance);
796     TipWin->Create(HVTWin);
797 maya 3227 }
798    
799     /////////////////////////////////////////////////////////////////////////////
800 yasuhide 8268 // CVTWindow destructor
801 maya 3227
802 yasuhide 8268 CVTWindow::~CVTWindow()
803     {
804     TipWin->Destroy();
805     delete TipWin;
806     TipWin = NULL;
807     }
808    
809     /////////////////////////////////////////////////////////////////////////////
810    
811 maya 3227 int CVTWindow::Parse()
812     {
813     // added ScrollLock (2006.11.14 yutaka)
814     if (LButton || MButton || RButton || ScrollLock)
815     return 0;
816     return (VTParse()); // Parse received characters
817     }
818    
819     void CVTWindow::ButtonUp(BOOL Paste)
820     {
821     BOOL disableBuffEndSelect = false;
822    
823     /* disable autoscrolling */
824     ::KillTimer(HVTWin,IdScrollTimer);
825     ReleaseCapture();
826    
827     if (ts.SelectOnlyByLButton &&
828     (MButton || RButton)) {
829     disableBuffEndSelect = true;
830     }
831    
832     LButton = FALSE;
833     MButton = FALSE;
834     RButton = FALSE;
835     DblClk = FALSE;
836     TplClk = FALSE;
837     CaretOn();
838    
839     // SelectOnlyByLButton �� on �� ���E�E�N���b�N����������
840     // �o�b�t�@���I���������������A�I�����e���N���b�v�{�[�h��
841     // �R�s�[�������������������C�� (2007.12.6 maya)
842     if (!disableBuffEndSelect) {
843     BuffEndSelect();
844     }
845    
846 doda 6415 if (Paste) {
847 doda 6456 CBStartPaste(HVTWin, FALSE, BracketedPasteMode());
848 doda 8445
849 doda 6456 // �X�N���[�����u�����Z�b�g
850     if (WinOrgY != 0) {
851     DispVScroll(SCROLL_BOTTOM, 0);
852 maya 3227 }
853     }
854     }
855    
856     void CVTWindow::ButtonDown(POINT p, int LMR)
857     {
858     HMENU PopupMenu, PopupBase;
859     BOOL mousereport;
860    
861     if ((LMR==IdLeftButton) && ControlKey() && (MainMenu==NULL) &&
862     ((ts.MenuFlag & MF_NOPOPUP)==0)) {
863     int i, numItems;
864     char itemText[256];
865    
866     InitMenu(&PopupMenu);
867    
868     PopupBase = CreatePopupMenu();
869     numItems = GetMenuItemCount(PopupMenu);
870    
871     for (i = 0; i < numItems; i++) {
872     HMENU submenu = GetSubMenu(PopupMenu, i);
873    
874     if (submenu != NULL) {
875     InitMenuPopup(submenu);
876     }
877    
878     if (GetMenuString(PopupMenu, i, itemText, sizeof(itemText), MF_BYPOSITION) != 0) {
879     int state = GetMenuState(PopupMenu, i, MF_BYPOSITION) &
880     (MF_CHECKED | MF_DISABLED | MF_GRAYED | MF_HILITE |
881     MF_MENUBARBREAK | MF_MENUBREAK | MF_SEPARATOR);
882    
883     AppendMenu(PopupBase,
884     submenu != NULL ? LOBYTE(state) | MF_POPUP : state,
885 zmatsuo 7896 submenu != NULL ? (UINT_PTR)submenu : GetMenuItemID(PopupMenu, i),
886 maya 3227 itemText);
887     }
888     }
889    
890     ::ClientToScreen(HVTWin, &p);
891     TrackPopupMenu(PopupBase,TPM_LEFTALIGN | TPM_LEFTBUTTON,
892     p.x,p.y,0,HVTWin,NULL);
893     if (WinMenu!=NULL) {
894     DestroyMenu(WinMenu);
895     WinMenu = NULL;
896     }
897     DestroyMenu(PopupBase);
898     DestroyMenu(PopupMenu);
899     PopupMenu = 0;
900     return;
901     }
902    
903 zmatsuo 7528 mousereport = MouseReport(IdMouseEventBtnDown, LMR, p.x, p.y);
904     if (mousereport) {
905     ::SetCapture(m_hWnd);
906 doda 3987 return;
907     }
908 maya 3227
909     // added ConfirmPasteMouseRButton (2007.3.17 maya)
910     if ((LMR == IdRightButton) &&
911 doda 6594 (ts.PasteFlag & CPF_DISABLE_RBUTTON) == 0 &&
912     (ts.PasteFlag & CPF_CONFIRM_RBUTTON) != 0 &&
913 maya 3227 cv.Ready &&
914     !mousereport &&
915     (SendVar==NULL) && (FileVar==NULL) &&
916     (cv.PortType!=IdFile) &&
917     (IsClipboardFormatAvailable(CF_TEXT) ||
918     IsClipboardFormatAvailable(CF_OEMTEXT))) {
919    
920     int i, numItems;
921     char itemText[256];
922    
923     InitPasteMenu(&PopupMenu);
924     PopupBase = CreatePopupMenu();
925     numItems = GetMenuItemCount(PopupMenu);
926    
927     for (i = 0; i < numItems; i++) {
928     if (GetMenuString(PopupMenu, i, itemText, sizeof(itemText), MF_BYPOSITION) != 0) {
929     int state = GetMenuState(PopupMenu, i, MF_BYPOSITION) &
930     (MF_CHECKED | MF_DISABLED | MF_GRAYED | MF_HILITE |
931     MF_MENUBARBREAK | MF_MENUBREAK | MF_SEPARATOR);
932    
933     AppendMenu(PopupBase, state,
934     GetMenuItemID(PopupMenu, i), itemText);
935     }
936     }
937    
938     ::ClientToScreen(HVTWin, &p);
939     TrackPopupMenu(PopupBase,TPM_LEFTALIGN | TPM_LEFTBUTTON,
940     p.x,p.y,0,HVTWin,NULL);
941     if (WinMenu!=NULL) {
942     DestroyMenu(WinMenu);
943     WinMenu = NULL;
944     }
945     DestroyMenu(PopupBase);
946     DestroyMenu(PopupMenu);
947     PopupMenu = 0;
948     return;
949     }
950    
951     if (AfterDblClk && (LMR==IdLeftButton) &&
952     (abs(p.x-DblClkX)<=GetSystemMetrics(SM_CXDOUBLECLK)) &&
953     (abs(p.y-DblClkY)<=GetSystemMetrics(SM_CYDOUBLECLK))) {
954     /* triple click */
955     ::KillTimer(HVTWin, IdDblClkTimer);
956     AfterDblClk = FALSE;
957     BuffTplClk(p.y);
958     LButton = TRUE;
959     TplClk = TRUE;
960     /* for AutoScrolling */
961     ::SetCapture(HVTWin);
962     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
963     }
964     else {
965     if (! (LButton || MButton || RButton)) {
966     BOOL box = FALSE;
967    
968     // select several pages of output from Tera Term window (2005.5.15 yutaka)
969     if (LMR == IdLeftButton && ShiftKey()) {
970     BuffSeveralPagesSelect(p.x, p.y);
971    
972     } else {
973     // Select rectangular block with Alt Key. Delete Shift key.(2005.5.15 yutaka)
974     if (LMR == IdLeftButton && AltKey()) {
975     box = TRUE;
976     }
977    
978     // Starting the selection only by a left button.(2007.11.20 maya)
979     if (!ts.SelectOnlyByLButton ||
980     (ts.SelectOnlyByLButton && LMR == IdLeftButton) ) {
981     BuffStartSelect(p.x,p.y, box);
982     TplClk = FALSE;
983    
984     /* for AutoScrolling */
985     ::SetCapture(HVTWin);
986     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
987     }
988     }
989     }
990    
991     switch (LMR) {
992     case IdRightButton:
993     RButton = TRUE;
994     break;
995     case IdMiddleButton:
996     MButton = TRUE;
997     break;
998     case IdLeftButton:
999     LButton = TRUE;
1000     break;
1001     }
1002     }
1003     }
1004    
1005     // LogMeIn.exe -> LogMeTT.exe �����l�[�� (2005.2.21 yutaka)
1006     static char LogMeTTMenuString[] = "Log&MeTT";
1007 yutakapon 3648 static char LogMeTT[MAX_PATH];
1008    
1009 doda 8395 #define IS_LOGMETT_NOTFOUND 0
1010     #define IS_LOGMETT_FOUND 1
1011     #define IS_LOGMETT_UNKNOWN 2
1012    
1013 maya 3227 static BOOL isLogMeTTExist()
1014     {
1015 yutakapon 3648 const char *LogMeTTexename = "LogMeTT.exe";
1016     LONG result;
1017     HKEY key;
1018     int inregist = 0;
1019     DWORD dwSize;
1020     DWORD dwType;
1021     DWORD dwDisposition;
1022     char *path;
1023 maya 3227
1024 doda 8395 static int status = IS_LOGMETT_UNKNOWN;
1025    
1026     if (status != IS_LOGMETT_UNKNOWN) {
1027     return status == IS_LOGMETT_FOUND;
1028     }
1029    
1030 yutakapon 3648 /* LogMeTT 2.9.6���������W�X�g�����C���X�g�[���p�X�����������B*/
1031     result = RegCreateKeyEx(HKEY_CURRENT_USER, "Software\\LogMeTT", 0, NULL,
1032     REG_OPTION_NON_VOLATILE, KEY_READ, NULL, &key, &dwDisposition);
1033     if (result == ERROR_SUCCESS) {
1034     result = RegQueryValueEx(key, "InstallPath", NULL, &dwType, NULL, &dwSize);
1035     if (result == ERROR_SUCCESS) {
1036     path = (char *)malloc(dwSize);
1037     if (path != NULL) {
1038     result = RegQueryValueEx(key, "InstallPath", NULL, &dwType, (LPBYTE)path, &dwSize);
1039     if (result == ERROR_SUCCESS) {
1040     inregist = 1;
1041     strncpy_s(LogMeTT, sizeof(LogMeTT), path, _TRUNCATE);
1042     }
1043     free(path);
1044     }
1045     }
1046 yutakapon 3649 RegCloseKey(key);
1047 yutakapon 3648 }
1048    
1049     if (inregist == 0) {
1050     strncpy_s(LogMeTT, sizeof(LogMeTT), ts.HomeDir, _TRUNCATE);
1051     AppendSlash(LogMeTT, sizeof(LogMeTT));
1052     strncat_s(LogMeTT, sizeof(LogMeTT), LogMeTTexename, _TRUNCATE);
1053     }
1054    
1055 maya 3227 if (_access(LogMeTT, 0) == -1) {
1056 doda 8395 status = IS_LOGMETT_NOTFOUND;
1057 maya 3227 return FALSE;
1058     }
1059 doda 8395 status = IS_LOGMETT_FOUND;
1060 maya 3227 return TRUE;
1061     }
1062    
1063     void CVTWindow::InitMenu(HMENU *Menu)
1064     {
1065 doda 8445 static const DlgTextInfo MenuTextInfo[] = {
1066     { ID_FILE, "MENU_FILE" },
1067     { ID_EDIT, "MENU_EDIT" },
1068     { ID_SETUP, "MENU_SETUP" },
1069     { ID_CONTROL, "MENU_CONTROL" },
1070     { ID_HELPMENU, "MENU_HELP" },
1071     };
1072     static const DlgTextInfo FileMenuTextInfo[] = {
1073     { ID_FILE_NEWCONNECTION, "MENU_FILE_NEW" },
1074     { ID_FILE_DUPLICATESESSION, "MENU_FILE_DUPLICATE" },
1075     { ID_FILE_CYGWINCONNECTION, "MENU_FILE_GYGWIN" },
1076     { ID_FILE_LOG, "MENU_FILE_LOG" },
1077     { ID_FILE_COMMENTTOLOG, "MENU_FILE_COMMENTLOG" },
1078     { ID_FILE_VIEWLOG, "MENU_FILE_VIEWLOG" },
1079     { ID_FILE_SHOWLOGDIALOG, "MENU_FILE_SHOWLOGDIALOG" },
1080     { ID_FILE_PAUSELOG, "MENU_FILE_PAUSELOG" },
1081     { ID_FILE_STOPLOG, "MENU_FILE_STOPLOG" },
1082     { ID_FILE_SENDFILE, "MENU_FILE_SENDFILE" },
1083     { ID_FILE_REPLAYLOG, "MENU_FILE_REPLAYLOG" },
1084     { ID_FILE_CHANGEDIR, "MENU_FILE_CHANGEDIR" },
1085     { ID_FILE_LOGMEIN, "MENU_FILE_LOGMETT" },
1086     { ID_FILE_PRINT2, "MENU_FILE_PRINT" },
1087     { ID_FILE_DISCONNECT, "MENU_FILE_DISCONNECT" },
1088     { ID_FILE_EXIT, "MENU_FILE_EXIT" },
1089     { ID_FILE_EXITALL, "MENU_FILE_EXITALL" },
1090     { 11, "MENU_TRANS" },
1091     { ID_FILE_KERMITRCV, "MENU_TRANS_KERMIT_RCV" },
1092     { ID_FILE_KERMITGET, "MENU_TRANS_KERMIT_GET" },
1093     { ID_FILE_KERMITSEND, "MENU_TRANS_KERMIT_SEND" },
1094     { ID_FILE_KERMITFINISH, "MENU_TRANS_KERMIT_FINISH" },
1095     { ID_FILE_XRCV, "MENU_TRANS_X_RCV" },
1096     { ID_FILE_XSEND, "MENU_TRANS_X_SEND" },
1097     { ID_FILE_YRCV, "MENU_TRANS_Y_RCV" },
1098     { ID_FILE_YSEND, "MENU_TRANS_Y_SEND" },
1099     { ID_FILE_ZRCV, "MENU_TRANS_Z_RCV" },
1100     { ID_FILE_ZSEND, "MENU_TRANS_Z_SEND" },
1101     { ID_FILE_BPRCV, "MENU_TRANS_BP_RCV" },
1102     { ID_FILE_BPSEND, "MENU_TRANS_BP_SEND" },
1103     { ID_FILE_QVRCV, "MENU_TRANS_QV_RCV" },
1104     { ID_FILE_QVSEND, "MENU_TRANS_QV_SEND" },
1105     };
1106     static const DlgTextInfo EditMenuTextInfo[] = {
1107     { ID_EDIT_COPY2, "MENU_EDIT_COPY" },
1108     { ID_EDIT_COPYTABLE, "MENU_EDIT_COPYTABLE" },
1109     { ID_EDIT_PASTE2, "MENU_EDIT_PASTE" },
1110     { ID_EDIT_PASTECR, "MENU_EDIT_PASTECR" },
1111     { ID_EDIT_CLEARSCREEN, "MENU_EDIT_CLSCREEN" },
1112     { ID_EDIT_CLEARBUFFER, "MENU_EDIT_CLBUFFER" },
1113     { ID_EDIT_CANCELSELECT, "MENU_EDIT_CANCELSELECT" },
1114     { ID_EDIT_SELECTSCREEN, "MENU_EDIT_SELECTSCREEN" },
1115     { ID_EDIT_SELECTALL, "MENU_EDIT_SELECTALL" },
1116     };
1117     static const DlgTextInfo SetupMenuTextInfo[] = {
1118     { ID_SETUP_TERMINAL, "MENU_SETUP_TERMINAL" },
1119     { ID_SETUP_WINDOW, "MENU_SETUP_WINDOW" },
1120     { ID_SETUP_FONT, "MENU_SETUP_FONT" },
1121     { ID_SETUP_DLG_FONT, "MENU_SETUP_DIALOG_FONT" },
1122     { 2, "MENU_SETUP_FONT_SUBMENU" },
1123     { ID_SETUP_KEYBOARD, "MENU_SETUP_KEYBOARD" },
1124     { ID_SETUP_SERIALPORT, "MENU_SETUP_SERIALPORT" },
1125     { ID_SETUP_TCPIP, "MENU_SETUP_TCPIP" },
1126     { ID_SETUP_GENERAL, "MENU_SETUP_GENERAL" },
1127     { ID_SETUP_ADDITIONALSETTINGS, "MENU_SETUP_ADDITION" },
1128     { ID_SETUP_SAVE, "MENU_SETUP_SAVE" },
1129     { ID_SETUP_RESTORE, "MENU_SETUP_RESTORE" },
1130     { ID_OPEN_SETUP, "MENU_SETUP_OPENSETUP" },
1131     { ID_SETUP_LOADKEYMAP, "MENU_SETUP_LOADKEYMAP" },
1132     };
1133     static const DlgTextInfo ControlMenuTextInfo[] = {
1134     { ID_CONTROL_RESETTERMINAL, "MENU_CONTROL_RESET" },
1135     { ID_CONTROL_RESETREMOTETITLE, "MENU_CONTROL_RESETTITLE" },
1136     { ID_CONTROL_AREYOUTHERE, "MENU_CONTROL_AREYOUTHERE" },
1137     { ID_CONTROL_SENDBREAK, "MENU_CONTROL_SENDBREAK" },
1138     { ID_CONTROL_RESETPORT, "MENU_CONTROL_RESETPORT" },
1139     { ID_CONTROL_BROADCASTCOMMAND, "MENU_CONTROL_BROADCAST" },
1140     { ID_CONTROL_OPENTEK, "MENU_CONTROL_OPENTEK" },
1141     { ID_CONTROL_CLOSETEK, "MENU_CONTROL_CLOSETEK" },
1142     { ID_CONTROL_MACRO, "MENU_CONTROL_MACRO" },
1143     { ID_CONTROL_SHOW_MACRO, "MENU_CONTROL_SHOW_MACRO" },
1144     };
1145     static const DlgTextInfo HelpMenuTextInfo[] = {
1146     { ID_HELP_INDEX2, "MENU_HELP_INDEX" },
1147     { ID_HELP_ABOUT, "MENU_HELP_ABOUT" },
1148     };
1149 maya 3227
1150 doda 8445 HMENU hMenu = LoadMenu(m_hInst, MAKEINTRESOURCE(IDR_MENU));
1151     *Menu = hMenu;
1152    
1153     FileMenu = GetSubMenu(hMenu,ID_FILE);
1154 maya 3227 TransMenu = GetSubMenu(FileMenu,ID_TRANSFER);
1155 doda 8445 EditMenu = GetSubMenu(hMenu,ID_EDIT);
1156     SetupMenu = GetSubMenu(hMenu,ID_SETUP);
1157     ControlMenu = GetSubMenu(hMenu,ID_CONTROL);
1158     HelpMenu = GetSubMenu(hMenu,ID_HELPMENU);
1159 maya 3227
1160 doda 8445 SetDlgMenuTexts(hMenu, MenuTextInfo, _countof(MenuTextInfo), ts.UILanguageFile);
1161    
1162 maya 3227 /* LogMeTT ���������m�F�������j���[���������� */
1163     if (isLogMeTTExist()) {
1164     ::InsertMenu(FileMenu, ID_FILE_PRINT2, MF_STRING | MF_ENABLED | MF_BYCOMMAND,
1165     ID_FILE_LOGMEIN, LogMeTTMenuString);
1166     ::InsertMenu(FileMenu, ID_FILE_PRINT2, MF_SEPARATOR, NULL, NULL);
1167     }
1168    
1169 doda 8445 SetDlgMenuTexts(FileMenu, FileMenuTextInfo, _countof(FileMenuTextInfo), ts.UILanguageFile);
1170     SetDlgMenuTexts(EditMenu, EditMenuTextInfo, _countof(EditMenuTextInfo), ts.UILanguageFile);
1171     SetDlgMenuTexts(SetupMenu, SetupMenuTextInfo, _countof(SetupMenuTextInfo), ts.UILanguageFile);
1172     SetDlgMenuTexts(ControlMenu, ControlMenuTextInfo, _countof(ControlMenuTextInfo), ts.UILanguageFile);
1173     SetDlgMenuTexts(HelpMenu, HelpMenuTextInfo, _countof(HelpMenuTextInfo), ts.UILanguageFile);
1174 maya 3227
1175     if ((ts.MenuFlag & MF_SHOWWINMENU) !=0) {
1176 zmatsuo 8490 wchar_t uimsg[MAX_UIMSG];
1177 maya 3227 WinMenu = CreatePopupMenu();
1178 zmatsuo 8490 get_lang_msgW("MENU_WINDOW", uimsg, _countof(uimsg),
1179     L"&Window", ts.UILanguageFile);
1180     _InsertMenuW(hMenu, ID_HELPMENU,
1181     MF_STRING | MF_ENABLED | MF_POPUP | MF_BYPOSITION,
1182     (UINT_PTR)WinMenu, uimsg);
1183 maya 3227 }
1184    
1185 doda 8445 TTXModifyMenu(hMenu); /* TTPLUG */
1186 maya 3227 }
1187    
1188     void CVTWindow::InitMenuPopup(HMENU SubMenu)
1189     {
1190     if ( SubMenu == FileMenu )
1191     {
1192 maya 3966 if (ts.DisableMenuNewConnection) {
1193     if ( Connecting || cv.Open ) {
1194 maya 3965 EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_GRAYED);
1195     }
1196     else {
1197     EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_ENABLED);
1198     }
1199 maya 3227 }
1200 maya 3966 else {
1201     if ( Connecting ) {
1202     EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_GRAYED);
1203     }
1204     else {
1205     EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_ENABLED);
1206     }
1207     }
1208 maya 3227
1209     if ( (! cv.Ready) || (SendVar!=NULL) ||
1210     (FileVar!=NULL) || (cv.PortType==IdFile) ) {
1211     EnableMenuItem(FileMenu,ID_FILE_SENDFILE,MF_BYCOMMAND | MF_GRAYED);
1212     EnableMenuItem(FileMenu,ID_TRANSFER,MF_BYPOSITION | MF_GRAYED); /* Transfer */
1213     EnableMenuItem(FileMenu,ID_FILE_CHANGEDIR,MF_BYCOMMAND | MF_GRAYED);
1214     EnableMenuItem(FileMenu,ID_FILE_DISCONNECT,MF_BYCOMMAND | MF_GRAYED);
1215     EnableMenuItem(FileMenu,ID_FILE_DUPLICATESESSION,MF_BYCOMMAND | MF_GRAYED);
1216     }
1217     else {
1218     EnableMenuItem(FileMenu,ID_FILE_SENDFILE,MF_BYCOMMAND | MF_ENABLED);
1219     EnableMenuItem(FileMenu,ID_TRANSFER,MF_BYPOSITION | MF_ENABLED); /* Transfer */
1220     EnableMenuItem(FileMenu,ID_FILE_CHANGEDIR,MF_BYCOMMAND | MF_ENABLED);
1221     EnableMenuItem(FileMenu,ID_FILE_DISCONNECT,MF_BYCOMMAND | MF_ENABLED);
1222 maya 3964 if (ts.DisableMenuDuplicateSession) {
1223     EnableMenuItem(FileMenu,ID_FILE_DUPLICATESESSION,MF_BYCOMMAND | MF_GRAYED);
1224     }
1225     else {
1226     EnableMenuItem(FileMenu,ID_FILE_DUPLICATESESSION,MF_BYCOMMAND | MF_ENABLED);
1227     }
1228 maya 3227 }
1229    
1230     // �V�K���j���[������ (2004.12.5 yutaka)
1231     EnableMenuItem(FileMenu,ID_FILE_CYGWINCONNECTION,MF_BYCOMMAND | MF_ENABLED);
1232     EnableMenuItem(FileMenu,ID_FILE_TERATERMMENU,MF_BYCOMMAND | MF_ENABLED);
1233     EnableMenuItem(FileMenu,ID_FILE_LOGMEIN,MF_BYCOMMAND | MF_ENABLED);
1234    
1235     // XXX: �������u�����������Alog���O���C�����������B (2005.2.1 yutaka)
1236     if (LogVar!=NULL) { // ���O�������[�h������
1237     EnableMenuItem(FileMenu,ID_FILE_LOG,MF_BYCOMMAND | MF_GRAYED);
1238     EnableMenuItem(FileMenu,ID_FILE_COMMENTTOLOG, MF_BYCOMMAND | MF_ENABLED);
1239     EnableMenuItem(FileMenu,ID_FILE_VIEWLOG, MF_BYCOMMAND | MF_ENABLED);
1240 maya 3709 EnableMenuItem(FileMenu,ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND | MF_ENABLED);
1241 doda 8396 EnableMenuItem(FileMenu,ID_FILE_PAUSELOG, MF_BYCOMMAND | MF_ENABLED);
1242     EnableMenuItem(FileMenu,ID_FILE_STOPLOG, MF_BYCOMMAND | MF_ENABLED);
1243     if (cv.FilePause & OpLog) {
1244     CheckMenuItem(FileMenu,ID_FILE_PAUSELOG, MF_BYCOMMAND | MF_CHECKED);
1245     }
1246     else {
1247     CheckMenuItem(FileMenu,ID_FILE_PAUSELOG, MF_BYCOMMAND | MF_UNCHECKED);
1248     }
1249 maya 3227 } else {
1250     EnableMenuItem(FileMenu,ID_FILE_LOG,MF_BYCOMMAND | MF_ENABLED);
1251     EnableMenuItem(FileMenu,ID_FILE_COMMENTTOLOG, MF_BYCOMMAND | MF_GRAYED);
1252     EnableMenuItem(FileMenu,ID_FILE_VIEWLOG, MF_BYCOMMAND | MF_GRAYED);
1253     EnableMenuItem(FileMenu,ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND | MF_GRAYED);
1254 doda 8396 EnableMenuItem(FileMenu,ID_FILE_PAUSELOG, MF_BYCOMMAND | MF_GRAYED);
1255     EnableMenuItem(FileMenu,ID_FILE_STOPLOG, MF_BYCOMMAND | MF_GRAYED);
1256    
1257     CheckMenuItem(FileMenu,ID_FILE_PAUSELOG, MF_BYCOMMAND | MF_UNCHECKED);
1258 maya 3227 }
1259    
1260     }
1261     else if ( SubMenu == TransMenu )
1262     {
1263     if ((cv.PortType==IdSerial) &&
1264     ((ts.DataBit==IdDataBit7) || (ts.Flow==IdFlowX))) {
1265     EnableMenuItem(TransMenu,1,MF_BYPOSITION | MF_GRAYED); /* XMODEM */
1266     EnableMenuItem(TransMenu,4,MF_BYPOSITION | MF_GRAYED); /* Quick-VAN */
1267     }
1268     else {
1269     EnableMenuItem(TransMenu,1,MF_BYPOSITION | MF_ENABLED); /* XMODEM */
1270     EnableMenuItem(TransMenu,4,MF_BYPOSITION | MF_ENABLED); /* Quick-VAN */
1271     }
1272     if ((cv.PortType==IdSerial) &&
1273     (ts.DataBit==IdDataBit7)) {
1274     EnableMenuItem(TransMenu,2,MF_BYPOSITION | MF_GRAYED); /* ZMODEM */
1275     EnableMenuItem(TransMenu,3,MF_BYPOSITION | MF_GRAYED); /* B-Plus */
1276     }
1277     else {
1278     EnableMenuItem(TransMenu,2,MF_BYPOSITION | MF_ENABLED); /* ZMODEM */
1279     EnableMenuItem(TransMenu,3,MF_BYPOSITION | MF_ENABLED); /* B-Plus */
1280     }
1281     }
1282     else if (SubMenu == EditMenu)
1283     {
1284     if (Selected) {
1285     EnableMenuItem(EditMenu,ID_EDIT_COPY2,MF_BYCOMMAND | MF_ENABLED);
1286     EnableMenuItem(EditMenu,ID_EDIT_COPYTABLE,MF_BYCOMMAND | MF_ENABLED);
1287     }
1288     else {
1289     EnableMenuItem(EditMenu,ID_EDIT_COPY2,MF_BYCOMMAND | MF_GRAYED);
1290     EnableMenuItem(EditMenu,ID_EDIT_COPYTABLE,MF_BYCOMMAND | MF_GRAYED);
1291     }
1292     if (cv.Ready &&
1293     (SendVar==NULL) && (FileVar==NULL) &&
1294     (cv.PortType!=IdFile) &&
1295     (IsClipboardFormatAvailable(CF_TEXT) ||
1296     IsClipboardFormatAvailable(CF_OEMTEXT))) {
1297     EnableMenuItem(EditMenu,ID_EDIT_PASTE2,MF_BYCOMMAND | MF_ENABLED);
1298     EnableMenuItem(EditMenu,ID_EDIT_PASTECR,MF_BYCOMMAND | MF_ENABLED);
1299     }
1300     else {
1301     EnableMenuItem(EditMenu,ID_EDIT_PASTE2,MF_BYCOMMAND | MF_GRAYED);
1302     EnableMenuItem(EditMenu,ID_EDIT_PASTECR,MF_BYCOMMAND | MF_GRAYED);
1303     }
1304     }
1305     else if (SubMenu == SetupMenu)
1306 yutakapon 8179 /*
1307     * �l�b�g���[�N������(TCP/IP���I������������������)���V���A���|�[�g
1308     * (ID_SETUP_SERIALPORT)�����j���[���I�����������������������������A
1309     * �����K�[�h���O���A�V���A���|�[�g�����_�C�A���O�����V���������������������������B
1310     */
1311     if ((SendVar!=NULL) || (FileVar!=NULL) || Connecting) {
1312     EnableMenuItem(SetupMenu,ID_SETUP_SERIALPORT,MF_BYCOMMAND | MF_GRAYED);
1313 maya 3392 }
1314     else {
1315 yutakapon 8179 EnableMenuItem(SetupMenu,ID_SETUP_SERIALPORT,MF_BYCOMMAND | MF_ENABLED);
1316 maya 3392 }
1317 maya 3227
1318     else if (SubMenu == ControlMenu)
1319     {
1320     if (cv.Ready &&
1321     (SendVar==NULL) && (FileVar==NULL)) {
1322 maya 3283 if (ts.DisableMenuSendBreak) {
1323 maya 3279 EnableMenuItem(ControlMenu,ID_CONTROL_SENDBREAK,MF_BYCOMMAND | MF_GRAYED);
1324     }
1325     else {
1326     EnableMenuItem(ControlMenu,ID_CONTROL_SENDBREAK,MF_BYCOMMAND | MF_ENABLED);
1327     }
1328 maya 3392 if (cv.PortType==IdSerial) {
1329 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_ENABLED);
1330 maya 3392 }
1331     else {
1332 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_GRAYED);
1333 maya 3392 }
1334 maya 3227 }
1335     else {
1336     EnableMenuItem(ControlMenu,ID_CONTROL_SENDBREAK,MF_BYCOMMAND | MF_GRAYED);
1337     EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_GRAYED);
1338     }
1339    
1340 maya 3392 if (cv.Ready && cv.TelFlag && (FileVar==NULL)) {
1341 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_AREYOUTHERE,MF_BYCOMMAND | MF_ENABLED);
1342 maya 3392 }
1343     else {
1344 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_AREYOUTHERE,MF_BYCOMMAND | MF_GRAYED);
1345 maya 3392 }
1346 maya 3227
1347 maya 3392 if (HTEKWin==0) {
1348 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_CLOSETEK,MF_BYCOMMAND | MF_GRAYED);
1349 maya 3392 }
1350     else {
1351 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_CLOSETEK,MF_BYCOMMAND | MF_ENABLED);
1352 maya 3392 }
1353 maya 3227
1354 maya 3392 if ((ConvH!=0) || (FileVar!=NULL)) {
1355 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_MACRO,MF_BYCOMMAND | MF_GRAYED);
1356 maya 3842 EnableMenuItem(ControlMenu,ID_CONTROL_SHOW_MACRO,MF_BYCOMMAND | MF_ENABLED);
1357 maya 3392 }
1358     else {
1359 yutakapon 3837 EnableMenuItem(ControlMenu,ID_CONTROL_MACRO,MF_BYCOMMAND | MF_ENABLED);
1360 maya 3842 EnableMenuItem(ControlMenu,ID_CONTROL_SHOW_MACRO,MF_BYCOMMAND | MF_GRAYED);
1361 maya 3392 }
1362 maya 3227
1363     }
1364     else if (SubMenu == WinMenu)
1365     {
1366 yutakapon 5249 SetWinMenu(WinMenu, ts.UIMsg, sizeof(ts.UIMsg), ts.UILanguageFile, 1);
1367 maya 3227 }
1368    
1369     TTXModifyPopupMenu(SubMenu); /* TTPLUG */
1370     }
1371    
1372     // added ConfirmPasteMouseRButton (2007.3.17 maya)
1373     void CVTWindow::InitPasteMenu(HMENU *Menu)
1374     {
1375 doda 8445 static const DlgTextInfo MenuTextInfo[] = {
1376     { ID_EDIT_PASTE2, "MENU_EDIT_PASTE" },
1377     { ID_EDIT_PASTECR, "MENU_EDIT_PASTECR" },
1378     };
1379 zmatsuo 7916 *Menu = LoadMenu(m_hInst,
1380 maya 3227 MAKEINTRESOURCE(IDR_PASTEMENU));
1381 doda 8445 SetDlgMenuTexts(*Menu, MenuTextInfo, _countof(MenuTextInfo), ts.UILanguageFile);
1382 maya 3227 }
1383    
1384     void CVTWindow::ResetSetup()
1385     {
1386     ChangeFont();
1387     BuffChangeWinSize(WinWidth,WinHeight);
1388     ChangeCaret();
1389    
1390     if (cv.Ready) {
1391     ts.PortType = cv.PortType;
1392     if (cv.PortType==IdSerial) {
1393     /* if serial port, change port parameters */
1394     ts.ComPort = cv.ComPort;
1395     CommResetSerial(&ts, &cv, TRUE);
1396     }
1397     }
1398    
1399     /* setup terminal */
1400     SetupTerm();
1401    
1402     /* background and ANSI color */
1403     #ifdef ALPHABLEND_TYPE2
1404 yutakapon 8106 BGInitialize(FALSE);
1405 maya 3227 BGSetupPrimary(TRUE);
1406     // 2006/03/17 by 337 : Alpha�l���������X
1407     // Layered��������������������������������
1408 yutakapon 6553 //
1409     // AlphaBlend ���������f�����������������B
1410     // (2016.12.24 yutaka)
1411 zmatsuo 7390 SetWindowAlpha(ts.AlphaBlendActive);
1412 maya 3227 #else
1413     DispApplyANSIColor();
1414     #endif
1415     DispSetNearestColors(IdBack, IdFore+8, NULL);
1416    
1417     /* setup window */
1418     ChangeWin();
1419    
1420     /* Language & IME */
1421     ResetIME();
1422    
1423     /* change TEK window */
1424     if (pTEKWin != NULL)
1425     ((CTEKWindow *)pTEKWin)->RestoreSetup();
1426     }
1427    
1428     void CVTWindow::RestoreSetup()
1429     {
1430     char TempDir[MAXPATHLEN];
1431 maya 4031 char TempName[MAX_PATH];
1432 maya 3227
1433 maya 3392 if ( strlen(ts.SetupFName)==0 ) {
1434 maya 3227 return;
1435 maya 3392 }
1436 maya 3227
1437     ExtractFileName(ts.SetupFName,TempName,sizeof(TempName));
1438     ExtractDirName(ts.SetupFName,TempDir);
1439     if (TempDir[0]==0)
1440     strncpy_s(TempDir, sizeof(TempDir),ts.HomeDir, _TRUNCATE);
1441     FitFileName(TempName,sizeof(TempName),".INI");
1442    
1443     strncpy_s(ts.SetupFName, sizeof(ts.SetupFName),TempDir, _TRUNCATE);
1444     AppendSlash(ts.SetupFName,sizeof(ts.SetupFName));
1445 maya 3392 strncat_s(ts.SetupFName,sizeof(ts.SetupFName),TempName,_TRUNCATE);
1446 maya 3227
1447 maya 3392 if (LoadTTSET()) {
1448 maya 3227 (*ReadIniFile)(ts.SetupFName,&ts);
1449 maya 3392 }
1450 maya 3227 FreeTTSET();
1451    
1452     #if 0
1453     ChangeDefaultSet(&ts,NULL);
1454     #endif
1455    
1456     ResetSetup();
1457     }
1458    
1459     /* called by the [Setup] Terminal command */
1460     void CVTWindow::SetupTerm()
1461     {
1462 doda 3407 if (ts.Language==IdJapanese || ts.Language==IdKorean || ts.Language==IdUtf8) {
1463 maya 3227 ResetCharSet();
1464 maya 3393 }
1465 maya 3227 cv.CRSend = ts.CRSend;
1466    
1467     // for russian mode
1468     cv.RussHost = ts.RussHost;
1469     cv.RussClient = ts.RussClient;
1470    
1471 doda 3932 if (cv.Ready) {
1472     if (cv.TelFlag && (ts.TelEcho>0)) {
1473     TelChangeEcho();
1474     }
1475     _free_locale(cv.locale);
1476     cv.locale = _create_locale(LC_ALL, cv.Locale);
1477 maya 3392 }
1478 maya 3227
1479     if ((ts.TerminalWidth!=NumOfColumns) ||
1480     (ts.TerminalHeight!=NumOfLines-StatusLine)) {
1481     LockBuffer();
1482     HideStatusLine();
1483     ChangeTerminalSize(ts.TerminalWidth,
1484     ts.TerminalHeight);
1485     UnlockBuffer();
1486     }
1487     else if ((ts.TermIsWin>0) &&
1488     ((ts.TerminalWidth!=WinWidth) ||
1489 maya 3392 (ts.TerminalHeight!=WinHeight-StatusLine))) {
1490 maya 3227 BuffChangeWinSize(ts.TerminalWidth,ts.TerminalHeight+StatusLine);
1491 maya 3392 }
1492 doda 4246
1493     ChangeTerminalID();
1494 maya 3227 }
1495    
1496     void CVTWindow::Startup()
1497     {
1498     /* auto log */
1499     /* OnCommOpen ���J�n�������������������J�n������ (2007.5.14 maya) */
1500    
1501     if ((TopicName[0]==0) && (ts.MacroFN[0]!=0)) {
1502     // start the macro specified in the command line or setup file
1503     RunMacro(ts.MacroFN,TRUE);
1504     ts.MacroFN[0] = 0;
1505     }
1506     else {// start connection
1507 maya 3392 if (TopicName[0]!=0) {
1508 maya 3227 cv.NoMsg=1; /* suppress error messages */
1509 maya 3392 }
1510 maya 3227 ::PostMessage(HVTWin,WM_USER_COMMSTART,0,0);
1511     }
1512     }
1513    
1514     void CVTWindow::OpenTEK()
1515     {
1516     ActiveWin = IdTEK;
1517     if (HTEKWin==NULL) {
1518 zmatsuo 7916 pTEKWin = new CTEKWindow(m_hInst);
1519 maya 3227 }
1520     else {
1521     ::ShowWindow(HTEKWin,SW_SHOWNORMAL);
1522     ::SetFocus(HTEKWin);
1523     }
1524     }
1525    
1526     /////////////////////////////////////////////////////////////////////////////
1527     // CVTWindow message handler
1528    
1529     BOOL CVTWindow::OnCommand(WPARAM wParam, LPARAM lParam)
1530     {
1531     WORD wID = LOWORD(wParam);
1532     WORD wNotifyCode = HIWORD(wParam);
1533    
1534     if (wNotifyCode==1) {
1535     switch (wID) {
1536     case ID_ACC_SENDBREAK:
1537     // added DisableAcceleratorSendBreak (2007.3.17 maya)
1538     if (!ts.DisableAcceleratorSendBreak)
1539     OnControlSendBreak();
1540     return TRUE;
1541     case ID_ACC_AREYOUTHERE:
1542     OnControlAreYouThere();
1543     return TRUE;
1544     }
1545     if (ActiveWin==IdVT) {
1546     switch (wID) {
1547     case ID_ACC_NEWCONNECTION:
1548 maya 5684 if (ts.AcceleratorNewConnection)
1549     OnFileNewConnection();
1550 maya 3227 return TRUE;
1551 maya 5691 case ID_ACC_DUPLICATESESSION:
1552     // added DisableAcceleratorDuplicateSession (2009.4.6 maya)
1553     if (!ts.DisableAcceleratorDuplicateSession)
1554     OnDuplicateSession();
1555     return TRUE;
1556 maya 5684 case ID_ACC_CYGWINCONNECTION:
1557     if (ts.AcceleratorCygwinConnection)
1558     OnCygwinConnection();
1559     return TRUE;
1560 maya 5691 case ID_ACC_DISCONNECT:
1561     Disconnect(TRUE);
1562     return TRUE;
1563 maya 3227 case ID_ACC_COPY:
1564     OnEditCopy();
1565     return TRUE;
1566 doda 6459 case ID_ACC_PASTECR:
1567     OnEditPasteCR();
1568     return TRUE;
1569     case ID_ACC_PASTE:
1570     OnEditPaste();
1571     return TRUE;
1572 maya 3227 case ID_ACC_PRINT:
1573     OnFilePrint();
1574     return TRUE;
1575     case ID_ACC_EXIT:
1576     OnFileExit();
1577     return TRUE;
1578     }
1579     }
1580     else { // transfer accelerator message to TEK win
1581     switch (wID) {
1582     case ID_ACC_COPY:
1583     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKEDIT_COPY,0);
1584     return TRUE;
1585 doda 6459 case ID_ACC_PASTECR:
1586     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKEDIT_PASTECR,0);
1587     return TRUE;
1588     case ID_ACC_PASTE:
1589     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKEDIT_PASTE,0);
1590     return TRUE;
1591 maya 3227 case ID_ACC_PRINT:
1592     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKFILE_PRINT,0);
1593     return TRUE;
1594     case ID_ACC_EXIT:
1595     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKFILE_EXIT,0);
1596     return TRUE;
1597     }
1598     }
1599     }
1600    
1601     if ((wID>=ID_WINDOW_1) && (wID<ID_WINDOW_1+9)) {
1602     SelectWin(wID-ID_WINDOW_1);
1603     return TRUE;
1604     }
1605     else {
1606 maya 3392 if (TTXProcessCommand(HVTWin, wID)) {
1607 maya 3227 return TRUE;
1608 maya 3392 }
1609     else { /* TTPLUG */
1610 zmatsuo 7784 return TTCFrameWnd::OnCommand(wParam, lParam);
1611 maya 3392 }
1612 maya 3227 }
1613     }
1614    
1615 zmatsuo 7528 void CVTWindow::OnActivate(UINT nState, HWND pWndOther, BOOL bMinimized)
1616 maya 3227 {
1617     DispSetActive(nState!=WA_INACTIVE);
1618 zmatsuo 7390 if (nState == WA_INACTIVE) {
1619     SetWindowAlpha(ts.AlphaBlendInactive);
1620     } else {
1621     SetWindowAlpha(ts.AlphaBlendActive);
1622     }
1623 maya 3227 }
1624    
1625 zmatsuo 8337 void CVTWindow::OnChar(WPARAM nChar, UINT nRepCnt, UINT nFlags)
1626 maya 3227 {
1627     unsigned int i;
1628    
1629 maya 3392 if (!KeybEnabled || (TalkStatus!=IdTalkKeyb)) {
1630 maya 3227 return;
1631 maya 3392 }
1632 maya 3227
1633 doda 4414 if (MetaKey(ts.MetaKey)) {
1634 maya 3227 ::PostMessage(HVTWin,WM_SYSCHAR,nChar,MAKELONG(nRepCnt,nFlags));
1635     return;
1636     }
1637    
1638 doda 8445 #if UNICODE_INTERNAL_BUFF
1639 maya 3227 for (i=1 ; i<=nRepCnt ; i++) {
1640 doda 8445 wchar_t u16 = nChar;
1641     CommTextOutW(&cv,&u16,1);
1642 maya 3392 if (ts.LocalEcho>0) {
1643 doda 8445 CommTextEchoW(&cv,&u16,1);
1644 maya 3392 }
1645 maya 3227 }
1646 doda 8445 #else
1647     {
1648     char Code = nChar;
1649     if ((ts.Language==IdRussian) &&
1650     ((BYTE)Code>=128)) {
1651     Code = (char)RussConv(ts.RussKeyb,ts.RussClient,(BYTE)Code);
1652     }
1653 maya 3227
1654 doda 8445 for (i=1 ; i<=nRepCnt ; i++) {
1655     CommTextOut(&cv,&Code,1);
1656     if (ts.LocalEcho>0) {
1657     CommTextEcho(&cv,&Code,1);
1658     }
1659     }
1660     }
1661     #endif
1662    
1663 doda 6421 // �X�N���[�����u�����Z�b�g
1664     if (WinOrgY != 0) {
1665 maya 3227 DispVScroll(SCROLL_BOTTOM, 0);
1666     }
1667     }
1668    
1669     /* copy from ttset.c*/
1670 zmatsuo 8463 static void WriteInt2(const char *Sect, const char *Key, const char *FName, int i1, int i2)
1671 maya 3227 {
1672     char Temp[32];
1673     _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d,%d", i1, i2);
1674     WritePrivateProfileString(Sect, Key, Temp, FName);
1675     }
1676    
1677     static void SaveVTPos()
1678     {
1679     #define Section "Tera Term"
1680     if (ts.SaveVTWinPos) {
1681     /* VT win position */
1682     WriteInt2(Section, "VTPos", ts.SetupFName, ts.VTPos.x, ts.VTPos.y);
1683    
1684     /* VT terminal size */
1685     WriteInt2(Section, "TerminalSize", ts.SetupFName,
1686     ts.TerminalWidth, ts.TerminalHeight);
1687     }
1688     }
1689    
1690     void CVTWindow::OnClose()
1691     {
1692     if ((HTEKWin!=NULL) && ! ::IsWindowEnabled(HTEKWin)) {
1693     MessageBeep(0);
1694     return;
1695     }
1696 zmatsuo 8479
1697 maya 3227 if (cv.Ready && (cv.PortType==IdTCPIP) &&
1698     ((ts.PortFlag & PF_CONFIRMDISCONN) != 0) &&
1699 zmatsuo 8479 ! CloseTT) {
1700     wchar_t uimsg[MAX_UIMSG];
1701     get_lang_msgW("MSG_DISCONNECT_CONF", uimsg, _countof(uimsg),
1702     L"Disconnect?", ts.UILanguageFile);
1703     int result = _MessageBoxW(HVTWin, uimsg, L"Tera Term",
1704     MB_OKCANCEL | MB_ICONEXCLAMATION | MB_DEFBUTTON2);
1705     if (result == IDCANCEL) {
1706     return;
1707     }
1708 maya 3392 }
1709 maya 3227
1710     FileTransEnd(0);
1711     ProtoEnd();
1712    
1713     SaveVTPos();
1714     DestroyWindow();
1715     }
1716    
1717 yutakapon 5232 // �STera Term���I�����w������
1718     void CVTWindow::OnAllClose()
1719     {
1720 yutakapon 5351 // ���R�I���������������������A�����������[�U���������������o�������������B
1721     // (2013.8.17 yutaka)
1722 zmatsuo 8487 wchar_t uimsg[MAX_UIMSG];
1723    
1724     get_lang_msgW("MSG_ALL_TERMINATE_CONF", uimsg, _countof(uimsg), L"Terminate ALL Tera Term(s)?", ts.UILanguageFile);
1725     if (_MessageBoxW(HVTWin, uimsg, L"Tera Term", MB_OKCANCEL | MB_ICONERROR | MB_DEFBUTTON2) == IDCANCEL)
1726 yutakapon 5351 return;
1727    
1728 yutakapon 5232 BroadcastClosingMessage(HVTWin);
1729     }
1730    
1731     // �I������������������Tera Term���I�������BOnAllClose()���M�p�B
1732 zmatsuo 7896 LRESULT CVTWindow::OnNonConfirmClose(WPARAM wParam, LPARAM lParam)
1733 yutakapon 5232 {
1734     // ������ ts �����e�����}�I���������������A�I�����������Z�[�u�����������������������A�������������B
1735     ts.PortFlag &= ~PF_CONFIRMDISCONN;
1736     OnClose();
1737     return 1;
1738     }
1739    
1740 maya 3227 void CVTWindow::OnDestroy()
1741     {
1742     // remove this window from the window list
1743     UnregWin(HVTWin);
1744    
1745 salarm 6100 // USB�f�o�C�X�������m����
1746     UnRegDeviceNotify(HVTWin);
1747    
1748 maya 3227 EndKeyboard();
1749    
1750     /* Disable drag-drop */
1751     ::DragAcceptFiles(HVTWin,FALSE);
1752 zmatsuo 7148 DropListFree();
1753 maya 3227
1754     EndDDE();
1755    
1756 maya 3392 if (cv.TelFlag) {
1757 maya 3227 EndTelnet();
1758 maya 3392 }
1759 maya 3227 CommClose(&cv);
1760    
1761 yutakapon 5636 OpenHelp(HH_CLOSE_ALL, 0, ts.UILanguageFile);
1762 maya 3227
1763 zmatsuo 7485 FreeIME(HVTWin);
1764 maya 3227 FreeTTSET();
1765 zmatsuo 7515 #if 0 // free�����s��������free��������
1766 maya 3227 do { }
1767 maya 3392 while (FreeTTDLG());
1768 zmatsuo 7515 #endif
1769 maya 3227
1770     do { }
1771 maya 3392 while (FreeTTFILE());
1772 maya 3227
1773 maya 3392 if (HTEKWin != NULL) {
1774 maya 3227 ::DestroyWindow(HTEKWin);
1775 maya 3392 }
1776 maya 3227
1777 doda 3450 EndTerm();
1778 maya 3227 EndDisp();
1779    
1780     FreeBuffer();
1781    
1782     TTXEnd(); /* TTPLUG */
1783 doda 6662
1784     DeleteNotifyIcon(&cv);
1785 maya 3227 }
1786    
1787 doda 8445 static void EscapeFilename(const wchar_t *src, wchar_t *dest)
1788 maya 3227 {
1789 doda 8445 #define ESCAPE_CHARS L" ;&()$!`'[]{}#^~"
1790     const wchar_t *s = src;
1791     wchar_t *d = dest;
1792 zmatsuo 7148 while (*s) {
1793 doda 8445 wchar_t c = *s++;
1794     if (c == L'\\') {
1795 zmatsuo 7148 // �p�X���������� \ -> / ��
1796     *d = '/';
1797 doda 8445 } else if (wcschr(ESCAPE_CHARS, c) != NULL) {
1798 zmatsuo 7148 // �G�X�P�[�v���K�v������
1799 doda 8445 *d++ = L'\\';
1800 zmatsuo 7148 *d = c;
1801     } else {
1802     *d = c;
1803     }
1804     d++;
1805     }
1806     *d = '\0'; // null-terminate
1807     }
1808 maya 3227
1809 doda 8445 static void PasteString(PComVar cv, const wchar_t *str, bool escape)
1810 zmatsuo 7148 {
1811 doda 8445 wchar_t *tmpbuf;
1812     if (!escape) {
1813     tmpbuf = _wcsdup(str);
1814     }
1815     else {
1816     const size_t len = wcslen(str) * sizeof(wchar_t) * 2;
1817     tmpbuf = (wchar_t *)malloc(len);
1818 zmatsuo 7148 EscapeFilename(str, tmpbuf);
1819     }
1820 yutakapon 4891
1821 doda 8445 SendMemPasteString(tmpbuf);
1822 zmatsuo 7148 }
1823 yutakapon 4891
1824 zmatsuo 7148 /* �������t�@�C������(�t�H���_������������) */
1825 doda 8445 static bool SendScp(wchar_t *Filenames[], int FileCount, const char *SendDir)
1826 zmatsuo 7148 {
1827     typedef int (CALLBACK *PSSH_start_scp)(char *, char *);
1828     static PSSH_start_scp func = NULL;
1829     static HMODULE h = NULL;
1830     char msg[128];
1831 yutakapon 4891
1832 zmatsuo 7148 if (h == NULL) {
1833     if ( ((h = GetModuleHandle("ttxssh.dll")) == NULL) ) {
1834     _snprintf_s(msg, sizeof(msg), _TRUNCATE, "GetModuleHandle(\"ttxssh.dll\")) %d", GetLastError());
1835     scp_send_error:
1836     ::MessageBox(NULL, msg, "Tera Term: scpsend command error", MB_OK | MB_ICONERROR);
1837     return false;
1838     }
1839     }
1840     if (func == NULL) {
1841     func = (PSSH_start_scp)GetProcAddress(h, "TTXScpSendfile");
1842     if (func == NULL) {
1843     _snprintf_s(msg, sizeof(msg), _TRUNCATE, "GetProcAddress(\"TTXScpSendfile\")) %d", GetLastError());
1844     goto scp_send_error;
1845     }
1846     }
1847 yutakapon 4891
1848 zmatsuo 7148 for (int i = 0; i < FileCount; i++) {
1849 doda 8445 char *FileName = ToU8W(Filenames[i]);
1850 zmatsuo 8449 func(FileName, ts.ScpSendDir);
1851 doda 8445 free(FileName);
1852 zmatsuo 7148 }
1853     return true;
1854     }
1855 doda 6620
1856 zmatsuo 7148 void CVTWindow::DropListFree()
1857     {
1858     if (DropListCount > 0) {
1859     for (int i = 0; i < DropListCount; i++) {
1860     free(DropLists[i]);
1861     DropLists[i] = NULL;
1862     }
1863     free(DropLists);
1864     DropLists = NULL;
1865     DropListCount = 0;
1866     }
1867     }
1868 yutakapon 4891
1869 zmatsuo 7896 LRESULT CVTWindow::OnDropNotify(WPARAM ShowDialog, LPARAM lParam)
1870 zmatsuo 7148 {
1871     // ini���������������A�����s��������Tera Term�������L��������
1872     static enum drop_type DefaultDropType = DROP_TYPE_CANCEL;
1873     static unsigned char DefaultDropTypePaste = DROP_TYPE_PASTE_ESCAPE;
1874     static bool DefaultShowDialog = ts.ConfirmFileDragAndDrop ? true : false;
1875 doda 6620
1876 zmatsuo 7148 (void)lParam;
1877     int FileCount = 0;
1878     int DirectoryCount = 0;
1879     for (int i = 0; i < DropListCount; i++) {
1880 doda 8445 const wchar_t *FileName = DropLists[i];
1881     const DWORD attr = _GetFileAttributesW(FileName);
1882 zmatsuo 7650 if (attr == INVALID_FILE_ATTRIBUTES) {
1883 zmatsuo 7536 FileCount++;
1884     } else if (attr & FILE_ATTRIBUTE_DIRECTORY) {
1885 zmatsuo 7148 DirectoryCount++;
1886     } else {
1887     FileCount++;
1888     }
1889     }
1890 yutakapon 4891
1891 zmatsuo 7148 bool DoSameProcess = false;
1892     const bool isSSH = (cv.isSSH == 2);
1893     enum drop_type DropType;
1894     unsigned char DropTypePaste = DROP_TYPE_PASTE_ESCAPE;
1895     if (DefaultDropType == DROP_TYPE_CANCEL) {
1896     // default is not set
1897     if (!ShowDialog) {
1898     if (FileCount == 1 && DirectoryCount == 0) {
1899     if (ts.ConfirmFileDragAndDrop) {
1900     if (isSSH) {
1901     DropType = DROP_TYPE_SCP;
1902     } else {
1903     DropType = DROP_TYPE_SEND_FILE;
1904 yutakapon 4891 }
1905 zmatsuo 7148 DoSameProcess = false;
1906     } else {
1907     DropType = DROP_TYPE_SEND_FILE;
1908     DoSameProcess = DefaultShowDialog ? false : true;
1909     }
1910     } else if (FileCount == 0 && DirectoryCount == 1) {
1911     DropType = DROP_TYPE_PASTE_FILENAME;
1912     DoSameProcess = DefaultShowDialog ? false : true;
1913     } else if (FileCount > 0 && DirectoryCount > 0) {
1914     DropType = DROP_TYPE_PASTE_FILENAME;
1915     DoSameProcess = false;
1916     } else if (FileCount > 0 && DirectoryCount == 0) {
1917     // filename only
1918     if (isSSH) {
1919     DropType = DROP_TYPE_SCP;
1920     } else {
1921     DropType = DROP_TYPE_SEND_FILE;
1922     }
1923     DoSameProcess = false;
1924     } else {
1925     // directory only
1926     DropType = DROP_TYPE_PASTE_FILENAME;
1927     DoSameProcess = ts.ConfirmFileDragAndDrop ? false : true;
1928     }
1929     } else {
1930     // show dialog
1931     if (DirectoryCount > 0) {
1932     DropType = DROP_TYPE_PASTE_FILENAME;
1933     } else {
1934     if (isSSH) {
1935     DropType = DROP_TYPE_SCP;
1936     } else {
1937     DropType = DROP_TYPE_SEND_FILE;
1938     }
1939     }
1940     DoSameProcess = false;
1941     }
1942     } else {
1943     if (DirectoryCount > 0 &&
1944     (DefaultDropType == DROP_TYPE_SEND_FILE ||
1945     DefaultDropType == DROP_TYPE_SEND_FILE_BINARY ||
1946     DefaultDropType == DROP_TYPE_SCP))
1947     { // �f�t�H���g�����������������������g��������
1948     DropType = DROP_TYPE_PASTE_FILENAME;
1949     DropTypePaste = DefaultDropTypePaste;
1950     DoSameProcess = false;
1951     } else {
1952     DropType = DefaultDropType;
1953     DropTypePaste = DefaultDropTypePaste;
1954     DoSameProcess = (ShowDialog || DefaultShowDialog) ? false : true;
1955     }
1956     }
1957 yutakapon 4891
1958 zmatsuo 7148 for (int i = 0; i < DropListCount; i++) {
1959 doda 8445 const wchar_t *FileName = DropLists[i];
1960 yutakapon 4891
1961 zmatsuo 7148 if (!DoSameProcess) {
1962     bool DoSameProcessNextDrop;
1963     bool DoNotShowDialog = !DefaultShowDialog;
1964 zmatsuo 7706 SetDialogFont(ts.DialogFontName, ts.DialogFontPoint, ts.DialogFontCharSet,
1965 zmatsuo 7589 ts.UILanguageFile, "Tera Term", "DLG_SYSTEM_FONT");
1966 zmatsuo 7148 DropType =
1967 zmatsuo 7916 ShowDropDialogBox(m_hInst, HVTWin,
1968 zmatsuo 7148 FileName, DropType,
1969     DropListCount - i,
1970     (DirectoryCount == 0 && isSSH) ? true : false,
1971     DirectoryCount == 0 ? true : false,
1972 zmatsuo 7172 &ts,
1973 zmatsuo 7148 &DropTypePaste,
1974     &DoSameProcess,
1975     &DoSameProcessNextDrop,
1976     &DoNotShowDialog);
1977     if (DropType == DROP_TYPE_CANCEL) {
1978     goto finish;
1979     }
1980     if (DoSameProcessNextDrop) {
1981     DefaultDropType = DropType;
1982     DefaultDropTypePaste = DropTypePaste;
1983     }
1984     if (!ts.ConfirmFileDragAndDrop) {
1985     DefaultShowDialog = !DoNotShowDialog;
1986     }
1987     }
1988 zmatsuo 7322
1989 zmatsuo 7148 switch (DropType) {
1990     case DROP_TYPE_CANCEL:
1991     default:
1992     // cancel
1993     break;
1994     case DROP_TYPE_SEND_FILE:
1995 zmatsuo 8449 SendMemSendFile(FileName, FALSE);
1996     break;
1997 zmatsuo 7148 case DROP_TYPE_SEND_FILE_BINARY:
1998 zmatsuo 8449 SendMemSendFile(FileName, TRUE);
1999 zmatsuo 7148 break;
2000     case DROP_TYPE_PASTE_FILENAME:
2001     {
2002     const bool escape = (DropTypePaste & DROP_TYPE_PASTE_ESCAPE) ? true : false;
2003 doda 7195
2004     TermSendStartBracket();
2005    
2006 zmatsuo 7148 PasteString(&cv, FileName, escape);
2007     if (DropListCount > 1 && i < DropListCount - 1) {
2008 doda 8445 const wchar_t *separator = (DropTypePaste & DROP_TYPE_PASTE_NEWLINE) ? L"\n" : L" ";
2009 zmatsuo 7148 PasteString(&cv, separator, false);
2010     }
2011 doda 7195
2012     TermSendEndBracket();
2013    
2014 zmatsuo 7148 break;
2015     }
2016     case DROP_TYPE_SCP:
2017     {
2018     // send by scp
2019 doda 8445 wchar_t **FileNames = &DropLists[i];
2020 zmatsuo 7148 int FileCount = DoSameProcess ? DropListCount - i : 1;
2021     if (!SendScp(FileNames, FileCount, ts.ScpSendDir)) {
2022     goto finish;
2023     }
2024     i += FileCount - 1;
2025     break;
2026     }
2027     }
2028     }
2029 yutakapon 4891
2030 zmatsuo 7148 finish:
2031     DropListFree();
2032     return 0;
2033 maya 3227 }
2034    
2035     void CVTWindow::OnDropFiles(HDROP hDropInfo)
2036     {
2037     ::SetForegroundWindow(HVTWin);
2038 zmatsuo 7148 if (cv.Ready && SendVar==NULL)
2039 maya 3227 {
2040 zmatsuo 7148 const UINT ShowDialog =
2041     ((GetAsyncKeyState(VK_CONTROL) & 0x8000) != 0) ? 1 : 0;
2042 doda 8445 DropListCount = _DragQueryFileW(hDropInfo, -1, NULL, 0);
2043     DropLists = (wchar_t **)malloc(sizeof(wchar_t *) * DropListCount);
2044 maya 3227
2045 zmatsuo 7148 for (int i = 0; i < DropListCount; i++) {
2046 doda 8445 const UINT cch = _DragQueryFileW(hDropInfo, i, NULL, 0);
2047     if (cch == 0) {
2048     continue;
2049     }
2050     wchar_t *FileName = (wchar_t *)malloc(sizeof(wchar_t) * (cch + 1));
2051     _DragQueryFileW(hDropInfo,i,FileName,cch + 1);
2052     FileName[cch] = '\0';
2053 zmatsuo 7148 DropLists[i] = FileName;
2054     }
2055 maya 3227
2056 zmatsuo 7148 ::PostMessage(HVTWin, WM_USER_DROPNOTIFY, ShowDialog, 0);
2057 maya 3227 }
2058     DragFinish(hDropInfo);
2059     }
2060    
2061 doda 6801 void CVTWindow::OnGetMinMaxInfo(MINMAXINFO *lpMMI)
2062 maya 3227 {
2063     #ifndef WINDOW_MAXMIMUM_ENABLED
2064     lpMMI->ptMaxSize.x = 10000;
2065     lpMMI->ptMaxSize.y = 10000;
2066     lpMMI->ptMaxTrackSize.x = 10000;
2067     lpMMI->ptMaxTrackSize.y = 10000;
2068     #endif
2069     }
2070    
2071 zmatsuo 7528 void CVTWindow::OnHScroll(UINT nSBCode, UINT nPos, HWND pScrollBar)
2072 maya 3227 {
2073     int Func;
2074    
2075     switch (nSBCode) {
2076     case SB_BOTTOM:
2077     Func = SCROLL_BOTTOM;
2078     break;
2079     case SB_ENDSCROLL:
2080     return;
2081     case SB_LINEDOWN:
2082     Func = SCROLL_LINEDOWN;
2083     break;
2084     case SB_LINEUP:
2085     Func = SCROLL_LINEUP;
2086     break;
2087     case SB_PAGEDOWN:
2088     Func = SCROLL_PAGEDOWN;
2089     break;
2090 doda 6435 case SB_PAGEUP:
2091 maya 3227 Func = SCROLL_PAGEUP;
2092     break;
2093     case SB_THUMBPOSITION:
2094     case SB_THUMBTRACK:
2095     Func = SCROLL_POS;
2096     break;
2097     case SB_TOP:
2098     Func = SCROLL_TOP;
2099     break;
2100     default:
2101     return;
2102     }
2103     DispHScroll(Func,nPos);
2104     }
2105    
2106 zmatsuo 7528 void CVTWindow::OnInitMenuPopup(HMENU hPopupMenu, UINT nIndex, BOOL bSysMenu)
2107 maya 3227 {
2108 zmatsuo 7528 InitMenuPopup(hPopupMenu);
2109 maya 3227 }
2110    
2111 zmatsuo 8337 void CVTWindow::OnKeyDown(WPARAM nChar, UINT nRepCnt, UINT nFlags)
2112 maya 3227 {
2113     BYTE KeyState[256];
2114     MSG M;
2115    
2116 doda 8445 #if UNICODE_DEBUG
2117     if (UnicodeDebugParam.CodePopupEnable)
2118     {
2119     const DWORD now = GetTickCount();
2120     switch(CtrlKeyState) {
2121     case 0:
2122     if (nChar == UnicodeDebugParam.CodePopupKey1) {
2123     CtrlKeyDownTick = now;
2124     CtrlKeyState = 1;
2125     }
2126     break;
2127     case 2:
2128     if (nChar != UnicodeDebugParam.CodePopupKey2) {
2129     CtrlKeyState = 0;
2130     break;
2131     }
2132     if (now - CtrlKeyDownTick < 500 && TipWinCodeDebug == NULL) {
2133     POINT pos;
2134     GetCursorPos(&pos);
2135     ScreenToClient(m_hWnd, &pos);
2136     CodePopup(pos.x, pos.y);
2137     CtrlKeyState = 3;
2138     } else {
2139     CtrlKeyDownTick = now;
2140     CtrlKeyState = 1;
2141     }
2142     break;
2143     case 3:
2144     break;
2145     default:
2146     CtrlKeyState = 0;
2147     break;
2148     }
2149     }
2150     if (TipWinCodeDebug != NULL && nChar == VK_SHIFT) {
2151     POINT pos;
2152     GetCursorPos(&pos);
2153     ScreenToClient(m_hWnd, &pos);
2154     wchar_t *buf = BuffGetCharInfo(pos.x, pos.y);
2155     CBSetTextW(HVTWin, buf, 0);
2156     free(buf);
2157     }
2158     #endif
2159 maya 3227 switch (KeyDown(HVTWin,nChar,nRepCnt,nFlags & 0x1ff)) {
2160     case KEYDOWN_OTHER:
2161     break;
2162     case KEYDOWN_CONTROL:
2163     return;
2164     case KEYDOWN_COMMOUT:
2165 doda 6421 // �X�N���[�����u�����Z�b�g
2166     if (WinOrgY != 0) {
2167 maya 3227 DispVScroll(SCROLL_BOTTOM, 0);
2168     }
2169     return;
2170     }
2171    
2172 doda 4519 if (MetaKey(ts.MetaKey) && (nFlags & 0x2000) != 0)
2173 doda 4414 {
2174 doda 4712 PeekMessage((LPMSG)&M,HVTWin,WM_CHAR,WM_CHAR,PM_REMOVE);
2175 maya 3227 /* for Ctrl+Alt+Key combination */
2176     GetKeyboardState((PBYTE)KeyState);
2177     KeyState[VK_MENU] = 0;
2178     SetKeyboardState((PBYTE)KeyState);
2179     M.hwnd = HVTWin;
2180     M.message = WM_KEYDOWN;
2181     M.wParam = nChar;
2182     M.lParam = MAKELONG(nRepCnt,nFlags & 0xdfff);
2183     TranslateMessage(&M);
2184     }
2185    
2186     }
2187    
2188 zmatsuo 8337 void CVTWindow::OnKeyUp(WPARAM nChar, UINT nRepCnt, UINT nFlags)
2189 maya 3227 {
2190     KeyUp(nChar);
2191 doda 8445 #if UNICODE_DEBUG
2192     if (CtrlKeyState == 1 && nChar == UnicodeDebugParam.CodePopupKey1) {
2193     CtrlKeyState++;
2194     } else {
2195     CtrlKeyState = 0;
2196     }
2197     if (nChar == UnicodeDebugParam.CodePopupKey2) {
2198     if (TipWinCodeDebug != NULL) {
2199     TipWinDestroy(TipWinCodeDebug);
2200     TipWinCodeDebug = NULL;
2201     CtrlKeyState = 0;
2202     }
2203     }
2204     #endif
2205 maya 3227 }
2206    
2207 zmatsuo 7528 void CVTWindow::OnKillFocus(HWND hNewWnd)
2208 maya 3227 {
2209     DispDestroyCaret();
2210     FocusReport(FALSE);
2211 zmatsuo 7784 // TTCFrameWnd::OnKillFocus(hNewWnd); // TODO
2212 maya 3227
2213 maya 3392 if (IsCaretOn()) {
2214 maya 3227 CaretKillFocus(TRUE);
2215 maya 3392 }
2216 maya 3227 }
2217    
2218 zmatsuo 8337 void CVTWindow::OnLButtonDblClk(WPARAM nFlags, POINTS point)
2219 maya 3227 {
2220 maya 3392 if (LButton || MButton || RButton) {
2221 maya 3227 return;
2222 maya 3392 }
2223 maya 3227
2224     DblClkX = point.x;
2225     DblClkY = point.y;
2226    
2227 doda 3992 if (MouseReport(IdMouseEventBtnDown, IdLeftButton, DblClkX, DblClkY)) {
2228 maya 3227 return;
2229 maya 3392 }
2230 maya 3227
2231 doda 3992 if (BuffUrlDblClk(DblClkX, DblClkY)) { // �u���E�U�����o���������������������B (2005.4.3 yutaka)
2232     return;
2233     }
2234    
2235 maya 3227 BuffDblClk(DblClkX, DblClkY);
2236    
2237     LButton = TRUE;
2238     DblClk = TRUE;
2239     AfterDblClk = TRUE;
2240     ::SetTimer(HVTWin, IdDblClkTimer, GetDoubleClickTime(), NULL);
2241    
2242     /* for AutoScrolling */
2243     ::SetCapture(HVTWin);
2244     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
2245     }
2246    
2247 zmatsuo 8337 void CVTWindow::OnLButtonDown(WPARAM nFlags, POINTS point)
2248 maya 3227 {
2249     POINT p;
2250    
2251     p.x = point.x;
2252     p.y = point.y;
2253     ButtonDown(p,IdLeftButton);
2254     }
2255    
2256 zmatsuo 8337 void CVTWindow::OnLButtonUp(WPARAM nFlags, POINTS point)
2257 maya 3227 {
2258 doda 5341 if (IgnoreRelease)
2259     IgnoreRelease = FALSE;
2260 doda 7078 else if (MouseReport(IdMouseEventBtnUp, IdLeftButton, point.x, point.y)) {
2261     ReleaseCapture();
2262     }
2263 maya 3227
2264 maya 3392 if (! LButton) {
2265 maya 3227 return;
2266 maya 3392 }
2267 maya 3227
2268     ButtonUp(FALSE);
2269     }
2270    
2271 zmatsuo 8337 void CVTWindow::OnMButtonDown(WPARAM nFlags, POINTS point)
2272 maya 3227 {
2273     POINT p;
2274    
2275     p.x = point.x;
2276     p.y = point.y;
2277     ButtonDown(p,IdMiddleButton);
2278     }
2279    
2280 zmatsuo 8337 void CVTWindow::OnMButtonUp(WPARAM nFlags, POINTS point)
2281 maya 3227 {
2282 doda 5341 if (IgnoreRelease)
2283     IgnoreRelease = FALSE;
2284 doda 7078 else if (MouseReport(IdMouseEventBtnUp, IdMiddleButton, point.x, point.y)) {
2285     ReleaseCapture();
2286     }
2287 maya 3227
2288 maya 3392 if (! MButton) {
2289 maya 3227 return;
2290 maya 3392 }
2291 maya 3227
2292     // added DisablePasteMouseMButton (2008.3.2 maya)
2293 doda 7078 if (ts.PasteFlag & CPF_DISABLE_MBUTTON) {
2294 maya 3227 ButtonUp(FALSE);
2295 maya 3392 }
2296     else {
2297 maya 3227 ButtonUp(TRUE);
2298 maya 3392 }
2299 maya 3227 }
2300    
2301 zmatsuo 7528 int CVTWindow::OnMouseActivate(HWND pDesktopWnd, UINT nHitTest, UINT message)
2302 maya 3227 {
2303 doda 5341 if ((ts.SelOnActive==0) && (nHitTest==HTCLIENT)) { //disable mouse event for text selection
2304     IgnoreRelease = TRUE;
2305 maya 3227 return MA_ACTIVATEANDEAT; // when window is activated
2306 doda 5341 }
2307     else {
2308 maya 3227 return MA_ACTIVATE;
2309 doda 5341 }
2310 maya 3227 }
2311    
2312 doda 8445
2313     void CVTWindow::CodePopup(int client_x, int client_y)
2314     {
2315     wchar_t *buf = BuffGetCharInfo(client_x, client_y);
2316     if (TipWinCodeDebug == NULL) {
2317     TipWinCodeDebug = TipWinCreate(m_hInst, m_hWnd);
2318     }
2319     POINT pos = { client_x, client_y };
2320     ClientToScreen(m_hWnd, &pos);
2321     TipWinSetPos(TipWinCodeDebug, pos.x, pos.y);
2322     TipWinSetTextW(TipWinCodeDebug, buf);
2323     TipWinSetVisible(TipWinCodeDebug, TRUE);
2324     free(buf);
2325     }
2326    
2327 zmatsuo 8337 void CVTWindow::OnMouseMove(WPARAM nFlags, POINTS point)
2328 maya 3227 {
2329     int i;
2330 doda 3987 BOOL mousereport;
2331 maya 3227
2332 doda 8445 #if UNICODE_DEBUG
2333     if (TipWinCodeDebug != NULL) {
2334     CodePopup(point.x, point.y);
2335     }
2336     #endif
2337    
2338 doda 5341 if (!IgnoreRelease)
2339     mousereport = MouseReport(IdMouseEventMove, 0, point.x, point.y);
2340 doda 3987
2341 maya 3227 if (! (LButton || MButton || RButton)) {
2342 doda 5279 if (BuffCheckMouseOnURL(point.x, point.y))
2343     SetMouseCursor("HAND");
2344     else
2345     SetMouseCursor(ts.MouseCursorName);
2346 maya 3227 return;
2347     }
2348    
2349 doda 3987 if (mousereport) {
2350     return;
2351     }
2352    
2353 maya 3392 if (DblClk) {
2354 maya 3227 i = 2;
2355 maya 3392 }
2356     else if (TplClk) {
2357 maya 3227 i = 3;
2358 maya 3392 }
2359     else {
2360 maya 3227 i = 1;
2361 maya 3392 }
2362 maya 3227
2363     if (!ts.SelectOnlyByLButton ||
2364 maya 3392 (ts.SelectOnlyByLButton && LButton) ) {
2365 maya 3227 // SelectOnlyByLButton == TRUE ���������A���{�^���_�E���������I������ (2007.11.21 maya)
2366     BuffChangeSelect(point.x, point.y,i);
2367     }
2368     }
2369