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 10405 - (hide annotations) (download) (as text)
Sun Dec 11 12:08:27 2022 UTC (16 months ago) by zmatsuo
Original Path: trunk/teraterm/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 138562 byte(s)
ファイル選択ダイアログの初期ディレクトリをファイルのパスから設定するようにした

- ttcommdlgからコモンダイアログを使用するよう修正

ticket #45554
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 8676 wchar_t *strW = BuffEndSelect();
544     if (strW != NULL) {
545     CBSetTextW(HVTWin, strW, 0);
546     }
547 maya 3227 }
548    
549 doda 6415 if (Paste) {
550 doda 6456 CBStartPaste(HVTWin, FALSE, BracketedPasteMode());
551 doda 8445
552 doda 6456 // �X�N���[�����u�����Z�b�g
553     if (WinOrgY != 0) {
554     DispVScroll(SCROLL_BOTTOM, 0);
555 maya 3227 }
556     }
557     }
558    
559     void CVTWindow::ButtonDown(POINT p, int LMR)
560     {
561     HMENU PopupMenu, PopupBase;
562     BOOL mousereport;
563    
564     if ((LMR==IdLeftButton) && ControlKey() && (MainMenu==NULL) &&
565     ((ts.MenuFlag & MF_NOPOPUP)==0)) {
566     int i, numItems;
567    
568     InitMenu(&PopupMenu);
569    
570     PopupBase = CreatePopupMenu();
571     numItems = GetMenuItemCount(PopupMenu);
572    
573     for (i = 0; i < numItems; i++) {
574 zmatsuo 9358 wchar_t itemText[256];
575 maya 3227 HMENU submenu = GetSubMenu(PopupMenu, i);
576    
577     if (submenu != NULL) {
578     InitMenuPopup(submenu);
579     }
580    
581 zmatsuo 9358 if (GetMenuStringW(PopupMenu, i, itemText, _countof(itemText), MF_BYPOSITION) != 0) {
582 maya 3227 int state = GetMenuState(PopupMenu, i, MF_BYPOSITION) &
583     (MF_CHECKED | MF_DISABLED | MF_GRAYED | MF_HILITE |
584     MF_MENUBARBREAK | MF_MENUBREAK | MF_SEPARATOR);
585    
586 zmatsuo 9358 AppendMenuW(PopupBase,
587     submenu != NULL ? LOBYTE(state) | MF_POPUP : state,
588     submenu != NULL ? (UINT_PTR)submenu : GetMenuItemID(PopupMenu, i),
589     itemText);
590 maya 3227 }
591     }
592    
593     ::ClientToScreen(HVTWin, &p);
594     TrackPopupMenu(PopupBase,TPM_LEFTALIGN | TPM_LEFTBUTTON,
595     p.x,p.y,0,HVTWin,NULL);
596     if (WinMenu!=NULL) {
597     DestroyMenu(WinMenu);
598     WinMenu = NULL;
599     }
600     DestroyMenu(PopupBase);
601     DestroyMenu(PopupMenu);
602     PopupMenu = 0;
603     return;
604     }
605    
606 zmatsuo 7528 mousereport = MouseReport(IdMouseEventBtnDown, LMR, p.x, p.y);
607     if (mousereport) {
608     ::SetCapture(m_hWnd);
609 doda 3987 return;
610     }
611 maya 3227
612     // added ConfirmPasteMouseRButton (2007.3.17 maya)
613     if ((LMR == IdRightButton) &&
614 doda 6594 (ts.PasteFlag & CPF_DISABLE_RBUTTON) == 0 &&
615     (ts.PasteFlag & CPF_CONFIRM_RBUTTON) != 0 &&
616 maya 3227 cv.Ready &&
617     !mousereport &&
618 zmatsuo 8948 IsSendVarNULL() && IsFileVarNULL() &&
619 maya 3227 (cv.PortType!=IdFile) &&
620     (IsClipboardFormatAvailable(CF_TEXT) ||
621     IsClipboardFormatAvailable(CF_OEMTEXT))) {
622    
623     int i, numItems;
624    
625     InitPasteMenu(&PopupMenu);
626     PopupBase = CreatePopupMenu();
627     numItems = GetMenuItemCount(PopupMenu);
628    
629     for (i = 0; i < numItems; i++) {
630 zmatsuo 9358 wchar_t itemText[256];
631     if (GetMenuStringW(PopupMenu, i, itemText, _countof(itemText), MF_BYPOSITION) != 0) {
632 maya 3227 int state = GetMenuState(PopupMenu, i, MF_BYPOSITION) &
633     (MF_CHECKED | MF_DISABLED | MF_GRAYED | MF_HILITE |
634     MF_MENUBARBREAK | MF_MENUBREAK | MF_SEPARATOR);
635    
636 zmatsuo 9358 AppendMenuW(PopupBase, state,
637     GetMenuItemID(PopupMenu, i), itemText);
638 maya 3227 }
639     }
640    
641     ::ClientToScreen(HVTWin, &p);
642     TrackPopupMenu(PopupBase,TPM_LEFTALIGN | TPM_LEFTBUTTON,
643     p.x,p.y,0,HVTWin,NULL);
644     if (WinMenu!=NULL) {
645     DestroyMenu(WinMenu);
646     WinMenu = NULL;
647     }
648     DestroyMenu(PopupBase);
649     DestroyMenu(PopupMenu);
650     PopupMenu = 0;
651     return;
652     }
653    
654     if (AfterDblClk && (LMR==IdLeftButton) &&
655     (abs(p.x-DblClkX)<=GetSystemMetrics(SM_CXDOUBLECLK)) &&
656     (abs(p.y-DblClkY)<=GetSystemMetrics(SM_CYDOUBLECLK))) {
657     /* triple click */
658     ::KillTimer(HVTWin, IdDblClkTimer);
659     AfterDblClk = FALSE;
660     BuffTplClk(p.y);
661     LButton = TRUE;
662     TplClk = TRUE;
663     /* for AutoScrolling */
664     ::SetCapture(HVTWin);
665     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
666     }
667     else {
668     if (! (LButton || MButton || RButton)) {
669     BOOL box = FALSE;
670    
671     // select several pages of output from Tera Term window (2005.5.15 yutaka)
672     if (LMR == IdLeftButton && ShiftKey()) {
673     BuffSeveralPagesSelect(p.x, p.y);
674    
675     } else {
676     // Select rectangular block with Alt Key. Delete Shift key.(2005.5.15 yutaka)
677     if (LMR == IdLeftButton && AltKey()) {
678     box = TRUE;
679     }
680    
681     // Starting the selection only by a left button.(2007.11.20 maya)
682     if (!ts.SelectOnlyByLButton ||
683     (ts.SelectOnlyByLButton && LMR == IdLeftButton) ) {
684     BuffStartSelect(p.x,p.y, box);
685     TplClk = FALSE;
686    
687     /* for AutoScrolling */
688     ::SetCapture(HVTWin);
689     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
690     }
691     }
692     }
693    
694     switch (LMR) {
695     case IdRightButton:
696     RButton = TRUE;
697     break;
698     case IdMiddleButton:
699     MButton = TRUE;
700     break;
701     case IdLeftButton:
702     LButton = TRUE;
703     break;
704     }
705     }
706     }
707    
708     void CVTWindow::InitMenu(HMENU *Menu)
709     {
710 doda 8445 static const DlgTextInfo MenuTextInfo[] = {
711     { ID_FILE, "MENU_FILE" },
712     { ID_EDIT, "MENU_EDIT" },
713     { ID_SETUP, "MENU_SETUP" },
714     { ID_CONTROL, "MENU_CONTROL" },
715     { ID_HELPMENU, "MENU_HELP" },
716     };
717     static const DlgTextInfo FileMenuTextInfo[] = {
718     { ID_FILE_NEWCONNECTION, "MENU_FILE_NEW" },
719     { ID_FILE_DUPLICATESESSION, "MENU_FILE_DUPLICATE" },
720     { ID_FILE_CYGWINCONNECTION, "MENU_FILE_GYGWIN" },
721     { ID_FILE_LOG, "MENU_FILE_LOG" },
722     { ID_FILE_COMMENTTOLOG, "MENU_FILE_COMMENTLOG" },
723     { ID_FILE_VIEWLOG, "MENU_FILE_VIEWLOG" },
724     { ID_FILE_SHOWLOGDIALOG, "MENU_FILE_SHOWLOGDIALOG" },
725     { ID_FILE_PAUSELOG, "MENU_FILE_PAUSELOG" },
726     { ID_FILE_STOPLOG, "MENU_FILE_STOPLOG" },
727     { ID_FILE_SENDFILE, "MENU_FILE_SENDFILE" },
728     { ID_FILE_REPLAYLOG, "MENU_FILE_REPLAYLOG" },
729     { ID_FILE_CHANGEDIR, "MENU_FILE_CHANGEDIR" },
730     { ID_FILE_PRINT2, "MENU_FILE_PRINT" },
731     { ID_FILE_DISCONNECT, "MENU_FILE_DISCONNECT" },
732     { ID_FILE_EXIT, "MENU_FILE_EXIT" },
733     { ID_FILE_EXITALL, "MENU_FILE_EXITALL" },
734     { 11, "MENU_TRANS" },
735     { ID_FILE_KERMITRCV, "MENU_TRANS_KERMIT_RCV" },
736     { ID_FILE_KERMITGET, "MENU_TRANS_KERMIT_GET" },
737     { ID_FILE_KERMITSEND, "MENU_TRANS_KERMIT_SEND" },
738     { ID_FILE_KERMITFINISH, "MENU_TRANS_KERMIT_FINISH" },
739     { ID_FILE_XRCV, "MENU_TRANS_X_RCV" },
740     { ID_FILE_XSEND, "MENU_TRANS_X_SEND" },
741     { ID_FILE_YRCV, "MENU_TRANS_Y_RCV" },
742     { ID_FILE_YSEND, "MENU_TRANS_Y_SEND" },
743     { ID_FILE_ZRCV, "MENU_TRANS_Z_RCV" },
744     { ID_FILE_ZSEND, "MENU_TRANS_Z_SEND" },
745     { ID_FILE_BPRCV, "MENU_TRANS_BP_RCV" },
746     { ID_FILE_BPSEND, "MENU_TRANS_BP_SEND" },
747     { ID_FILE_QVRCV, "MENU_TRANS_QV_RCV" },
748     { ID_FILE_QVSEND, "MENU_TRANS_QV_SEND" },
749     };
750     static const DlgTextInfo EditMenuTextInfo[] = {
751     { ID_EDIT_COPY2, "MENU_EDIT_COPY" },
752     { ID_EDIT_COPYTABLE, "MENU_EDIT_COPYTABLE" },
753     { ID_EDIT_PASTE2, "MENU_EDIT_PASTE" },
754     { ID_EDIT_PASTECR, "MENU_EDIT_PASTECR" },
755     { ID_EDIT_CLEARSCREEN, "MENU_EDIT_CLSCREEN" },
756     { ID_EDIT_CLEARBUFFER, "MENU_EDIT_CLBUFFER" },
757     { ID_EDIT_CANCELSELECT, "MENU_EDIT_CANCELSELECT" },
758     { ID_EDIT_SELECTSCREEN, "MENU_EDIT_SELECTSCREEN" },
759     { ID_EDIT_SELECTALL, "MENU_EDIT_SELECTALL" },
760     };
761     static const DlgTextInfo SetupMenuTextInfo[] = {
762     { ID_SETUP_TERMINAL, "MENU_SETUP_TERMINAL" },
763     { ID_SETUP_WINDOW, "MENU_SETUP_WINDOW" },
764     { ID_SETUP_FONT, "MENU_SETUP_FONT" },
765     { ID_SETUP_DLG_FONT, "MENU_SETUP_DIALOG_FONT" },
766     { 2, "MENU_SETUP_FONT_SUBMENU" },
767     { ID_SETUP_KEYBOARD, "MENU_SETUP_KEYBOARD" },
768     { ID_SETUP_SERIALPORT, "MENU_SETUP_SERIALPORT" },
769     { ID_SETUP_TCPIP, "MENU_SETUP_TCPIP" },
770     { ID_SETUP_GENERAL, "MENU_SETUP_GENERAL" },
771     { ID_SETUP_ADDITIONALSETTINGS, "MENU_SETUP_ADDITION" },
772     { ID_SETUP_SAVE, "MENU_SETUP_SAVE" },
773     { ID_SETUP_RESTORE, "MENU_SETUP_RESTORE" },
774     { ID_OPEN_SETUP, "MENU_SETUP_OPENSETUP" },
775     { ID_SETUP_LOADKEYMAP, "MENU_SETUP_LOADKEYMAP" },
776     };
777     static const DlgTextInfo ControlMenuTextInfo[] = {
778     { ID_CONTROL_RESETTERMINAL, "MENU_CONTROL_RESET" },
779     { ID_CONTROL_RESETREMOTETITLE, "MENU_CONTROL_RESETTITLE" },
780     { ID_CONTROL_AREYOUTHERE, "MENU_CONTROL_AREYOUTHERE" },
781     { ID_CONTROL_SENDBREAK, "MENU_CONTROL_SENDBREAK" },
782     { ID_CONTROL_RESETPORT, "MENU_CONTROL_RESETPORT" },
783     { ID_CONTROL_BROADCASTCOMMAND, "MENU_CONTROL_BROADCAST" },
784     { ID_CONTROL_OPENTEK, "MENU_CONTROL_OPENTEK" },
785     { ID_CONTROL_CLOSETEK, "MENU_CONTROL_CLOSETEK" },
786     { ID_CONTROL_MACRO, "MENU_CONTROL_MACRO" },
787     { ID_CONTROL_SHOW_MACRO, "MENU_CONTROL_SHOW_MACRO" },
788     };
789     static const DlgTextInfo HelpMenuTextInfo[] = {
790     { ID_HELP_INDEX2, "MENU_HELP_INDEX" },
791     { ID_HELP_ABOUT, "MENU_HELP_ABOUT" },
792     };
793 maya 3227
794 doda 8445 HMENU hMenu = LoadMenu(m_hInst, MAKEINTRESOURCE(IDR_MENU));
795     *Menu = hMenu;
796    
797     FileMenu = GetSubMenu(hMenu,ID_FILE);
798 maya 3227 TransMenu = GetSubMenu(FileMenu,ID_TRANSFER);
799 doda 8445 EditMenu = GetSubMenu(hMenu,ID_EDIT);
800     SetupMenu = GetSubMenu(hMenu,ID_SETUP);
801     ControlMenu = GetSubMenu(hMenu,ID_CONTROL);
802     HelpMenu = GetSubMenu(hMenu,ID_HELPMENU);
803 maya 3227
804 zmatsuo 9350 SetDlgMenuTextsW(hMenu, MenuTextInfo, _countof(MenuTextInfo), ts.UILanguageFileW);
805 doda 8445
806 zmatsuo 9350 SetDlgMenuTextsW(FileMenu, FileMenuTextInfo, _countof(FileMenuTextInfo), ts.UILanguageFileW);
807     SetDlgMenuTextsW(EditMenu, EditMenuTextInfo, _countof(EditMenuTextInfo), ts.UILanguageFileW);
808     SetDlgMenuTextsW(SetupMenu, SetupMenuTextInfo, _countof(SetupMenuTextInfo), ts.UILanguageFileW);
809     SetDlgMenuTextsW(ControlMenu, ControlMenuTextInfo, _countof(ControlMenuTextInfo), ts.UILanguageFileW);
810     SetDlgMenuTextsW(HelpMenu, HelpMenuTextInfo, _countof(HelpMenuTextInfo), ts.UILanguageFileW);
811 maya 3227
812     if ((ts.MenuFlag & MF_SHOWWINMENU) !=0) {
813 zmatsuo 8490 wchar_t uimsg[MAX_UIMSG];
814 maya 3227 WinMenu = CreatePopupMenu();
815 zmatsuo 8490 get_lang_msgW("MENU_WINDOW", uimsg, _countof(uimsg),
816     L"&Window", ts.UILanguageFile);
817 zmatsuo 9324 InsertMenuW(hMenu, ID_HELPMENU,
818     MF_STRING | MF_ENABLED | MF_POPUP | MF_BYPOSITION,
819     (UINT_PTR)WinMenu, uimsg);
820 maya 3227 }
821    
822 doda 8445 TTXModifyMenu(hMenu); /* TTPLUG */
823 maya 3227 }
824    
825     void CVTWindow::InitMenuPopup(HMENU SubMenu)
826     {
827     if ( SubMenu == FileMenu )
828     {
829 maya 3966 if (ts.DisableMenuNewConnection) {
830     if ( Connecting || cv.Open ) {
831 maya 3965 EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_GRAYED);
832     }
833     else {
834     EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_ENABLED);
835     }
836 maya 3227 }
837 maya 3966 else {
838     if ( Connecting ) {
839     EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_GRAYED);
840     }
841     else {
842     EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_ENABLED);
843     }
844     }
845 maya 3227
846 zmatsuo 8948 if ( (! cv.Ready) || (!IsSendVarNULL()) ||
847     (!IsFileVarNULL()) || (cv.PortType==IdFile) ) {
848 maya 3227 EnableMenuItem(FileMenu,ID_FILE_SENDFILE,MF_BYCOMMAND | MF_GRAYED);
849     EnableMenuItem(FileMenu,ID_TRANSFER,MF_BYPOSITION | MF_GRAYED); /* Transfer */
850     EnableMenuItem(FileMenu,ID_FILE_CHANGEDIR,MF_BYCOMMAND | MF_GRAYED);
851     EnableMenuItem(FileMenu,ID_FILE_DISCONNECT,MF_BYCOMMAND | MF_GRAYED);
852     EnableMenuItem(FileMenu,ID_FILE_DUPLICATESESSION,MF_BYCOMMAND | MF_GRAYED);
853     }
854     else {
855     EnableMenuItem(FileMenu,ID_FILE_SENDFILE,MF_BYCOMMAND | MF_ENABLED);
856     EnableMenuItem(FileMenu,ID_TRANSFER,MF_BYPOSITION | MF_ENABLED); /* Transfer */
857     EnableMenuItem(FileMenu,ID_FILE_CHANGEDIR,MF_BYCOMMAND | MF_ENABLED);
858     EnableMenuItem(FileMenu,ID_FILE_DISCONNECT,MF_BYCOMMAND | MF_ENABLED);
859 maya 3964 if (ts.DisableMenuDuplicateSession) {
860     EnableMenuItem(FileMenu,ID_FILE_DUPLICATESESSION,MF_BYCOMMAND | MF_GRAYED);
861     }
862     else {
863     EnableMenuItem(FileMenu,ID_FILE_DUPLICATESESSION,MF_BYCOMMAND | MF_ENABLED);
864     }
865 maya 3227 }
866    
867     // �V�K���j���[������ (2004.12.5 yutaka)
868     EnableMenuItem(FileMenu,ID_FILE_CYGWINCONNECTION,MF_BYCOMMAND | MF_ENABLED);
869     EnableMenuItem(FileMenu,ID_FILE_TERATERMMENU,MF_BYCOMMAND | MF_ENABLED);
870    
871     // XXX: �������u�����������Alog���O���C�����������B (2005.2.1 yutaka)
872 zmatsuo 8858 if (FLogIsOpend()) { // ���O�������[�h������
873 maya 3227 EnableMenuItem(FileMenu,ID_FILE_LOG,MF_BYCOMMAND | MF_GRAYED);
874     EnableMenuItem(FileMenu,ID_FILE_COMMENTTOLOG, MF_BYCOMMAND | MF_ENABLED);
875     EnableMenuItem(FileMenu,ID_FILE_VIEWLOG, MF_BYCOMMAND | MF_ENABLED);
876 maya 3709 EnableMenuItem(FileMenu,ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND | MF_ENABLED);
877 doda 8396 EnableMenuItem(FileMenu,ID_FILE_PAUSELOG, MF_BYCOMMAND | MF_ENABLED);
878     EnableMenuItem(FileMenu,ID_FILE_STOPLOG, MF_BYCOMMAND | MF_ENABLED);
879 zmatsuo 8857 if (FLogIsPause()) {
880 doda 8396 CheckMenuItem(FileMenu,ID_FILE_PAUSELOG, MF_BYCOMMAND | MF_CHECKED);
881     }
882     else {
883     CheckMenuItem(FileMenu,ID_FILE_PAUSELOG, MF_BYCOMMAND | MF_UNCHECKED);
884     }
885 maya 3227 } else {
886     EnableMenuItem(FileMenu,ID_FILE_LOG,MF_BYCOMMAND | MF_ENABLED);
887     EnableMenuItem(FileMenu,ID_FILE_COMMENTTOLOG, MF_BYCOMMAND | MF_GRAYED);
888     EnableMenuItem(FileMenu,ID_FILE_VIEWLOG, MF_BYCOMMAND | MF_GRAYED);
889     EnableMenuItem(FileMenu,ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND | MF_GRAYED);
890 doda 8396 EnableMenuItem(FileMenu,ID_FILE_PAUSELOG, MF_BYCOMMAND | MF_GRAYED);
891     EnableMenuItem(FileMenu,ID_FILE_STOPLOG, MF_BYCOMMAND | MF_GRAYED);
892    
893     CheckMenuItem(FileMenu,ID_FILE_PAUSELOG, MF_BYCOMMAND | MF_UNCHECKED);
894 maya 3227 }
895    
896     }
897     else if ( SubMenu == TransMenu )
898     {
899     if ((cv.PortType==IdSerial) &&
900     ((ts.DataBit==IdDataBit7) || (ts.Flow==IdFlowX))) {
901     EnableMenuItem(TransMenu,1,MF_BYPOSITION | MF_GRAYED); /* XMODEM */
902     EnableMenuItem(TransMenu,4,MF_BYPOSITION | MF_GRAYED); /* Quick-VAN */
903     }
904     else {
905     EnableMenuItem(TransMenu,1,MF_BYPOSITION | MF_ENABLED); /* XMODEM */
906     EnableMenuItem(TransMenu,4,MF_BYPOSITION | MF_ENABLED); /* Quick-VAN */
907     }
908     if ((cv.PortType==IdSerial) &&
909     (ts.DataBit==IdDataBit7)) {
910     EnableMenuItem(TransMenu,2,MF_BYPOSITION | MF_GRAYED); /* ZMODEM */
911     EnableMenuItem(TransMenu,3,MF_BYPOSITION | MF_GRAYED); /* B-Plus */
912     }
913     else {
914     EnableMenuItem(TransMenu,2,MF_BYPOSITION | MF_ENABLED); /* ZMODEM */
915     EnableMenuItem(TransMenu,3,MF_BYPOSITION | MF_ENABLED); /* B-Plus */
916     }
917     }
918     else if (SubMenu == EditMenu)
919     {
920     if (Selected) {
921     EnableMenuItem(EditMenu,ID_EDIT_COPY2,MF_BYCOMMAND | MF_ENABLED);
922     EnableMenuItem(EditMenu,ID_EDIT_COPYTABLE,MF_BYCOMMAND | MF_ENABLED);
923     }
924     else {
925     EnableMenuItem(EditMenu,ID_EDIT_COPY2,MF_BYCOMMAND | MF_GRAYED);
926     EnableMenuItem(EditMenu,ID_EDIT_COPYTABLE,MF_BYCOMMAND | MF_GRAYED);
927     }
928     if (cv.Ready &&
929 zmatsuo 8948 IsSendVarNULL() && IsFileVarNULL() &&
930 maya 3227 (cv.PortType!=IdFile) &&
931     (IsClipboardFormatAvailable(CF_TEXT) ||
932     IsClipboardFormatAvailable(CF_OEMTEXT))) {
933     EnableMenuItem(EditMenu,ID_EDIT_PASTE2,MF_BYCOMMAND | MF_ENABLED);
934     EnableMenuItem(EditMenu,ID_EDIT_PASTECR,MF_BYCOMMAND | MF_ENABLED);
935     }
936     else {
937     EnableMenuItem(EditMenu,ID_EDIT_PASTE2,MF_BYCOMMAND | MF_GRAYED);
938     EnableMenuItem(EditMenu,ID_EDIT_PASTECR,MF_BYCOMMAND | MF_GRAYED);
939     }
940     }
941     else if (SubMenu == SetupMenu)
942 yutakapon 8179 /*
943     * �l�b�g���[�N������(TCP/IP���I������������������)���V���A���|�[�g
944     * (ID_SETUP_SERIALPORT)�����j���[���I�����������������������������A
945     * �����K�[�h���O���A�V���A���|�[�g�����_�C�A���O�����V���������������������������B
946     */
947 zmatsuo 8948 if (!IsSendVarNULL() || !IsFileVarNULL() || Connecting) {
948 yutakapon 8179 EnableMenuItem(SetupMenu,ID_SETUP_SERIALPORT,MF_BYCOMMAND | MF_GRAYED);
949 maya 3392 }
950     else {
951 yutakapon 8179 EnableMenuItem(SetupMenu,ID_SETUP_SERIALPORT,MF_BYCOMMAND | MF_ENABLED);
952 maya 3392 }
953 maya 3227
954     else if (SubMenu == ControlMenu)
955     {
956     if (cv.Ready &&
957 zmatsuo 8948 IsSendVarNULL() && IsFileVarNULL()) {
958 maya 3283 if (ts.DisableMenuSendBreak) {
959 maya 3279 EnableMenuItem(ControlMenu,ID_CONTROL_SENDBREAK,MF_BYCOMMAND | MF_GRAYED);
960     }
961     else {
962     EnableMenuItem(ControlMenu,ID_CONTROL_SENDBREAK,MF_BYCOMMAND | MF_ENABLED);
963     }
964 maya 3392 if (cv.PortType==IdSerial) {
965 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_ENABLED);
966 maya 3392 }
967     else {
968 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_GRAYED);
969 maya 3392 }
970 maya 3227 }
971     else {
972     EnableMenuItem(ControlMenu,ID_CONTROL_SENDBREAK,MF_BYCOMMAND | MF_GRAYED);
973     EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_GRAYED);
974     }
975    
976 zmatsuo 8948 if (cv.Ready && cv.TelFlag && IsFileVarNULL()) {
977 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_AREYOUTHERE,MF_BYCOMMAND | MF_ENABLED);
978 maya 3392 }
979     else {
980 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_AREYOUTHERE,MF_BYCOMMAND | MF_GRAYED);
981 maya 3392 }
982 maya 3227
983 maya 3392 if (HTEKWin==0) {
984 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_CLOSETEK,MF_BYCOMMAND | MF_GRAYED);
985 maya 3392 }
986     else {
987 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_CLOSETEK,MF_BYCOMMAND | MF_ENABLED);
988 maya 3392 }
989 maya 3227
990 zmatsuo 8948 if (DDELog || !IsFileVarNULL()) {
991 maya 3227 EnableMenuItem(ControlMenu,ID_CONTROL_MACRO,MF_BYCOMMAND | MF_GRAYED);
992 maya 3842 EnableMenuItem(ControlMenu,ID_CONTROL_SHOW_MACRO,MF_BYCOMMAND | MF_ENABLED);
993 maya 3392 }
994     else {
995 yutakapon 3837 EnableMenuItem(ControlMenu,ID_CONTROL_MACRO,MF_BYCOMMAND | MF_ENABLED);
996 maya 3842 EnableMenuItem(ControlMenu,ID_CONTROL_SHOW_MACRO,MF_BYCOMMAND | MF_GRAYED);
997 maya 3392 }
998 maya 3227
999     }
1000     else if (SubMenu == WinMenu)
1001     {
1002 yutakapon 5249 SetWinMenu(WinMenu, ts.UIMsg, sizeof(ts.UIMsg), ts.UILanguageFile, 1);
1003 maya 3227 }
1004    
1005     TTXModifyPopupMenu(SubMenu); /* TTPLUG */
1006     }
1007    
1008     // added ConfirmPasteMouseRButton (2007.3.17 maya)
1009     void CVTWindow::InitPasteMenu(HMENU *Menu)
1010     {
1011 doda 8445 static const DlgTextInfo MenuTextInfo[] = {
1012     { ID_EDIT_PASTE2, "MENU_EDIT_PASTE" },
1013     { ID_EDIT_PASTECR, "MENU_EDIT_PASTECR" },
1014     };
1015 zmatsuo 7916 *Menu = LoadMenu(m_hInst,
1016 maya 3227 MAKEINTRESOURCE(IDR_PASTEMENU));
1017 zmatsuo 9350 SetDlgMenuTextsW(*Menu, MenuTextInfo, _countof(MenuTextInfo), ts.UILanguageFileW);
1018 maya 3227 }
1019    
1020     void CVTWindow::ResetSetup()
1021     {
1022     ChangeFont();
1023     BuffChangeWinSize(WinWidth,WinHeight);
1024     ChangeCaret();
1025    
1026     if (cv.Ready) {
1027     ts.PortType = cv.PortType;
1028     if (cv.PortType==IdSerial) {
1029     /* if serial port, change port parameters */
1030     ts.ComPort = cv.ComPort;
1031     CommResetSerial(&ts, &cv, TRUE);
1032     }
1033     }
1034    
1035     /* setup terminal */
1036     SetupTerm();
1037    
1038     /* background and ANSI color */
1039 zmatsuo 10134
1040     #if 0
1041     // �N�������������������e�[�}����������������������������
1042 yutakapon 8106 BGInitialize(FALSE);
1043 maya 3227 BGSetupPrimary(TRUE);
1044 zmatsuo 10134 #endif
1045    
1046 maya 3227 // 2006/03/17 by 337 : Alpha�l���������X
1047     // Layered��������������������������������
1048 yutakapon 6553 //
1049     // AlphaBlend ���������f�����������������B
1050     // (2016.12.24 yutaka)
1051 zmatsuo 7390 SetWindowAlpha(ts.AlphaBlendActive);
1052 maya 3227
1053     /* setup window */
1054     ChangeWin();
1055    
1056     /* Language & IME */
1057     ResetIME();
1058    
1059     /* change TEK window */
1060     if (pTEKWin != NULL)
1061     ((CTEKWindow *)pTEKWin)->RestoreSetup();
1062     }
1063    
1064     void CVTWindow::RestoreSetup()
1065     {
1066     char TempDir[MAXPATHLEN];
1067 maya 4031 char TempName[MAX_PATH];
1068 maya 3227
1069 maya 3392 if ( strlen(ts.SetupFName)==0 ) {
1070 maya 3227 return;
1071 maya 3392 }
1072 maya 3227
1073     ExtractFileName(ts.SetupFName,TempName,sizeof(TempName));
1074     ExtractDirName(ts.SetupFName,TempDir);
1075     if (TempDir[0]==0)
1076     strncpy_s(TempDir, sizeof(TempDir),ts.HomeDir, _TRUNCATE);
1077     FitFileName(TempName,sizeof(TempName),".INI");
1078    
1079     strncpy_s(ts.SetupFName, sizeof(ts.SetupFName),TempDir, _TRUNCATE);
1080     AppendSlash(ts.SetupFName,sizeof(ts.SetupFName));
1081 maya 3392 strncat_s(ts.SetupFName,sizeof(ts.SetupFName),TempName,_TRUNCATE);
1082 maya 3227
1083 maya 3392 if (LoadTTSET()) {
1084 zmatsuo 9429 (*ReadIniFile)(ts.SetupFNameW, &ts);
1085 maya 3392 }
1086 maya 3227 FreeTTSET();
1087    
1088     ResetSetup();
1089     }
1090    
1091     /* called by the [Setup] Terminal command */
1092     void CVTWindow::SetupTerm()
1093     {
1094 zmatsuo 9314 // if (ts.Language==IdJapanese || ts.Language==IdKorean || ts.Language==IdUtf8) {
1095 maya 3227 ResetCharSet();
1096 zmatsuo 9314 // }
1097 maya 3227 cv.CRSend = ts.CRSend;
1098    
1099 doda 3932 if (cv.Ready) {
1100     if (cv.TelFlag && (ts.TelEcho>0)) {
1101     TelChangeEcho();
1102     }
1103 maya 3392 }
1104 maya 3227
1105     if ((ts.TerminalWidth!=NumOfColumns) ||
1106     (ts.TerminalHeight!=NumOfLines-StatusLine)) {
1107     LockBuffer();
1108     HideStatusLine();
1109     ChangeTerminalSize(ts.TerminalWidth,
1110     ts.TerminalHeight);
1111     UnlockBuffer();
1112     }
1113     else if ((ts.TermIsWin>0) &&
1114     ((ts.TerminalWidth!=WinWidth) ||
1115 maya 3392 (ts.TerminalHeight!=WinHeight-StatusLine))) {
1116 maya 3227 BuffChangeWinSize(ts.TerminalWidth,ts.TerminalHeight+StatusLine);
1117 maya 3392 }
1118 doda 4246
1119     ChangeTerminalID();
1120 maya 3227 }
1121    
1122     void CVTWindow::Startup()
1123     {
1124     /* auto log */
1125     /* OnCommOpen ���J�n�������������������J�n������ (2007.5.14 maya) */
1126    
1127     if ((TopicName[0]==0) && (ts.MacroFN[0]!=0)) {
1128     // start the macro specified in the command line or setup file
1129     RunMacro(ts.MacroFN,TRUE);
1130     ts.MacroFN[0] = 0;
1131     }
1132     else {// start connection
1133 maya 3392 if (TopicName[0]!=0) {
1134 maya 3227 cv.NoMsg=1; /* suppress error messages */
1135 maya 3392 }
1136 maya 3227 ::PostMessage(HVTWin,WM_USER_COMMSTART,0,0);
1137     }
1138     }
1139    
1140     void CVTWindow::OpenTEK()
1141     {
1142     ActiveWin = IdTEK;
1143     if (HTEKWin==NULL) {
1144 zmatsuo 7916 pTEKWin = new CTEKWindow(m_hInst);
1145 maya 3227 }
1146     else {
1147     ::ShowWindow(HTEKWin,SW_SHOWNORMAL);
1148     ::SetFocus(HTEKWin);
1149     }
1150     }
1151    
1152     /////////////////////////////////////////////////////////////////////////////
1153     // CVTWindow message handler
1154    
1155     BOOL CVTWindow::OnCommand(WPARAM wParam, LPARAM lParam)
1156     {
1157     WORD wID = LOWORD(wParam);
1158     WORD wNotifyCode = HIWORD(wParam);
1159    
1160     if (wNotifyCode==1) {
1161     switch (wID) {
1162     case ID_ACC_SENDBREAK:
1163     // added DisableAcceleratorSendBreak (2007.3.17 maya)
1164     if (!ts.DisableAcceleratorSendBreak)
1165     OnControlSendBreak();
1166     return TRUE;
1167     case ID_ACC_AREYOUTHERE:
1168     OnControlAreYouThere();
1169     return TRUE;
1170     }
1171     if (ActiveWin==IdVT) {
1172     switch (wID) {
1173     case ID_ACC_NEWCONNECTION:
1174 maya 5684 if (ts.AcceleratorNewConnection)
1175     OnFileNewConnection();
1176 maya 3227 return TRUE;
1177 maya 5691 case ID_ACC_DUPLICATESESSION:
1178     // added DisableAcceleratorDuplicateSession (2009.4.6 maya)
1179     if (!ts.DisableAcceleratorDuplicateSession)
1180     OnDuplicateSession();
1181     return TRUE;
1182 maya 5684 case ID_ACC_CYGWINCONNECTION:
1183     if (ts.AcceleratorCygwinConnection)
1184     OnCygwinConnection();
1185     return TRUE;
1186 maya 5691 case ID_ACC_DISCONNECT:
1187     Disconnect(TRUE);
1188     return TRUE;
1189 maya 3227 case ID_ACC_COPY:
1190     OnEditCopy();
1191     return TRUE;
1192 doda 6459 case ID_ACC_PASTECR:
1193     OnEditPasteCR();
1194     return TRUE;
1195     case ID_ACC_PASTE:
1196     OnEditPaste();
1197     return TRUE;
1198 maya 3227 case ID_ACC_PRINT:
1199     OnFilePrint();
1200     return TRUE;
1201     case ID_ACC_EXIT:
1202     OnFileExit();
1203     return TRUE;
1204     }
1205     }
1206     else { // transfer accelerator message to TEK win
1207     switch (wID) {
1208     case ID_ACC_COPY:
1209     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKEDIT_COPY,0);
1210     return TRUE;
1211 doda 6459 case ID_ACC_PASTECR:
1212     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKEDIT_PASTECR,0);
1213     return TRUE;
1214     case ID_ACC_PASTE:
1215     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKEDIT_PASTE,0);
1216     return TRUE;
1217 maya 3227 case ID_ACC_PRINT:
1218     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKFILE_PRINT,0);
1219     return TRUE;
1220     case ID_ACC_EXIT:
1221     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKFILE_EXIT,0);
1222     return TRUE;
1223     }
1224     }
1225     }
1226    
1227     if ((wID>=ID_WINDOW_1) && (wID<ID_WINDOW_1+9)) {
1228     SelectWin(wID-ID_WINDOW_1);
1229     return TRUE;
1230     }
1231     else {
1232 maya 3392 if (TTXProcessCommand(HVTWin, wID)) {
1233 maya 3227 return TRUE;
1234 maya 3392 }
1235     else { /* TTPLUG */
1236 zmatsuo 7784 return TTCFrameWnd::OnCommand(wParam, lParam);
1237 maya 3392 }
1238 maya 3227 }
1239     }
1240    
1241 zmatsuo 7528 void CVTWindow::OnActivate(UINT nState, HWND pWndOther, BOOL bMinimized)
1242 maya 3227 {
1243     DispSetActive(nState!=WA_INACTIVE);
1244 zmatsuo 7390 if (nState == WA_INACTIVE) {
1245     SetWindowAlpha(ts.AlphaBlendInactive);
1246     } else {
1247     SetWindowAlpha(ts.AlphaBlendActive);
1248     }
1249 maya 3227 }
1250    
1251 zmatsuo 9143 /**
1252     * �L�[�{�[�h����1��������
1253     * @param nChar UTF-16 char(wchar_t) IsWindowUnicode() == TRUE ��
1254     * ANSI char(char) IsWindowUnicode() == FALSE ��
1255     */
1256 zmatsuo 8337 void CVTWindow::OnChar(WPARAM nChar, UINT nRepCnt, UINT nFlags)
1257 maya 3227 {
1258     unsigned int i;
1259    
1260 maya 3392 if (!KeybEnabled || (TalkStatus!=IdTalkKeyb)) {
1261 maya 3227 return;
1262 maya 3392 }
1263 maya 3227
1264 doda 4414 if (MetaKey(ts.MetaKey)) {
1265 maya 3227 ::PostMessage(HVTWin,WM_SYSCHAR,nChar,MAKELONG(nRepCnt,nFlags));
1266     return;
1267     }
1268    
1269 zmatsuo 9143 wchar_t u16;
1270     if (IsWindowUnicode(HVTWin) == TRUE) {
1271     // ������ UTF-16
1272     u16 = (wchar_t)nChar;
1273     } else {
1274 zmatsuo 9150 // ������ ANSI
1275 zmatsuo 9500 if (ts.Language == IdJapanese || ts.Language == IdChinese || ts.Language == IdKorean) {
1276     // CJK (2byte����)
1277     if (vtwin_work.dbcs_lead_byte == 0 && IsDBCSLeadByte(nChar)) {
1278     // ANSI 2�o�C�g������ 1byte��������
1279     // ������ WM_IME_* ���b�Z�[�W������������
1280     // ������������������������
1281     // TERATERM.INI �� IME=off ������
1282     // imm32.dll �����[�h����������������
1283     vtwin_work.dbcs_lead_byte = nChar;
1284     return;
1285     }
1286     else {
1287     // ANSI(ACP) -> UTF-32 -> UTF-16
1288     char mb_str[2];
1289     size_t mb_len;
1290     if (vtwin_work.dbcs_lead_byte == 0) {
1291     // 1�o�C�g����
1292     mb_str[0] = (char)nChar;
1293     mb_len = 1;
1294     }
1295     else {
1296     // 2�o�C�g����
1297     mb_str[0] = (char)vtwin_work.dbcs_lead_byte;
1298     mb_str[1] = (char)nChar;
1299     mb_len = 2;
1300     vtwin_work.dbcs_lead_byte = 0;
1301     }
1302     unsigned int u32;
1303     mb_len = MBCPToUTF32(mb_str, mb_len, CP_ACP, &u32);
1304     if (mb_len == 0) {
1305     return;
1306     }
1307     u16 = (wchar_t)u32;
1308     }
1309 zmatsuo 9143 }
1310 zmatsuo 9500 else if (ts.Language == IdRussian) {
1311     BYTE c;
1312     if (ts.RussKeyb == IdWindows) {
1313     // key = CP1251
1314     c = (char)nChar;
1315 zmatsuo 9383 }
1316     else {
1317 zmatsuo 9500 // key -> CP1251
1318     c = RussConv(ts.RussKeyb, IdWindows, nChar);
1319 zmatsuo 9383 }
1320 zmatsuo 9500 // CP1251 -> UTF-32 -> UTF-16
1321     unsigned long u32 = MBCP_UTF32(c, 1251);
1322 zmatsuo 9383 u16 = (wchar_t)u32;
1323     }
1324 zmatsuo 9500 else {
1325     u16 = (wchar_t)nChar;
1326     }
1327 zmatsuo 9143 }
1328    
1329     // �o�b�t�@���o���A�������o��
1330 maya 3227 for (i=1 ; i<=nRepCnt ; i++) {
1331 doda 8445 CommTextOutW(&cv,&u16,1);
1332 maya 3392 if (ts.LocalEcho>0) {
1333 doda 8445 CommTextEchoW(&cv,&u16,1);
1334 maya 3392 }
1335 maya 3227 }
1336    
1337 doda 6421 // �X�N���[�����u�����Z�b�g
1338     if (WinOrgY != 0) {
1339 maya 3227 DispVScroll(SCROLL_BOTTOM, 0);
1340     }
1341     }
1342    
1343 zmatsuo 8827 LRESULT CVTWindow::OnUniChar(WPARAM wParam, LPARAM lParam)
1344     {
1345     if (wParam == UNICODE_NOCHAR) {
1346     // �������b�Z�[�W���T�|�[�g�����������e�X�g��������������������
1347     return TRUE;
1348     }
1349    
1350     char32_t u32 = (char32_t)wParam;
1351     wchar_t strW[2];
1352     size_t u16_len = UTF32ToUTF16(u32, strW, _countof(strW));
1353     CommTextOutW(&cv, strW, u16_len);
1354     if (ts.LocalEcho > 0) {
1355     CommTextEchoW(&cv, strW, u16_len);
1356     }
1357    
1358     return FALSE;
1359     }
1360    
1361 maya 3227 /* copy from ttset.c*/
1362 zmatsuo 8463 static void WriteInt2(const char *Sect, const char *Key, const char *FName, int i1, int i2)
1363 maya 3227 {
1364     char Temp[32];
1365     _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d,%d", i1, i2);
1366     WritePrivateProfileString(Sect, Key, Temp, FName);
1367     }
1368    
1369     static void SaveVTPos()
1370     {
1371     #define Section "Tera Term"
1372     if (ts.SaveVTWinPos) {
1373     /* VT win position */
1374     WriteInt2(Section, "VTPos", ts.SetupFName, ts.VTPos.x, ts.VTPos.y);
1375    
1376     /* VT terminal size */
1377     WriteInt2(Section, "TerminalSize", ts.SetupFName,
1378     ts.TerminalWidth, ts.TerminalHeight);
1379     }
1380     }
1381    
1382     void CVTWindow::OnClose()
1383     {
1384     if ((HTEKWin!=NULL) && ! ::IsWindowEnabled(HTEKWin)) {
1385     MessageBeep(0);
1386     return;
1387     }
1388 zmatsuo 8479
1389 maya 3227 if (cv.Ready && (cv.PortType==IdTCPIP) &&
1390     ((ts.PortFlag & PF_CONFIRMDISCONN) != 0) &&
1391 zmatsuo 8479 ! CloseTT) {
1392 zmatsuo 9351 static const TTMessageBoxInfoW info = {
1393     "Tera Term",
1394     NULL, L"Tera Term",
1395     "MSG_DISCONNECT_CONF", L"Disconnect?",
1396     MB_OKCANCEL | MB_ICONEXCLAMATION | MB_DEFBUTTON2
1397     };
1398     int result = TTMessageBoxW(HVTWin, &info, ts.UILanguageFileW);
1399 zmatsuo 8479 if (result == IDCANCEL) {
1400     return;
1401     }
1402 maya 3392 }
1403 maya 3227
1404 zmatsuo 8900 FLogClose();
1405 zmatsuo 9067 FileSendEnd();
1406 maya 3227 ProtoEnd();
1407    
1408     SaveVTPos();
1409 zmatsuo 10394 Notify2UnsetWindow((NotifyIcon *)cv.NotifyIcon);
1410 nmaya 10009
1411     // �A�v���P�[�V�����I�������A�C�R�����j���������A�E�B���h�E���������O��
1412     // �^�C�g���o�[���A�C�R���� "Windows �����s�t�@�C�����A�C�R��" ��������
1413     // ���������������j��������
1414     // TTSetIcon(m_hInst, m_hWnd, NULL, 0);
1415    
1416 maya 3227 DestroyWindow();
1417     }
1418    
1419 yutakapon 5232 // �STera Term���I�����w������
1420     void CVTWindow::OnAllClose()
1421     {
1422 yutakapon 5351 // ���R�I���������������������A�����������[�U���������������o�������������B
1423 zmatsuo 9351 static const TTMessageBoxInfoW info = {
1424     "Tera Term",
1425     NULL, L"Tera Term",
1426     "MSG_ALL_TERMINATE_CONF", L"Terminate ALL Tera Term(s)?",
1427     MB_OKCANCEL | MB_ICONERROR | MB_DEFBUTTON2
1428     };
1429     int result = TTMessageBoxW(HVTWin, &info, ts.UILanguageFileW);
1430     if (result == IDCANCEL)
1431 yutakapon 5351 return;
1432    
1433 yutakapon 5232 BroadcastClosingMessage(HVTWin);
1434     }
1435    
1436     // �I������������������Tera Term���I�������BOnAllClose()���M�p�B
1437 zmatsuo 7896 LRESULT CVTWindow::OnNonConfirmClose(WPARAM wParam, LPARAM lParam)
1438 yutakapon 5232 {
1439     // ������ ts �����e�����}�I���������������A�I�����������Z�[�u�����������������������A�������������B
1440     ts.PortFlag &= ~PF_CONFIRMDISCONN;
1441     OnClose();
1442     return 1;
1443     }
1444    
1445 maya 3227 void CVTWindow::OnDestroy()
1446     {
1447     // remove this window from the window list
1448     UnregWin(HVTWin);
1449    
1450 salarm 6100 // USB�f�o�C�X�������m����
1451     UnRegDeviceNotify(HVTWin);
1452    
1453 maya 3227 EndKeyboard();
1454    
1455     /* Disable drag-drop */
1456     ::DragAcceptFiles(HVTWin,FALSE);
1457 zmatsuo 7148 DropListFree();
1458 maya 3227
1459     EndDDE();
1460    
1461 maya 3392 if (cv.TelFlag) {
1462 maya 3227 EndTelnet();
1463 maya 3392 }
1464 maya 3227 CommClose(&cv);
1465    
1466 zmatsuo 7485 FreeIME(HVTWin);
1467 maya 3227 FreeTTSET();
1468    
1469 zmatsuo 9055 #if 0
1470 maya 3227 do { }
1471 maya 3392 while (FreeTTFILE());
1472 zmatsuo 9055 #endif
1473 maya 3227
1474 maya 3392 if (HTEKWin != NULL) {
1475 maya 3227 ::DestroyWindow(HTEKWin);
1476 maya 3392 }
1477 maya 3227
1478 doda 3450 EndTerm();
1479 maya 3227 EndDisp();
1480    
1481     FreeBuffer();
1482    
1483     TTXEnd(); /* TTPLUG */
1484 doda 6662
1485 zmatsuo 10102 TTSetUnInit(&ts);
1486    
1487 zmatsuo 10394 Notify2Uninitialize((NotifyIcon *)cv.NotifyIcon);
1488     cv.NotifyIcon = NULL;
1489 zmatsuo 10402
1490     DropUninit();
1491 maya 3227 }
1492    
1493 doda 8445 static void EscapeFilename(const wchar_t *src, wchar_t *dest)
1494 maya 3227 {
1495 doda 8445 #define ESCAPE_CHARS L" ;&()$!`'[]{}#^~"
1496     const wchar_t *s = src;
1497     wchar_t *d = dest;
1498 zmatsuo 7148 while (*s) {
1499 doda 8445 wchar_t c = *s++;
1500     if (c == L'\\') {
1501 zmatsuo 7148 // �p�X���������� \ -> / ��
1502     *d = '/';
1503 doda 8445 } else if (wcschr(ESCAPE_CHARS, c) != NULL) {
1504 zmatsuo 7148 // �G�X�P�[�v���K�v������
1505 doda 8445 *d++ = L'\\';
1506 zmatsuo 7148 *d = c;
1507     } else {
1508     *d = c;
1509     }
1510     d++;
1511     }
1512     *d = '\0'; // null-terminate
1513     }
1514 maya 3227
1515 zmatsuo 9175 static wchar_t *GetPasteString(const wchar_t *str, bool escape)
1516 zmatsuo 7148 {
1517 doda 8445 wchar_t *tmpbuf;
1518     if (!escape) {
1519     tmpbuf = _wcsdup(str);
1520     }
1521     else {
1522     const size_t len = wcslen(str) * sizeof(wchar_t) * 2;
1523     tmpbuf = (wchar_t *)malloc(len);
1524 zmatsuo 7148 EscapeFilename(str, tmpbuf);
1525     }
1526 zmatsuo 9175 return tmpbuf;
1527 zmatsuo 7148 }
1528 yutakapon 4891
1529 zmatsuo 7148 /* �������t�@�C������(�t�H���_������������) */
1530 zmatsuo 10402 /**
1531     * SCP���t�@�C��������
1532     * @param Filenames �t�@�C����(����)
1533     * �t�H���_����������,�t�@�C������
1534     * @param FileCount �t�@�C����(������1���O���g������)
1535     * @param SendDir ���M�t�H���_
1536     *
1537     */
1538 doda 8445 static bool SendScp(wchar_t *Filenames[], int FileCount, const char *SendDir)
1539 zmatsuo 7148 {
1540 zmatsuo 10402 for (int i = 0; i < FileCount; i++) {
1541     char *FileName = ToU8W(Filenames[i]);
1542     BOOL r = ScpSend(FileName, ts.ScpSendDir);
1543     free(FileName);
1544     if (r == FALSE) {
1545     ::MessageBoxA(HVTWin, "scp send error", "Tera Term: error", MB_OK | MB_ICONERROR);
1546 zmatsuo 7148 return false;
1547     }
1548     }
1549     return true;
1550     }
1551 doda 6620
1552 zmatsuo 7148 void CVTWindow::DropListFree()
1553     {
1554     if (DropListCount > 0) {
1555     for (int i = 0; i < DropListCount; i++) {
1556     free(DropLists[i]);
1557     DropLists[i] = NULL;
1558     }
1559     free(DropLists);
1560     DropLists = NULL;
1561     DropListCount = 0;
1562     }
1563     }
1564 yutakapon 4891
1565 zmatsuo 10400 typedef struct DropData_tag {
1566     // ini���������������A�����s��������Tera Term�������L��������
1567     enum drop_type DefaultDropType;
1568     unsigned char DefaultDropTypePaste;
1569     bool DefaultShowDialog;
1570     bool TransBin;
1571     bool DoSameProcess;
1572     enum drop_type DropType;
1573     unsigned char DropTypePaste;
1574    
1575     HWND vtwin;
1576 zmatsuo 10402 UINT_PTR PollingTimerID;
1577 zmatsuo 10400
1578     int FileCount;
1579     int DirectoryCount;
1580     int SendIndex;
1581     } DropData_t;
1582    
1583 nmaya 10093 /**
1584 zmatsuo 10400 * ������
1585     */
1586 zmatsuo 10402 void CVTWindow::DropInit()
1587 zmatsuo 10400 {
1588     DropData_t *data =(DropData_t *)calloc(sizeof(*data), 1);
1589     data->DefaultDropType = DROP_TYPE_CANCEL;
1590     data->DefaultDropTypePaste = DROP_TYPE_PASTE_ESCAPE;
1591     data->DefaultShowDialog = ts.ConfirmFileDragAndDrop ? true : false;
1592     data->vtwin = HVTWin;
1593 zmatsuo 10402
1594     DropData = data;
1595 zmatsuo 10400 }
1596    
1597 zmatsuo 10402 void CVTWindow::DropUninit()
1598     {
1599     free(DropData);
1600     DropData = NULL;
1601     }
1602    
1603 zmatsuo 10400 /**
1604     * ���M�����R�[���o�b�N
1605     */
1606     static void DropSendCallback(void *callback_data)
1607     {
1608     DropData_t *data = (DropData_t *)callback_data;
1609     // �������M���s��
1610     ::PostMessage(data->vtwin, WM_USER_DROPNOTIFY, 0, 1);
1611     }
1612    
1613     /**
1614 zmatsuo 10402 * �^�C�}�[��SCP�����M�������`�F�b�N
1615     */
1616     static void CALLBACK DropSendTimerProc(HWND, UINT, UINT_PTR nIDEvent, DWORD)
1617     {
1618     DropData_t *data = (DropData_t *)nIDEvent;
1619    
1620     // ���M��?
1621     if (ScpGetStatus() == TRUE) {
1622     // �����^�C�}�[�C���^�[�o�������x�`�F�b�N
1623     return;
1624     }
1625    
1626     assert(data->PollingTimerID != 0);
1627     BOOL r = KillTimer(HVTWin, data->PollingTimerID);
1628     assert(r == 1); (void)r;
1629     data->PollingTimerID = 0;
1630    
1631     // �������M���s��
1632     ::PostMessage(data->vtwin, WM_USER_DROPNOTIFY, 0, 1);
1633     }
1634    
1635     /**
1636 zmatsuo 10400 * �t�@�C�����h���b�v���m
1637     * @param lparam 0 �t�@�C�����h���b�v������
1638     * ShowDialog���Q��������
1639     * 1 �t�@�C�����]������������
1640 nmaya 10093 * @param ShowDialog 0 �\���������\����������������
1641     * 1 �K���\������
1642     */
1643 zmatsuo 10400 LRESULT CVTWindow::OnDropNotify(WPARAM ShowDialog, LPARAM lparam)
1644 zmatsuo 7148 {
1645 zmatsuo 10400 DropData_t *data = DropData;
1646 doda 6620
1647 zmatsuo 10400 switch (lparam) {
1648     case 0: {
1649     data->FileCount = 0;
1650     data->DirectoryCount = 0;
1651     for (int i = 0; i < DropListCount; i++) {
1652     const wchar_t *FileName = DropLists[i];
1653     const DWORD attr = GetFileAttributesW(FileName);
1654     if (attr == INVALID_FILE_ATTRIBUTES) {
1655     data->FileCount++;
1656     } else if (attr & FILE_ATTRIBUTE_DIRECTORY) {
1657     data->DirectoryCount++;
1658     } else {
1659     data->FileCount++;
1660     }
1661 zmatsuo 7148 }
1662 yutakapon 4891
1663 zmatsuo 10400 data->DoSameProcess = false;
1664     const bool isSSH = (cv.isSSH == 2);
1665     data->DropTypePaste = DROP_TYPE_PASTE_ESCAPE;
1666     if (data->DefaultDropType == DROP_TYPE_CANCEL) {
1667     // default is not set
1668     data->TransBin = ts.TransBin == 0 ? false : true;
1669     if (!ShowDialog) {
1670     if (data->FileCount == 1 && data->DirectoryCount == 0) {
1671     if (ts.ConfirmFileDragAndDrop) {
1672     if (isSSH) {
1673     data->DropType = DROP_TYPE_SCP;
1674     } else {
1675     data->DropType = DROP_TYPE_SEND_FILE;
1676     }
1677     data->DoSameProcess = false;
1678     } else {
1679     data->DropType = DROP_TYPE_SEND_FILE;
1680     data->DoSameProcess = data->DefaultShowDialog ? false : true;
1681     }
1682     }
1683     else if (data->FileCount == 0 && data->DirectoryCount == 1) {
1684     data->DropType = DROP_TYPE_PASTE_FILENAME;
1685     data->DoSameProcess = data->DefaultShowDialog ? false : true;
1686     }
1687     else if (data->FileCount > 0 && data->DirectoryCount > 0) {
1688     data->DropType = DROP_TYPE_PASTE_FILENAME;
1689     data->DoSameProcess = false;
1690     }
1691     else if (data->FileCount > 0 && data->DirectoryCount == 0) {
1692     // filename only
1693 zmatsuo 7148 if (isSSH) {
1694 zmatsuo 10400 data->DropType = DROP_TYPE_SCP;
1695 zmatsuo 7148 } else {
1696 zmatsuo 10400 data->DropType = DROP_TYPE_SEND_FILE;
1697 yutakapon 4891 }
1698 zmatsuo 10400 data->DoSameProcess = false;
1699 zmatsuo 7148 } else {
1700 zmatsuo 10400 // directory only
1701     data->DropType = DROP_TYPE_PASTE_FILENAME;
1702     data->DoSameProcess = ts.ConfirmFileDragAndDrop ? false : true;
1703 zmatsuo 7148 }
1704 zmatsuo 10400 } else {
1705     // show dialog
1706     if (data->DirectoryCount > 0) {
1707     data->DropType = DROP_TYPE_PASTE_FILENAME;
1708 zmatsuo 7148 } else {
1709 zmatsuo 10400 if (isSSH) {
1710     data->DropType = DROP_TYPE_SCP;
1711     } else {
1712     data->DropType = DROP_TYPE_SEND_FILE;
1713     }
1714 zmatsuo 7148 }
1715 zmatsuo 10400 data->DoSameProcess = false;
1716 zmatsuo 7148 }
1717     } else {
1718 zmatsuo 10400 if (data->DirectoryCount > 0 &&
1719     (data->DefaultDropType == DROP_TYPE_SEND_FILE ||
1720     data->DefaultDropType == DROP_TYPE_SCP))
1721     { // �f�t�H���g�����������������������g��������
1722     data->DropType = DROP_TYPE_PASTE_FILENAME;
1723     data->DropTypePaste = data->DefaultDropTypePaste;
1724     data->DoSameProcess = false;
1725 zmatsuo 7148 } else {
1726 zmatsuo 10400 data->DropType = data->DefaultDropType;
1727     data->DropTypePaste = data->DefaultDropTypePaste;
1728     data->DoSameProcess = (ShowDialog || data->DefaultShowDialog) ? false : true;
1729 zmatsuo 7148 }
1730     }
1731 zmatsuo 10400
1732     data->SendIndex = 0;
1733     // break;
1734     // FALLTHROUGH
1735     }
1736     case 1:
1737     next_file: {
1738     if (data->SendIndex == DropListCount) {
1739     // ���������M����
1740     goto finish;
1741 zmatsuo 7148 }
1742 zmatsuo 10400 int i = data->SendIndex;
1743     data->SendIndex++;
1744 doda 8445 const wchar_t *FileName = DropLists[i];
1745 yutakapon 4891
1746 zmatsuo 10400 if (!data->DoSameProcess) {
1747     const bool isSSH = (cv.isSSH == 2);
1748 zmatsuo 7148 bool DoSameProcessNextDrop;
1749 zmatsuo 10400 bool DoNotShowDialog = !data->DefaultShowDialog;
1750 zmatsuo 10150 SetDialogFont(ts.DialogFontNameW, ts.DialogFontPoint, ts.DialogFontCharSet,
1751     ts.UILanguageFileW, "Tera Term", "DLG_SYSTEM_FONT");
1752 zmatsuo 10400 data->DropType =
1753     ShowDropDialogBox(m_hInst, HVTWin, FileName, data->DropType,
1754 zmatsuo 7148 DropListCount - i,
1755 zmatsuo 10400 (data->DirectoryCount == 0 && isSSH) ? true : false, data->DirectoryCount == 0 ? true : false,
1756     &data->TransBin,
1757 zmatsuo 7172 &ts,
1758 zmatsuo 10400 &data->DropTypePaste, &data->DoSameProcess,
1759 zmatsuo 7148 &DoSameProcessNextDrop,
1760     &DoNotShowDialog);
1761 zmatsuo 10400 if (data->DropType == DROP_TYPE_CANCEL) {
1762 zmatsuo 7148 goto finish;
1763     }
1764     if (DoSameProcessNextDrop) {
1765 zmatsuo 10400 data->DefaultDropType = data->DropType;
1766 zmatsuo 7148 }
1767     if (!ts.ConfirmFileDragAndDrop) {
1768 zmatsuo 10400 data->DefaultShowDialog = !DoNotShowDialog;
1769 zmatsuo 7148 }
1770     }
1771 zmatsuo 7322
1772 zmatsuo 10400 switch (data->DropType) {
1773 zmatsuo 7148 case DROP_TYPE_CANCEL:
1774     default:
1775     // cancel
1776     break;
1777 zmatsuo 10400 case DROP_TYPE_SEND_FILE: {
1778     if (!data->TransBin) {
1779     SendMemSendFile2(FileName, FALSE, SENDMEM_DELAYTYPE_NO_DELAY, 0, 0, DropSendCallback, data);
1780 nmaya 10093 }
1781     else {
1782 zmatsuo 10400 SendMemSendFile2(FileName, TRUE, SENDMEM_DELAYTYPE_NO_DELAY, 0, 0, DropSendCallback, data);
1783 nmaya 10093 }
1784 zmatsuo 8449 break;
1785 zmatsuo 10400 }
1786 zmatsuo 7148 case DROP_TYPE_PASTE_FILENAME:
1787     {
1788 zmatsuo 10400 const bool escape = (data->DropTypePaste & DROP_TYPE_PASTE_ESCAPE) ? true : false;
1789 doda 7195
1790 zmatsuo 10400 data->DefaultDropTypePaste = data->DropTypePaste;
1791 nmaya 10093
1792 doda 7195 TermSendStartBracket();
1793    
1794 zmatsuo 9175 wchar_t *str = GetPasteString(FileName, escape);
1795     TermPasteStringNoBracket(str, wcslen(str));
1796     free(str);
1797 zmatsuo 7148 if (DropListCount > 1 && i < DropListCount - 1) {
1798 zmatsuo 10400 if (data->DropTypePaste & DROP_TYPE_PASTE_NEWLINE) {
1799 zmatsuo 9175 TermPasteStringNoBracket(L"\x0d", 1); // ���s(CR,0x0d)
1800     }
1801     else {
1802     TermPasteStringNoBracket(L" ", 1); // space
1803     }
1804 zmatsuo 7148 }
1805 doda 7195
1806     TermSendEndBracket();
1807    
1808 zmatsuo 10400 // �����t�@�C����������
1809     goto next_file;
1810 zmatsuo 7148 }
1811     case DROP_TYPE_SCP:
1812     {
1813 zmatsuo 10402 // send by scp
1814     wchar_t **FileNames = &DropLists[i];
1815     int FileCount = 1;
1816     if (!SendScp(FileNames, FileCount, ts.ScpSendDir)) {
1817     // ���M�G���[
1818 zmatsuo 7148 goto finish;
1819     }
1820 youlab 9554
1821 zmatsuo 10402 data->PollingTimerID = SetTimer(HVTWin, (UINT_PTR)data, 100, DropSendTimerProc);
1822     break;
1823 youlab 9554
1824 zmatsuo 7148 }
1825     }
1826 zmatsuo 10402 break;
1827 zmatsuo 7148 }
1828 zmatsuo 10400 case 2:
1829     default:
1830     finish:
1831     // �I������
1832     DropListFree();
1833     break;
1834     }
1835 yutakapon 4891
1836 zmatsuo 7148 return 0;
1837 maya 3227 }
1838    
1839     void CVTWindow::OnDropFiles(HDROP hDropInfo)
1840     {
1841     ::SetForegroundWindow(HVTWin);
1842 zmatsuo 8948 if (cv.Ready && IsSendVarNULL())
1843 maya 3227 {
1844 zmatsuo 7148 const UINT ShowDialog =
1845     ((GetAsyncKeyState(VK_CONTROL) & 0x8000) != 0) ? 1 : 0;
1846 zmatsuo 9324 DropListCount = DragQueryFileW(hDropInfo, -1, NULL, 0);
1847 doda 8445 DropLists = (wchar_t **)malloc(sizeof(wchar_t *) * DropListCount);
1848 maya 3227
1849 zmatsuo 7148 for (int i = 0; i < DropListCount; i++) {
1850 zmatsuo 9324 const UINT cch = DragQueryFileW(hDropInfo, i, NULL, 0);
1851 doda 8445 if (cch == 0) {
1852     continue;
1853     }
1854     wchar_t *FileName = (wchar_t *)malloc(sizeof(wchar_t) * (cch + 1));
1855 zmatsuo 9324 DragQueryFileW(hDropInfo,i,FileName,cch + 1);
1856 doda 8445 FileName[cch] = '\0';
1857 zmatsuo 7148 DropLists[i] = FileName;
1858     }
1859 maya 3227
1860 zmatsuo 7148 ::PostMessage(HVTWin, WM_USER_DROPNOTIFY, ShowDialog, 0);
1861 maya 3227 }
1862     DragFinish(hDropInfo);
1863     }
1864    
1865 doda 6801 void CVTWindow::OnGetMinMaxInfo(MINMAXINFO *lpMMI)
1866 maya 3227 {
1867     #ifndef WINDOW_MAXMIMUM_ENABLED
1868     lpMMI->ptMaxSize.x = 10000;
1869     lpMMI->ptMaxSize.y = 10000;
1870     lpMMI->ptMaxTrackSize.x = 10000;
1871     lpMMI->ptMaxTrackSize.y = 10000;
1872     #endif
1873     }
1874    
1875 zmatsuo 7528 void CVTWindow::OnHScroll(UINT nSBCode, UINT nPos, HWND pScrollBar)
1876 maya 3227 {
1877     int Func;
1878    
1879     switch (nSBCode) {
1880     case SB_BOTTOM:
1881     Func = SCROLL_BOTTOM;
1882     break;
1883     case SB_ENDSCROLL:
1884     return;
1885     case SB_LINEDOWN:
1886     Func = SCROLL_LINEDOWN;
1887     break;
1888     case SB_LINEUP:
1889     Func = SCROLL_LINEUP;
1890     break;
1891     case SB_PAGEDOWN:
1892     Func = SCROLL_PAGEDOWN;
1893     break;
1894 doda 6435 case SB_PAGEUP:
1895 maya 3227 Func = SCROLL_PAGEUP;
1896     break;
1897     case SB_THUMBPOSITION:
1898     case SB_THUMBTRACK:
1899     Func = SCROLL_POS;
1900     break;
1901     case SB_TOP:
1902     Func = SCROLL_TOP;
1903     break;
1904     default:
1905     return;
1906     }
1907     DispHScroll(Func,nPos);
1908     }
1909    
1910 zmatsuo 7528 void CVTWindow::OnInitMenuPopup(HMENU hPopupMenu, UINT nIndex, BOOL bSysMenu)
1911 maya 3227 {
1912 zmatsuo 7528 InitMenuPopup(hPopupMenu);
1913 maya 3227 }
1914    
1915 zmatsuo 8337 void CVTWindow::OnKeyDown(WPARAM nChar, UINT nRepCnt, UINT nFlags)
1916 maya 3227 {
1917 doda 8445 #if UNICODE_DEBUG
1918     if (UnicodeDebugParam.CodePopupEnable)
1919     {
1920     const DWORD now = GetTickCount();
1921     switch(CtrlKeyState) {
1922     case 0:
1923     if (nChar == UnicodeDebugParam.CodePopupKey1) {
1924     CtrlKeyDownTick = now;
1925     CtrlKeyState = 1;
1926     }
1927     break;
1928     case 2:
1929     if (nChar != UnicodeDebugParam.CodePopupKey2) {
1930     CtrlKeyState = 0;
1931     break;
1932     }
1933     if (now - CtrlKeyDownTick < 500 && TipWinCodeDebug == NULL) {
1934     POINT pos;
1935     GetCursorPos(&pos);
1936     ScreenToClient(m_hWnd, &pos);
1937     CodePopup(pos.x, pos.y);
1938     CtrlKeyState = 3;
1939     } else {
1940     CtrlKeyDownTick = now;
1941     CtrlKeyState = 1;
1942     }
1943     break;
1944     case 3:
1945     break;
1946     default:
1947     CtrlKeyState = 0;
1948     break;
1949     }
1950     }
1951     if (TipWinCodeDebug != NULL && nChar == VK_SHIFT) {
1952     POINT pos;
1953     GetCursorPos(&pos);
1954     ScreenToClient(m_hWnd, &pos);
1955     wchar_t *buf = BuffGetCharInfo(pos.x, pos.y);
1956     CBSetTextW(HVTWin, buf, 0);
1957     free(buf);
1958 zmatsuo 8745 MessageBeep(MB_OK);
1959     TipWinDestroy(TipWinCodeDebug);
1960     TipWinCodeDebug = NULL;
1961     CtrlKeyState = 0;
1962 doda 8445 }
1963     #endif
1964 maya 3227 switch (KeyDown(HVTWin,nChar,nRepCnt,nFlags & 0x1ff)) {
1965     case KEYDOWN_OTHER:
1966     break;
1967     case KEYDOWN_CONTROL:
1968     return;
1969     case KEYDOWN_COMMOUT:
1970 doda 6421 // �X�N���[�����u�����Z�b�g
1971     if (WinOrgY != 0) {
1972 maya 3227 DispVScroll(SCROLL_BOTTOM, 0);
1973     }
1974     return;
1975     }
1976    
1977 doda 4519 if (MetaKey(ts.MetaKey) && (nFlags & 0x2000) != 0)
1978 doda 4414 {
1979 zmatsuo 9150 BYTE KeyState[256];
1980     MSG M;
1981    
1982 doda 4712 PeekMessage((LPMSG)&M,HVTWin,WM_CHAR,WM_CHAR,PM_REMOVE);
1983 maya 3227 /* for Ctrl+Alt+Key combination */
1984 zmatsuo 9150 GetKeyboardState(KeyState);
1985 maya 3227 KeyState[VK_MENU] = 0;
1986 zmatsuo 9150 SetKeyboardState(KeyState);
1987 maya 3227 M.hwnd = HVTWin;
1988     M.message = WM_KEYDOWN;
1989     M.wParam = nChar;
1990     M.lParam = MAKELONG(nRepCnt,nFlags & 0xdfff);
1991     TranslateMessage(&M);
1992     }
1993    
1994     }
1995    
1996 zmatsuo 8337 void CVTWindow::OnKeyUp(WPARAM nChar, UINT nRepCnt, UINT nFlags)
1997 maya 3227 {
1998     KeyUp(nChar);
1999 doda 8445 #if UNICODE_DEBUG
2000     if (CtrlKeyState == 1 && nChar == UnicodeDebugParam.CodePopupKey1) {
2001     CtrlKeyState++;
2002     } else {
2003     CtrlKeyState = 0;
2004     }
2005     if (nChar == UnicodeDebugParam.CodePopupKey2) {
2006     if (TipWinCodeDebug != NULL) {
2007     TipWinDestroy(TipWinCodeDebug);
2008     TipWinCodeDebug = NULL;
2009     CtrlKeyState = 0;
2010     }
2011     }
2012     #endif
2013 maya 3227 }
2014    
2015 zmatsuo 7528 void CVTWindow::OnKillFocus(HWND hNewWnd)
2016 maya 3227 {
2017     DispDestroyCaret();
2018     FocusReport(FALSE);
2019 zmatsuo 7784 // TTCFrameWnd::OnKillFocus(hNewWnd); // TODO
2020 maya 3227
2021 maya 3392 if (IsCaretOn()) {
2022 maya 3227 CaretKillFocus(TRUE);
2023 maya 3392 }
2024 maya 3227 }
2025    
2026 zmatsuo 8337 void CVTWindow::OnLButtonDblClk(WPARAM nFlags, POINTS point)
2027 maya 3227 {
2028 maya 3392 if (LButton || MButton || RButton) {
2029 maya 3227 return;
2030 maya 3392 }
2031 maya 3227
2032     DblClkX = point.x;
2033     DblClkY = point.y;
2034    
2035 doda 3992 if (MouseReport(IdMouseEventBtnDown, IdLeftButton, DblClkX, DblClkY)) {
2036 maya 3227 return;
2037 maya 3392 }
2038 maya 3227
2039 doda 3992 if (BuffUrlDblClk(DblClkX, DblClkY)) { // �u���E�U�����o���������������������B (2005.4.3 yutaka)
2040     return;
2041     }
2042    
2043 maya 3227 BuffDblClk(DblClkX, DblClkY);
2044    
2045     LButton = TRUE;
2046     DblClk = TRUE;
2047     AfterDblClk = TRUE;
2048     ::SetTimer(HVTWin, IdDblClkTimer, GetDoubleClickTime(), NULL);
2049    
2050     /* for AutoScrolling */
2051     ::SetCapture(HVTWin);
2052     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
2053     }
2054    
2055 zmatsuo 8337 void CVTWindow::OnLButtonDown(WPARAM nFlags, POINTS point)
2056 maya 3227 {
2057     POINT p;
2058    
2059     p.x = point.x;
2060     p.y = point.y;
2061     ButtonDown(p,IdLeftButton);
2062     }
2063    
2064 zmatsuo 8337 void CVTWindow::OnLButtonUp(WPARAM nFlags, POINTS point)
2065 maya 3227 {
2066 doda 5341 if (IgnoreRelease)
2067     IgnoreRelease = FALSE;
2068 doda 7078 else if (MouseReport(IdMouseEventBtnUp, IdLeftButton, point.x, point.y)) {
2069     ReleaseCapture();
2070     }
2071 maya 3227
2072 maya 3392 if (! LButton) {
2073 maya 3227 return;
2074 maya 3392 }
2075 maya 3227
2076     ButtonUp(FALSE);
2077     }
2078    
2079 zmatsuo 8337 void CVTWindow::OnMButtonDown(WPARAM nFlags, POINTS point)
2080 maya 3227 {
2081     POINT p;
2082    
2083     p.x = point.x;
2084     p.y = point.y;
2085     ButtonDown(p,IdMiddleButton);
2086     }
2087    
2088 zmatsuo 8337 void CVTWindow::OnMButtonUp(WPARAM nFlags, POINTS point)
2089 maya 3227 {
2090 doda 5341 if (IgnoreRelease)
2091     IgnoreRelease = FALSE;
2092 doda 7078 else if (MouseReport(IdMouseEventBtnUp, IdMiddleButton, point.x, point.y)) {
2093     ReleaseCapture();
2094     }
2095 maya 3227
2096 maya 3392 if (! MButton) {
2097 maya 3227 return;
2098 maya 3392 }
2099 maya 3227
2100     // added DisablePasteMouseMButton (2008.3.2 maya)
2101 doda 7078 if (ts.PasteFlag & CPF_DISABLE_MBUTTON) {
2102 maya 3227 ButtonUp(FALSE);
2103 maya 3392 }
2104     else {
2105 maya 3227 ButtonUp(TRUE);
2106 maya 3392 }
2107 maya 3227 }
2108    
2109 zmatsuo 8677 LRESULT CVTWindow::OnMouseActivate(HWND pDesktopWnd, UINT nHitTest, UINT message)
2110 maya 3227 {
2111 doda 5341 if ((ts.SelOnActive==0) && (nHitTest==HTCLIENT)) { //disable mouse event for text selection
2112     IgnoreRelease = TRUE;
2113 maya 3227 return MA_ACTIVATEANDEAT; // when window is activated
2114 doda 5341 }
2115     else {
2116 maya 3227 return MA_ACTIVATE;
2117 doda 5341 }
2118 maya 3227 }
2119    
2120 doda 8445
2121     void CVTWindow::CodePopup(int client_x, int client_y)
2122     {
2123     wchar_t *buf = BuffGetCharInfo(client_x, client_y);
2124     if (TipWinCodeDebug == NULL) {
2125     TipWinCodeDebug = TipWinCreate(m_hInst, m_hWnd);
2126     }
2127     POINT pos = { client_x, client_y };
2128     ClientToScreen(m_hWnd, &pos);
2129     TipWinSetPos(TipWinCodeDebug, pos.x, pos.y);
2130     TipWinSetTextW(TipWinCodeDebug, buf);
2131     TipWinSetVisible(TipWinCodeDebug, TRUE);
2132     free(buf);
2133     }
2134    
2135 zmatsuo 8337 void CVTWindow::OnMouseMove(WPARAM nFlags, POINTS point)
2136 maya 3227 {
2137     int i;
2138 zmatsuo 9157 BOOL mousereport = FALSE;
2139 maya 3227
2140 doda 8445 #if UNICODE_DEBUG
2141     if (TipWinCodeDebug != NULL) {
2142     CodePopup(point.x, point.y);
2143     }
2144     #endif
2145    
2146 doda 5341 if (!IgnoreRelease)
2147     mousereport = MouseReport(IdMouseEventMove, 0, point.x, point.y);
2148 doda 3987
2149 maya 3227 if (! (LButton || MButton || RButton)) {
2150 doda 5279 if (BuffCheckMouseOnURL(point.x, point.y))
2151     SetMouseCursor("HAND");
2152     else
2153     SetMouseCursor(ts.MouseCursorName);
2154 maya 3227 return;
2155     }
2156    
2157 doda 3987 if (mousereport) {
2158     return;
2159     }
2160    
2161 maya 3392 if (DblClk) {
2162 maya 3227 i = 2;
2163 maya 3392 }
2164     else if (TplClk) {
2165 maya 3227 i = 3;
2166 maya 3392 }
2167     else {
2168 maya 3227 i = 1;
2169 maya 3392 }
2170 maya 3227
2171     if (!ts.SelectOnlyByLButton ||
2172 maya 3392 (ts.SelectOnlyByLButton && LButton) ) {
2173 maya 3227 // SelectOnlyByLButton == TRUE ���������A���{�^���_�E���������I������ (2007.11.21 maya)
2174     BuffChangeSelect(point.x, point.y,i);
2175     }
2176     }
2177    
2178     void CVTWindow::OnMove(int x, int y)
2179     {
2180 zmatsuo 10391 // �E�B���h�E���u������
2181     // �� x,y ���N���C�A���g���������������W
2182     RECT R;
2183     ::GetWindowRect(HVTWin,&R);
2184     ts.VTPos.x = R.left;
2185     ts.VTPos.y = R.top;
2186    
2187 maya 3227 DispSetWinPos();
2188     }
2189    
2190     // �}�E�X�z�C�[�������]
2191     BOOL CVTWindow::OnMouseWheel(
2192     UINT nFlags, // ���z�L�[
2193     short zDelta, // ���]����
2194 zmatsuo 7528 POINTS pts // �J�[�\�����u
2195 maya 3227 )
2196     {
2197 zmatsuo 7528 POINT pt;
2198     pt.x = pts.x;
2199     pt.y = pts.y;
2200    
2201 maya 3227 int line, i;
2202    
2203 zmatsuo 7457 if (pSetLayeredWindowAttributes != NULL) {
2204 zmatsuo 7390 BOOL InTitleBar;
2205     POINT point = pt;
2206     GetPositionOnWindow(HVTWin, &point,
2207     NULL, NULL, &InTitleBar);
2208     if (InTitleBar) {
2209     int delta = zDelta < 0 ? -1 : 1;
2210     int newAlpha = Alpha;
2211 yasuhide 8143 POINT tippos;
2212 yasuhide 8091
2213 zmatsuo 7390 newAlpha += delta * ts.MouseWheelScrollLine;
2214     if (newAlpha > 255)
2215     newAlpha = 255;
2216     else if (newAlpha < 0)
2217     newAlpha = 0;
2218     SetWindowAlpha(newAlpha);
2219 yasuhide 8091
2220 zmatsuo 9355 wchar_t *uimsg;
2221     GetI18nStrWA("Tera Term", "TOOLTIP_TITLEBAR_OPACITY", L"Opacity %.1f %%", ts.UILanguageFile, &uimsg);
2222     wchar_t *tipbuf;
2223     aswprintf(&tipbuf, uimsg, (newAlpha / 255.0) * 100);
2224     free(uimsg);
2225 yasuhide 8091
2226 yasuhide 8143 tippos = TipWin->GetPos();
2227     if (tippos.x != pt.x ||
2228     tippos.y != pt.y) {
2229     TipWin->SetVisible(FALSE);
2230 yasuhide 8091 }
2231    
2232 yasuhide 8143 TipWin->SetText(tipbuf);
2233     TipWin->SetPos(pt.x, pt.y);
2234     TipWin->SetHideTimer(1000);
2235    
2236     if(! TipWin->IsVisible()) {
2237     TipWin->SetVisible(TRUE);
2238 yasuhide 8091 }
2239    
2240 zmatsuo 9355 free(tipbuf);
2241    
2242 zmatsuo 7390 return TRUE;
2243     }
2244     }
2245    
2246 maya 3227 ::ScreenToClient(HVTWin, &pt);
2247    
2248     line = abs(zDelta) / WHEEL_DELTA; // ���C����
2249     if (line < 1) line = 1;
2250    
2251     // ���X�N���[�����������s������������ (2008.4.6 yutaka)
2252     if (line == 1 && ts.MouseWheelScrollLine > 0)
2253     line *= ts.MouseWheelScrollLine;
2254    
2255     if (MouseReport(IdMouseEventWheel, zDelta<0, pt.x, pt.y))
2256     return TRUE;
2257    
2258 doda 4293 if (WheelToCursorMode()) {
2259 maya 3227 if (zDelta < 0) {
2260     KeyDown(HVTWin, VK_DOWN, line, MapVirtualKey(VK_DOWN, 0) | 0x100);
2261     KeyUp(VK_DOWN);
2262     } else {
2263     KeyDown(HVTWin, VK_UP, line, MapVirtualKey(VK_UP, 0) | 0x100);
2264     KeyUp(VK_UP);
2265     }
2266     } else {
2267     for (i = 0 ; i < line ; i++) {
2268     if (zDelta < 0) {
2269     OnVScroll(SB_LINEDOWN, 0, NULL);
2270     } else {
2271     OnVScroll(SB_LINEUP, 0, NULL);
2272     }
2273     }
2274     }
2275    
2276     return (TRUE);
2277     }
2278    
2279 zmatsuo 7528 void CVTWindow::OnNcLButtonDblClk(UINT nHitTest, POINTS point)
2280 maya 3227 {
2281 doda 7132 if (! Minimized && !ts.TermIsWin && (nHitTest == HTCAPTION)) {
2282 maya 3227 DispRestoreWinSize();
2283 maya 3392 }
2284 maya 3227 }
2285    
2286 zmatsuo 7528 void CVTWindow::OnNcRButtonDown(UINT nHitTest, POINTS point)
2287 maya 3227 {
2288     if ((nHitTest==HTCAPTION) &&
2289     (ts.HideTitle>0) &&
2290 maya 3392 AltKey()) {
2291 maya 3227 ::CloseWindow(HVTWin); /* iconize */
2292 maya 3392 }
2293 maya 3227 }
2294    
2295     void CVTWindow::OnPaint()
2296     {
2297     PAINTSTRUCT ps;
2298     HDC PaintDC;
2299     int Xs, Ys, Xe, Ye;
2300    
2301 zmatsuo 7322 // �\������������������WM_PAINT�����������P�[�X����
2302 zmatsuo 7528 if (::IsWindowVisible(m_hWnd) == 0) {
2303 zmatsuo 7322 return;
2304     }
2305    
2306 maya 3227 BGSetupPrimary(FALSE);
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����