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 10190 - (hide annotations) (download) (as text)
Fri Aug 26 14:28:55 2022 UTC (19 months, 2 weeks ago) by zmatsuo
Original Path: trunk/teraterm/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 140914 byte(s)
ifdef ALPHABLEND_TYPE2 を削除

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