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 8678 - (hide annotations) (download) (as text)
Wed Apr 8 16:01:23 2020 UTC (4 years ago) by zmatsuo
Original Path: trunk/teraterm/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 178843 byte(s)
IME前後参照変換をUnicode化

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