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 8749 - (hide annotations) (download) (as text)
Sun Apr 26 14:35:29 2020 UTC (3 years, 11 months ago) by zmatsuo
Original Path: trunk/teraterm/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 179005 byte(s)
設定を別ファイルに分離した

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