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 9115 - (hide annotations) (download) (as text)
Mon Dec 28 14:29:48 2020 UTC (3 years, 3 months ago) by zmatsuo
Original Path: trunk/teraterm/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 164188 byte(s)
エスケープシーケンスからの印字を修正

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