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