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 10402 - (hide annotations) (download) (as text)
Sun Dec 11 12:07:56 2022 UTC (16 months ago) by zmatsuo
Original Path: trunk/teraterm/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 141257 byte(s)
DnDでのscp送信を修正

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