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 9554 - (hide annotations) (download) (as text)
Fri Dec 3 12:12:03 2021 UTC (2 years, 4 months ago) by youlab
Original Path: trunk/teraterm/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 140457 byte(s)
D&DによるSCP送信で、多数のファイルを一括送信するとエラーになる問題を修正した。
sshd_configのMaxSessions=10の場合、10個目の送信でエラーとなっていた。

Feedback from 
r8924

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