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 9055 - (hide annotations) (download) (as text)
Sun Dec 20 12:06:51 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: 163921 byte(s)
ttpfile.dll を使用しないようにした

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