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 2545 - (hide annotations) (download) (as text)
Fri Jun 20 11:58:47 2008 UTC (15 years, 9 months ago) by doda
Original Path: teraterm/trunk/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 120890 byte(s)
・TeraTerm -> Tera Term
・その他細かい修正

1 maya 2476 /* Tera Term
2     Copyright(C) 1994-1998 T. Teranishi
3     All rights reserved. */
4     /* IPv6 modification is Copyright(C) 2000 Jun-ya Kato <kato@win6.jp> */
5    
6     /* TERATERM.EXE, VT window */
7    
8     #include "stdafx.h"
9     #include "teraterm.h"
10     #include "tttypes.h"
11    
12     #include "ttcommon.h"
13     #include "ttwinman.h"
14     #include "ttsetup.h"
15     #include "keyboard.h"
16     #include "buffer.h"
17     #include "vtterm.h"
18     #include "vtdisp.h"
19     #include "ttdialog.h"
20     #include "ttime.h"
21     #include "commlib.h"
22     #include "clipboar.h"
23     #include "ttftypes.h"
24     #include "filesys.h"
25     #include "telnet.h"
26     #include "tektypes.h"
27     #include "tekwin.h"
28     #include "ttdde.h"
29     #include "ttlib.h"
30     #include "helpid.h"
31     #include "teraprn.h"
32     #ifndef NO_INET6
33     #include <winsock2.h>
34     #include <ws2tcpip.h>
35     #else
36     #include <winsock.h>
37     #endif /* NO_INET6 */
38     #include "ttplug.h" /* TTPLUG */
39    
40     #include <stdio.h>
41     #include <stdlib.h>
42     #include <string.h>
43     #include <locale.h>
44    
45     #include <shlobj.h>
46     #include <io.h>
47     #include <errno.h>
48     #include <imagehlp.h>
49    
50     #include <windowsx.h>
51    
52     #include "tt_res.h"
53     #include "vtwin.h"
54 maya 2504 #include "addsetting.h"
55 maya 2476
56     #define VTClassName "VTWin32"
57    
58     /* mouse buttons */
59     #define IdLeftButton 0
60     #define IdMiddleButton 1
61     #define IdRightButton 2
62    
63     #ifdef _DEBUG
64     #define new DEBUG_NEW
65     #undef THIS_FILE
66     static char THIS_FILE[] = __FILE__;
67     #endif
68    
69     // �E�B���h�E�������{�^�����L�������� (2005.1.15 yutaka)
70     #define WINDOW_MAXMIMUM_ENABLED 1
71    
72     // WM_COPYDATA�������v���Z�X�����M������ (2005.1.22 yutaka)
73     #define IPC_BROADCAST_COMMAND 1
74    
75     static HFONT DlgBroadcastFont;
76     static HFONT DlgCommentFont;
77    
78 maya 2504 // �{���� addsetting.cpp
79     extern mouse_cursor_t MouseCursor[];
80 maya 2476
81     /////////////////////////////////////////////////////////////////////////////
82     // CVTWindow
83    
84     BEGIN_MESSAGE_MAP(CVTWindow, CFrameWnd)
85     //{{AFX_MSG_MAP(CVTWindow)
86     ON_WM_ACTIVATE()
87     ON_WM_CHAR()
88     ON_WM_CLOSE()
89     ON_WM_DESTROY()
90     ON_WM_DROPFILES()
91     ON_WM_GETMINMAXINFO()
92     ON_WM_HSCROLL()
93     ON_WM_INITMENUPOPUP()
94     ON_WM_KEYDOWN()
95     ON_WM_KEYUP()
96     ON_WM_KILLFOCUS()
97     ON_WM_LBUTTONDBLCLK()
98     ON_WM_LBUTTONDOWN()
99     ON_WM_LBUTTONUP()
100     ON_WM_MBUTTONDOWN()
101     ON_WM_MBUTTONUP()
102     ON_WM_MOUSEACTIVATE()
103     ON_WM_MOUSEMOVE()
104     ON_WM_MOUSEWHEEL()
105     ON_WM_MOVE()
106     ON_WM_NCLBUTTONDBLCLK()
107     ON_WM_NCRBUTTONDOWN()
108     ON_WM_PAINT()
109     ON_WM_RBUTTONDOWN()
110     ON_WM_RBUTTONUP()
111     ON_WM_SETFOCUS()
112     ON_WM_SIZE()
113     ON_WM_SYSCHAR()
114     ON_WM_SYSCOLORCHANGE()
115     ON_WM_SYSCOMMAND()
116     ON_WM_SYSKEYDOWN()
117     ON_WM_SYSKEYUP()
118     ON_WM_TIMER()
119     ON_WM_VSCROLL()
120     ON_MESSAGE(WM_IME_COMPOSITION,OnIMEComposition)
121     //<!--by AKASI
122     ON_MESSAGE(WM_WINDOWPOSCHANGING,OnWindowPosChanging)
123     ON_MESSAGE(WM_SETTINGCHANGE,OnSettingChange)
124     ON_MESSAGE(WM_ENTERSIZEMOVE,OnEnterSizeMove)
125     ON_MESSAGE(WM_EXITSIZEMOVE ,OnExitSizeMove)
126     //-->
127     ON_MESSAGE(WM_USER_ACCELCOMMAND, OnAccelCommand)
128     ON_MESSAGE(WM_USER_CHANGEMENU,OnChangeMenu)
129     ON_MESSAGE(WM_USER_CHANGETBAR,OnChangeTBar)
130     ON_MESSAGE(WM_USER_COMMNOTIFY,OnCommNotify)
131     ON_MESSAGE(WM_USER_COMMOPEN,OnCommOpen)
132     ON_MESSAGE(WM_USER_COMMSTART,OnCommStart)
133     ON_MESSAGE(WM_USER_DDEEND,OnDdeEnd)
134     ON_MESSAGE(WM_USER_DLGHELP2,OnDlgHelp)
135     ON_MESSAGE(WM_USER_FTCANCEL,OnFileTransEnd)
136     ON_MESSAGE(WM_USER_GETSERIALNO,OnGetSerialNo)
137     ON_MESSAGE(WM_USER_KEYCODE,OnKeyCode)
138     ON_MESSAGE(WM_USER_PROTOCANCEL,OnProtoEnd)
139     ON_MESSAGE(WM_USER_CHANGETITLE,OnChangeTitle)
140     ON_MESSAGE(WM_COPYDATA,OnReceiveIpcMessage)
141     ON_COMMAND(ID_FILE_NEWCONNECTION, OnFileNewConnection)
142     ON_COMMAND(ID_FILE_DUPLICATESESSION, OnDuplicateSession)
143     ON_COMMAND(ID_FILE_CYGWINCONNECTION, OnCygwinConnection)
144     ON_COMMAND(ID_FILE_TERATERMMENU, OnTTMenuLaunch)
145     ON_COMMAND(ID_FILE_LOGMEIN, OnLogMeInLaunch)
146     ON_COMMAND(ID_FILE_LOG, OnFileLog)
147     ON_COMMAND(ID_FILE_COMMENTTOLOG, OnCommentToLog)
148     ON_COMMAND(ID_FILE_VIEWLOG, OnViewLog)
149     ON_COMMAND(ID_FILE_SHOWLOGDIALOG, OnShowLogDialog)
150     ON_COMMAND(ID_FILE_REPLAYLOG, OnReplayLog)
151     ON_COMMAND(ID_FILE_SENDFILE, OnFileSend)
152     ON_COMMAND(ID_FILE_KERMITRCV, OnFileKermitRcv)
153     ON_COMMAND(ID_FILE_KERMITGET, OnFileKermitGet)
154     ON_COMMAND(ID_FILE_KERMITSEND, OnFileKermitSend)
155     ON_COMMAND(ID_FILE_KERMITFINISH, OnFileKermitFinish)
156     ON_COMMAND(ID_FILE_XRCV, OnFileXRcv)
157     ON_COMMAND(ID_FILE_XSEND, OnFileXSend)
158 yutakapon 2511 ON_COMMAND(ID_FILE_YRCV, OnFileYRcv)
159     ON_COMMAND(ID_FILE_YSEND, OnFileYSend)
160 maya 2476 ON_COMMAND(ID_FILE_ZRCV, OnFileZRcv)
161     ON_COMMAND(ID_FILE_ZSEND, OnFileZSend)
162     ON_COMMAND(ID_FILE_BPRCV, OnFileBPRcv)
163     ON_COMMAND(ID_FILE_BPSEND, OnFileBPSend)
164     ON_COMMAND(ID_FILE_QVRCV, OnFileQVRcv)
165     ON_COMMAND(ID_FILE_QVSEND, OnFileQVSend)
166     ON_COMMAND(ID_FILE_CHANGEDIR, OnFileChangeDir)
167     ON_COMMAND(ID_FILE_PRINT2, OnFilePrint)
168     ON_COMMAND(ID_FILE_DISCONNECT, OnFileDisconnect)
169     ON_COMMAND(ID_FILE_EXIT, OnFileExit)
170     ON_COMMAND(ID_EDIT_COPY2, OnEditCopy)
171     ON_COMMAND(ID_EDIT_COPYTABLE, OnEditCopyTable)
172     ON_COMMAND(ID_EDIT_PASTE2, OnEditPaste)
173     ON_COMMAND(ID_EDIT_PASTECR, OnEditPasteCR)
174     ON_COMMAND(ID_EDIT_CLEARSCREEN, OnEditClearScreen)
175     ON_COMMAND(ID_EDIT_CLEARBUFFER, OnEditClearBuffer)
176     ON_COMMAND(ID_EDIT_CANCELSELECT, OnEditCancelSelection)
177     ON_COMMAND(ID_EDIT_SELECTALL, OnEditSelectAllBuffer)
178     ON_COMMAND(ID_EDIT_SELECTSCREEN, OnEditSelectScreenBuffer)
179     ON_COMMAND(ID_SETUP_ADDITIONALSETTINGS, OnExternalSetup)
180     ON_COMMAND(ID_SETUP_TERMINAL, OnSetupTerminal)
181     ON_COMMAND(ID_SETUP_WINDOW, OnSetupWindow)
182     ON_COMMAND(ID_SETUP_FONT, OnSetupFont)
183     ON_COMMAND(ID_SETUP_KEYBOARD, OnSetupKeyboard)
184     ON_COMMAND(ID_SETUP_SERIALPORT, OnSetupSerialPort)
185     ON_COMMAND(ID_SETUP_TCPIP, OnSetupTCPIP)
186     ON_COMMAND(ID_SETUP_GENERAL, OnSetupGeneral)
187     ON_COMMAND(ID_SETUP_SAVE, OnSetupSave)
188     ON_COMMAND(ID_SETUP_RESTORE, OnSetupRestore)
189     ON_COMMAND(ID_SETUP_LOADKEYMAP, OnSetupLoadKeyMap)
190     ON_COMMAND(ID_CONTROL_RESETTERMINAL, OnControlResetTerminal)
191     ON_COMMAND(ID_CONTROL_AREYOUTHERE, OnControlAreYouThere)
192     ON_COMMAND(ID_CONTROL_SENDBREAK, OnControlSendBreak)
193     ON_COMMAND(ID_CONTROL_RESETPORT, OnControlResetPort)
194     ON_COMMAND(ID_CONTROL_BROADCASTCOMMAND, OnControlBroadcastCommand)
195     ON_COMMAND(ID_CONTROL_OPENTEK, OnControlOpenTEK)
196     ON_COMMAND(ID_CONTROL_CLOSETEK, OnControlCloseTEK)
197     ON_COMMAND(ID_CONTROL_MACRO, OnControlMacro)
198     ON_COMMAND(ID_WINDOW_WINDOW, OnWindowWindow)
199     ON_COMMAND(ID_HELP_INDEX2, OnHelpIndex)
200     ON_COMMAND(ID_HELP_ABOUT, OnHelpAbout)
201     //}}AFX_MSG_MAP
202     END_MESSAGE_MAP()
203    
204     /////////////////////////////////////////////////////////////////////////////
205     // CVTWindow constructor
206    
207    
208     static BOOL MySetLayeredWindowAttributes(HWND hwnd, COLORREF crKey, BYTE bAlpha, DWORD dwFlags)
209     {
210     typedef BOOL (WINAPI *func)(HWND,COLORREF,BYTE,DWORD);
211     static HMODULE g_hmodUser32 = NULL;
212     static func g_pSetLayeredWindowAttributes = NULL;
213    
214     if (g_hmodUser32 == NULL) {
215     g_hmodUser32 = LoadLibrary("user32.dll");
216     if (g_hmodUser32 == NULL)
217     return FALSE;
218    
219     g_pSetLayeredWindowAttributes =
220     (func)GetProcAddress(g_hmodUser32, "SetLayeredWindowAttributes");
221     }
222    
223     if (g_pSetLayeredWindowAttributes == NULL)
224     return FALSE;
225    
226     return g_pSetLayeredWindowAttributes(hwnd, crKey,
227     bAlpha, dwFlags);
228     }
229    
230    
231 doda 2545 // Tera Term�N������URL������mouse over������������ (2005.4.2 yutaka)
232 maya 2476 extern "C" void SetMouseCursor(char *cursor)
233     {
234     HCURSOR hc;
235     LPCTSTR name = NULL;
236     int i;
237    
238     for (i = 0 ; MouseCursor[i].name ; i++) {
239     if (_stricmp(cursor, MouseCursor[i].name) == 0) {
240     name = MouseCursor[i].id;
241     break;
242     }
243     }
244     if (name == NULL)
245     return;
246    
247    
248     hc = (HCURSOR)LoadImage(NULL, MAKEINTRESOURCE(name), IMAGE_CURSOR,
249     0, 0, LR_DEFAULTSIZE | LR_SHARED);
250    
251     if (hc != NULL) {
252     SetClassLongPtr(HVTWin, GCLP_HCURSOR, (LONG_PTR)hc);
253     }
254     }
255    
256    
257 maya 2504 void SetWindowStyle(TTTSet *ts)
258 maya 2476 {
259     LONG_PTR lp;
260    
261     SetMouseCursor(ts->MouseCursorName);
262    
263     // 2006/03/16 by 337: BGUseAlphaBlendAPI��On������Layered����������
264     //if (ts->EtermLookfeel.BGUseAlphaBlendAPI) {
265     // �A���t�@�l��255�������A�����������������}�����������������������������B(2006.4.1 yutaka)
266     // �����o�������A�l�����X�����������������������f�����B(2007.10.19 maya)
267     if (ts->AlphaBlend < 255) {
268     lp = GetWindowLongPtr(HVTWin, GWL_EXSTYLE);
269     if (lp != 0) {
270     SetWindowLongPtr(HVTWin, GWL_EXSTYLE, lp | WS_EX_LAYERED);
271     MySetLayeredWindowAttributes(HVTWin, 0, ts->AlphaBlend, LWA_ALPHA);
272     }
273     }
274     // �A���t�@�l�� 255 �������A�����������������������`�������B(2007.10.22 maya)
275     else {
276     lp = GetWindowLongPtr(HVTWin, GWL_EXSTYLE);
277     if (lp != 0) {
278     SetWindowLongPtr(HVTWin, GWL_EXSTYLE, lp & ~WS_EX_LAYERED);
279     RedrawWindow(HVTWin, NULL, NULL, RDW_ERASE | RDW_INVALIDATE | RDW_FRAME);
280     }
281     }
282     }
283    
284    
285     //
286     // ���O�n���h�����t�b�N�i�X�^�b�N�g���[�X���_���v�j
287     //
288     // cf. http://svn.collab.net/repos/svn/trunk/subversion/libsvn_subr/win32_crashrpt.c
289     // (2007.9.30 yutaka)
290     //
291     // ���O�R�[�h������������������
292     static char *GetExceptionString(int exception)
293     {
294     #define EXCEPTION(x) case EXCEPTION_##x: return (#x);
295     static char buf[16];
296    
297     switch (exception)
298     {
299     EXCEPTION(ACCESS_VIOLATION)
300     EXCEPTION(DATATYPE_MISALIGNMENT)
301     EXCEPTION(BREAKPOINT)
302     EXCEPTION(SINGLE_STEP)
303     EXCEPTION(ARRAY_BOUNDS_EXCEEDED)
304     EXCEPTION(FLT_DENORMAL_OPERAND)
305     EXCEPTION(FLT_DIVIDE_BY_ZERO)
306     EXCEPTION(FLT_INEXACT_RESULT)
307     EXCEPTION(FLT_INVALID_OPERATION)
308     EXCEPTION(FLT_OVERFLOW)
309     EXCEPTION(FLT_STACK_CHECK)
310     EXCEPTION(FLT_UNDERFLOW)
311     EXCEPTION(INT_DIVIDE_BY_ZERO)
312     EXCEPTION(INT_OVERFLOW)
313     EXCEPTION(PRIV_INSTRUCTION)
314     EXCEPTION(IN_PAGE_ERROR)
315     EXCEPTION(ILLEGAL_INSTRUCTION)
316     EXCEPTION(NONCONTINUABLE_EXCEPTION)
317     EXCEPTION(STACK_OVERFLOW)
318     EXCEPTION(INVALID_DISPOSITION)
319     EXCEPTION(GUARD_PAGE)
320     EXCEPTION(INVALID_HANDLE)
321    
322     default:
323     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "0x%x", exception);
324     return buf;
325     //return "UNKNOWN_ERROR";
326     }
327     #undef EXCEPTION
328     }
329    
330     /* ���O�������������������o���������\�������A���O�t�B���^���� */
331     static LONG CALLBACK ApplicationFaultHandler(EXCEPTION_POINTERS *ExInfo)
332     {
333     HGLOBAL gptr;
334     STACKFRAME sf;
335     BOOL bResult;
336     PIMAGEHLP_SYMBOL pSym;
337     DWORD Disp;
338     HANDLE hProcess = GetCurrentProcess();
339     HANDLE hThread = GetCurrentThread();
340     IMAGEHLP_MODULE ih_module;
341     IMAGEHLP_LINE ih_line;
342     int frame;
343     char msg[3072], buf[256];
344     HMODULE h, h2;
345    
346     // Windows98/Me/NT4�����������������X�L�b�v�����B(2007.10.9 yutaka)
347     h2 = LoadLibrary("imagehlp.dll");
348     if (((h = GetModuleHandle("imagehlp.dll")) == NULL) ||
349     (GetProcAddress(h, "SymGetLineFromAddr") == NULL)) {
350     FreeLibrary(h2);
351     goto error;
352     }
353     FreeLibrary(h2);
354    
355     /* �V���{�������i�[�p�o�b�t�@�������� */
356     gptr = GlobalAlloc(GMEM_FIXED, 10000);
357     if (gptr == NULL)
358     goto error;
359     pSym = (PIMAGEHLP_SYMBOL)GlobalLock(gptr);
360     ZeroMemory(pSym, sizeof(IMAGEHLP_SYMBOL));
361     pSym->SizeOfStruct = 10000;
362     pSym->MaxNameLength = 10000 - sizeof(IMAGEHLP_SYMBOL);
363    
364     /* �X�^�b�N�t���[���������� */
365     ZeroMemory(&sf, sizeof(sf));
366     sf.AddrPC.Offset = ExInfo->ContextRecord->Eip;
367     sf.AddrStack.Offset = ExInfo->ContextRecord->Esp;
368     sf.AddrFrame.Offset = ExInfo->ContextRecord->Ebp;
369     sf.AddrPC.Mode = AddrModeFlat;
370     sf.AddrStack.Mode = AddrModeFlat;
371     sf.AddrFrame.Mode = AddrModeFlat;
372    
373     /* �V���{���n���h���������� */
374     SymInitialize(hProcess, NULL, TRUE);
375    
376     // ���W�X�^�_���v
377     msg[0] = '\0';
378     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "eax=%08X ebx=%08X ecx=%08X edx=%08X esi=%08X edi=%08X\r\n"
379     "ebp=%08X esp=%08X eip=%08X efl=%08X\r\n"
380     "cs=%04X ss=%04X ds=%04X es=%04X fs=%04X gs=%04X\r\n",
381     ExInfo->ContextRecord->Eax,
382     ExInfo->ContextRecord->Ebx,
383     ExInfo->ContextRecord->Ecx,
384     ExInfo->ContextRecord->Edx,
385     ExInfo->ContextRecord->Esi,
386     ExInfo->ContextRecord->Edi,
387     ExInfo->ContextRecord->Ebp,
388     ExInfo->ContextRecord->Esp,
389     ExInfo->ContextRecord->Eip,
390     ExInfo->ContextRecord->EFlags,
391     ExInfo->ContextRecord->SegCs,
392     ExInfo->ContextRecord->SegSs,
393     ExInfo->ContextRecord->SegDs,
394     ExInfo->ContextRecord->SegEs,
395     ExInfo->ContextRecord->SegFs,
396     ExInfo->ContextRecord->SegGs
397     );
398     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
399    
400     if (ExInfo->ExceptionRecord != NULL) {
401     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "Exception: %s\r\n", GetExceptionString(ExInfo->ExceptionRecord->ExceptionCode));
402     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
403     }
404    
405     /* �X�^�b�N�t���[���������\���������� */
406     frame = 0;
407     for (;;) {
408     /* �����X�^�b�N�t���[�������� */
409     bResult = StackWalk(
410     IMAGE_FILE_MACHINE_I386,
411     hProcess,
412     hThread,
413     &sf,
414     NULL,
415     NULL,
416     SymFunctionTableAccess,
417     SymGetModuleBase,
418     NULL);
419    
420     /* ���s�������A���[�v�������� */
421     if (!bResult || sf.AddrFrame.Offset == 0)
422     break;
423    
424     frame++;
425    
426     /* �v���O�����J�E���^�i���z�A�h���X�j�������������I�t�Z�b�g������ */
427     bResult = SymGetSymFromAddr(hProcess, sf.AddrPC.Offset, &Disp, pSym);
428    
429     /* �����������\�� */
430     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "#%d 0x%08x in ", frame, sf.AddrPC.Offset);
431     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
432     if (bResult) {
433     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%s() + 0x%x ", pSym->Name, Disp);
434     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
435     } else {
436     _snprintf_s(buf, sizeof(buf), _TRUNCATE, " --- ");
437     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
438     }
439    
440     // ���s�t�@�C����������
441     ZeroMemory( &(ih_module), sizeof(ih_module) );
442     ih_module.SizeOfStruct = sizeof(ih_module);
443     bResult = SymGetModuleInfo( hProcess, sf.AddrPC.Offset, &(ih_module) );
444     strncat_s(msg, sizeof(msg), "at ", _TRUNCATE);
445     if (bResult) {
446     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%s ", ih_module.ImageName );
447     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
448     } else {
449     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%s ", "<Unknown Module>" );
450     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
451     }
452    
453     // �t�@�C�������s����������
454     ZeroMemory( &(ih_line), sizeof(ih_line) );
455     ih_line.SizeOfStruct = sizeof(ih_line);
456     bResult = SymGetLineFromAddr( hProcess, sf.AddrPC.Offset, &Disp, &ih_line );
457     if (bResult)
458     {
459     _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%s:%lu", ih_line.FileName, ih_line.LineNumber );
460     strncat_s(msg, sizeof(msg), buf, _TRUNCATE);
461     }
462    
463     strncat_s(msg, sizeof(msg), "\r\n", _TRUNCATE);
464     }
465    
466     /* ������ */
467     SymCleanup(hProcess);
468     GlobalUnlock(pSym);
469     GlobalFree(pSym);
470    
471     MessageBox(NULL, msg, "Tera Term: Application fault", MB_OK | MB_ICONEXCLAMATION);
472    
473     error:
474     // return (EXCEPTION_EXECUTE_HANDLER); /* ���������v���Z�X���I�������� */
475     return (EXCEPTION_CONTINUE_SEARCH); /* ���������m�A�v���P�[�V�����G���[�n�|�b�v�A�b�v���b�Z�[�W�{�b�N�X�������o�� */
476     }
477    
478    
479     CVTWindow::CVTWindow()
480     {
481     WNDCLASS wc;
482     RECT rect;
483     DWORD Style;
484     #ifdef ALPHABLEND_TYPE2
485     DWORD ExStyle;
486     #endif
487     char Temp[MAXPATHLEN];
488     char *Param;
489     int CmdShow;
490     PKeyMap tempkm;
491    
492     #ifdef _DEBUG
493     ::_CrtSetDbgFlag(_CRTDBG_ALLOC_MEM_DF | _CRTDBG_LEAK_CHECK_DF);
494     #endif
495    
496     // ���O�n���h�����t�b�N (2007.9.30 yutaka)
497     SetUnhandledExceptionFilter(ApplicationFaultHandler);
498    
499     TTXInit(&ts, &cv); /* TTPLUG */
500    
501     CommInit(&cv);
502    
503     MsgDlgHelp = RegisterWindowMessage(HELPMSGSTRING);
504    
505     if (StartTeraTerm(&ts)) {
506     /* first instance */
507     if (LoadTTSET()) {
508     /* read setup info from "teraterm.ini" */
509     (*ReadIniFile)(ts.SetupFName, &ts);
510     /* read keycode map from "keyboard.cnf" */
511     tempkm = (PKeyMap)malloc(sizeof(TKeyMap));
512     if (tempkm!=NULL) {
513     strncpy_s(Temp, sizeof(Temp), ts.HomeDir, _TRUNCATE);
514     AppendSlash(Temp,sizeof(Temp));
515     strncat_s(Temp,sizeof(Temp),"KEYBOARD.CNF",_TRUNCATE);
516     (*ReadKeyboardCnf)(Temp,tempkm,TRUE);
517     }
518     FreeTTSET();
519     /* store default sets in TTCMN */
520 maya 2482 #if 0
521 maya 2476 ChangeDefaultSet(&ts,tempkm);
522 maya 2482 #else
523     ChangeDefaultSet(NULL,tempkm);
524     #endif
525 maya 2476 if (tempkm!=NULL) free(tempkm);
526     }
527    
528     } else {
529     // 2�������~���v���Z�X�����������A�f�B�X�N���� TERATERM.INI �������B(2004.11.4 yutaka)
530     if (LoadTTSET()) {
531     /* read setup info from "teraterm.ini" */
532     (*ReadIniFile)(ts.SetupFName, &ts);
533     /* read keycode map from "keyboard.cnf" */
534     tempkm = (PKeyMap)malloc(sizeof(TKeyMap));
535     if (tempkm!=NULL) {
536     strncpy_s(Temp, sizeof(Temp, ts.HomeDir), ts.HomeDir, _TRUNCATE);
537     AppendSlash(Temp,sizeof(Temp));
538     strncat_s(Temp,sizeof(Temp),"KEYBOARD.CNF",_TRUNCATE);
539     (*ReadKeyboardCnf)(Temp,tempkm,TRUE);
540     }
541     FreeTTSET();
542     /* store default sets in TTCMN */
543     if (tempkm!=NULL) free(tempkm);
544     }
545    
546     }
547    
548     /* Parse command line parameters*/
549     // 256�o�C�g�������R�}���h���C���p�����[�^�w�����������ABOF(Buffer Over Flow)��
550     // �������o�O���C���B(2007.6.12 maya)
551     Param = GetCommandLine();
552     if (LoadTTSET())
553     (*ParseParam)(Param, &ts, &(TopicName[0]));
554     FreeTTSET();
555    
556     // duplicate session���w�������������A���L�����������R�s�[���� (2004.12.7 yutaka)
557     if (ts.DuplicateSession == 1) {
558     CopyShmemToTTSet(&ts);
559     }
560    
561     InitKeyboard();
562     SetKeyMap();
563    
564     // �R�}���h���C�����������t�@�C���������X���������������������� (2008.1.25 maya)
565     cv.isSSH = 0;
566    
567     /* window status */
568     AdjustSize = TRUE;
569     Minimized = FALSE;
570     LButton = FALSE;
571     MButton = FALSE;
572     RButton = FALSE;
573     DblClk = FALSE;
574     AfterDblClk = FALSE;
575     TplClk = FALSE;
576     Hold = FALSE;
577     FirstPaint = TRUE;
578     ScrollLock = FALSE; // �����l������ (2006.11.14 yutaka)
579    
580     /* Initialize scroll buffer */
581     InitBuffer();
582    
583     InitDisp();
584    
585     if (ts.HideTitle>0) {
586     Style = WS_VSCROLL | WS_HSCROLL |
587     WS_BORDER | WS_THICKFRAME | WS_POPUP;
588    
589     #ifdef ALPHABLEND_TYPE2
590     if(BGNoFrame)
591     Style &= ~(WS_BORDER | WS_THICKFRAME);
592     #endif
593     }
594     else
595     #ifdef WINDOW_MAXMIMUM_ENABLED
596     Style = WS_VSCROLL | WS_HSCROLL |
597     WS_BORDER | WS_THICKFRAME |
598     WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX | WS_MAXIMIZEBOX;
599     #else
600     Style = WS_VSCROLL | WS_HSCROLL |
601     WS_BORDER | WS_THICKFRAME |
602     WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX;
603     #endif
604    
605     wc.style = CS_DBLCLKS | CS_HREDRAW | CS_VREDRAW;
606     wc.lpfnWndProc = AfxWndProc;
607     wc.cbClsExtra = 0;
608     wc.cbWndExtra = 0;
609     wc.hInstance = AfxGetInstanceHandle();
610 doda 2497 wc.hIcon = LoadIcon(wc.hInstance, MAKEINTRESOURCE((ts.VTIcon!=IdIconDefault)?ts.VTIcon:IDI_VT));
611 maya 2476 //wc.hCursor = LoadCursor(NULL,IDC_IBEAM);
612     wc.hCursor = NULL; // �}�E�X�J�[�\�������I�����X���� (2005.4.2 yutaka)
613     wc.hbrBackground = NULL;
614     wc.lpszMenuName = NULL;
615     wc.lpszClassName = VTClassName;
616    
617     RegisterClass(&wc);
618     LoadAccelTable(MAKEINTRESOURCE(IDR_ACC));
619    
620     if (ts.VTPos.x==CW_USEDEFAULT)
621     rect = rectDefault;
622     else {
623     rect.left = ts.VTPos.x;
624     rect.top = ts.VTPos.y;
625     rect.right = rect.left + 100;
626     rect.bottom = rect.top + 100;
627     }
628     Create(VTClassName, "Tera Term", Style, rect, NULL, NULL);
629    
630     /*--------- Init2 -----------------*/
631     HVTWin = GetSafeHwnd();
632     if (HVTWin == NULL) return;
633     // register this window to the window list
634     SerialNo = RegWin(HVTWin,NULL);
635    
636     logfile_lock_initialize();
637     SetWindowStyle(&ts);
638     // ���P�[��������
639     // wctomb ������
640     setlocale(LC_ALL, ts.Locale);
641    
642     #ifdef ALPHABLEND_TYPE2
643     //<!--by AKASI
644     if(BGNoFrame && ts.HideTitle > 0) {
645     ExStyle = GetWindowLong(HVTWin,GWL_EXSTYLE);
646     ExStyle &= ~WS_EX_CLIENTEDGE;
647     SetWindowLong(HVTWin,GWL_EXSTYLE,ExStyle);
648     }
649     //-->
650     #endif
651    
652     // set the small icon
653     ::PostMessage(HVTWin,WM_SETICON,0,
654     (LPARAM)LoadImage(AfxGetInstanceHandle(),
655 doda 2497 MAKEINTRESOURCE((ts.VTIcon!=IdIconDefault)?ts.VTIcon:IDI_VT),
656 maya 2476 IMAGE_ICON,16,16,0));
657     MainMenu = NULL;
658     WinMenu = NULL;
659     if ((ts.HideTitle==0) && (ts.PopupMenu==0)) {
660     InitMenu(&MainMenu);
661     ::SetMenu(HVTWin,MainMenu);
662     }
663    
664     /* Reset Terminal */
665     ResetTerminal();
666    
667     if ((ts.PopupMenu>0) || (ts.HideTitle>0))
668     ::PostMessage(HVTWin,WM_USER_CHANGEMENU,0,0);
669    
670     ChangeFont();
671    
672     ResetIME();
673    
674     BuffChangeWinSize(NumOfColumns,NumOfLines);
675    
676     ChangeTitle();
677     /* Enable drag-drop */
678     ::DragAcceptFiles(HVTWin,TRUE);
679    
680     if (ts.HideWindow>0) {
681     if (strlen(TopicName)>0) {
682     InitDDE();
683     SendDDEReady();
684     }
685     FirstPaint = FALSE;
686     Startup();
687     return;
688     }
689     CmdShow = SW_SHOWDEFAULT;
690     if (ts.Minimize>0)
691     CmdShow = SW_SHOWMINIMIZED;
692     ShowWindow(CmdShow);
693     ChangeCaret();
694     }
695    
696     /////////////////////////////////////////////////////////////////////////////
697    
698     #ifdef _DEBUG
699     void CVTWindow::AssertValid() const
700     {
701     CFrameWnd::AssertValid();
702     }
703    
704     void CVTWindow::Dump(CDumpContext& dc) const
705     {
706     CFrameWnd::Dump(dc);
707     }
708    
709     #endif //_DEBUG
710    
711     /////////////////////////////////////////////////////////////////////////////
712    
713     int CVTWindow::Parse()
714     {
715     // added ScrollLock (2006.11.14 yutaka)
716     if (LButton || MButton || RButton || ScrollLock)
717     return 0;
718     return (VTParse()); // Parse received characters
719     }
720    
721     void CVTWindow::ButtonUp(BOOL Paste)
722     {
723     BOOL disableBuffEndSelect = false;
724     BOOL pasteRButton = RButton && Paste;
725     BOOL pasteMButton = MButton && Paste;
726    
727     /* disable autoscrolling */
728     ::KillTimer(HVTWin,IdScrollTimer);
729     ReleaseCapture();
730    
731     if (ts.SelectOnlyByLButton &&
732     (MButton || RButton)) {
733     disableBuffEndSelect = true;
734     }
735    
736     LButton = FALSE;
737     MButton = FALSE;
738     RButton = FALSE;
739     DblClk = FALSE;
740     TplClk = FALSE;
741     CaretOn();
742    
743     // SelectOnlyByLButton �� on �� ���E�E�N���b�N����������
744     // �o�b�t�@���I���������������A�I�����e���N���b�v�{�[�h��
745     // �R�s�[�������������������C�� (2007.12.6 maya)
746     if (!disableBuffEndSelect) {
747     BuffEndSelect();
748     }
749    
750     // added ConfirmPasteMouseRButton (2007.3.17 maya)
751     if (pasteRButton && !ts.ConfirmPasteMouseRButton) {
752 salarm 2514 if (CBStartPasteConfirmChange(HVTWin)) {
753 maya 2476 CBStartPaste(HVTWin,FALSE,0,NULL,0);
754 salarm 2514 /* �����s�����������X�N���[����������������
755     �y�[�X�g�������X�N���[�������� */
756     if (ts.AutoScrollOnlyInBottomLine != 0 && WinOrgY != 0) {
757     DispVScroll(SCROLL_BOTTOM, 0);
758     }
759     }
760 maya 2476 }
761     else if (pasteMButton) {
762 salarm 2514 if (CBStartPasteConfirmChange(HVTWin)) {
763 maya 2476 CBStartPaste(HVTWin,FALSE,0,NULL,0);
764 salarm 2514 /* �����s�����������X�N���[����������������
765     �y�[�X�g�������X�N���[�������� */
766     if (ts.AutoScrollOnlyInBottomLine != 0 && WinOrgY != 0) {
767     DispVScroll(SCROLL_BOTTOM, 0);
768     }
769     }
770 maya 2476 }
771     }
772    
773     void CVTWindow::ButtonDown(POINT p, int LMR)
774     {
775     HMENU PopupMenu, PopupBase;
776     BOOL mousereport;
777    
778     if ((LMR==IdLeftButton) && ControlKey() && (MainMenu==NULL) &&
779     ((ts.MenuFlag & MF_NOPOPUP)==0)) {
780     int i, numItems;
781     char itemText[256];
782    
783     InitMenu(&PopupMenu);
784    
785     PopupBase = CreatePopupMenu();
786     numItems = GetMenuItemCount(PopupMenu);
787    
788     for (i = 0; i < numItems; i++) {
789     HMENU submenu = GetSubMenu(PopupMenu, i);
790    
791     if (submenu != NULL) {
792     InitMenuPopup(submenu);
793     }
794    
795     if (GetMenuString(PopupMenu, i, itemText, sizeof(itemText), MF_BYPOSITION) != 0) {
796     int state = GetMenuState(PopupMenu, i, MF_BYPOSITION) &
797     (MF_CHECKED | MF_DISABLED | MF_GRAYED | MF_HILITE |
798     MF_MENUBARBREAK | MF_MENUBREAK | MF_SEPARATOR);
799    
800     AppendMenu(PopupBase,
801     submenu != NULL ? LOBYTE(state) | MF_POPUP : state,
802     submenu != NULL ? (UINT)submenu : GetMenuItemID(PopupMenu, i),
803     itemText);
804     }
805     }
806    
807     ::ClientToScreen(HVTWin, &p);
808     TrackPopupMenu(PopupBase,TPM_LEFTALIGN | TPM_LEFTBUTTON,
809     p.x,p.y,0,HVTWin,NULL);
810     if (WinMenu!=NULL) {
811     DestroyMenu(WinMenu);
812     WinMenu = NULL;
813     }
814     DestroyMenu(PopupBase);
815     DestroyMenu(PopupMenu);
816     PopupMenu = 0;
817     return;
818     }
819    
820     mousereport = MouseReport(IdMouseEventBtnDown, LMR, p.x, p.y);
821    
822     // added ConfirmPasteMouseRButton (2007.3.17 maya)
823     if ((LMR == IdRightButton) &&
824     !ts.DisablePasteMouseRButton &&
825     ts.ConfirmPasteMouseRButton &&
826     cv.Ready &&
827     !mousereport &&
828     (SendVar==NULL) && (FileVar==NULL) &&
829     (cv.PortType!=IdFile) &&
830     (IsClipboardFormatAvailable(CF_TEXT) ||
831     IsClipboardFormatAvailable(CF_OEMTEXT))) {
832    
833     int i, numItems;
834     char itemText[256];
835    
836     InitPasteMenu(&PopupMenu);
837     PopupBase = CreatePopupMenu();
838     numItems = GetMenuItemCount(PopupMenu);
839    
840     for (i = 0; i < numItems; i++) {
841     if (GetMenuString(PopupMenu, i, itemText, sizeof(itemText), MF_BYPOSITION) != 0) {
842     int state = GetMenuState(PopupMenu, i, MF_BYPOSITION) &
843     (MF_CHECKED | MF_DISABLED | MF_GRAYED | MF_HILITE |
844     MF_MENUBARBREAK | MF_MENUBREAK | MF_SEPARATOR);
845    
846     AppendMenu(PopupBase, state,
847     GetMenuItemID(PopupMenu, i), itemText);
848     }
849     }
850    
851     ::ClientToScreen(HVTWin, &p);
852     TrackPopupMenu(PopupBase,TPM_LEFTALIGN | TPM_LEFTBUTTON,
853     p.x,p.y,0,HVTWin,NULL);
854     if (WinMenu!=NULL) {
855     DestroyMenu(WinMenu);
856     WinMenu = NULL;
857     }
858     DestroyMenu(PopupBase);
859     DestroyMenu(PopupMenu);
860     PopupMenu = 0;
861     return;
862     }
863    
864     if (AfterDblClk && (LMR==IdLeftButton) &&
865     (abs(p.x-DblClkX)<=GetSystemMetrics(SM_CXDOUBLECLK)) &&
866     (abs(p.y-DblClkY)<=GetSystemMetrics(SM_CYDOUBLECLK))) {
867     /* triple click */
868     ::KillTimer(HVTWin, IdDblClkTimer);
869     AfterDblClk = FALSE;
870     BuffTplClk(p.y);
871     LButton = TRUE;
872     TplClk = TRUE;
873     /* for AutoScrolling */
874     ::SetCapture(HVTWin);
875     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
876     }
877     else {
878     if (! (LButton || MButton || RButton)) {
879     BOOL box = FALSE;
880    
881 doda 2545 // select several pages of output from Tera Term window (2005.5.15 yutaka)
882 maya 2476 if (LMR == IdLeftButton && ShiftKey()) {
883     BuffSeveralPagesSelect(p.x, p.y);
884    
885     } else {
886     // Select rectangular block with Alt Key. Delete Shift key.(2005.5.15 yutaka)
887     if (LMR == IdLeftButton && AltKey()) {
888     box = TRUE;
889     }
890    
891     // Starting the selection only by a left button.(2007.11.20 maya)
892     if (!ts.SelectOnlyByLButton ||
893     (ts.SelectOnlyByLButton && LMR == IdLeftButton) ) {
894     BuffStartSelect(p.x,p.y, box);
895     TplClk = FALSE;
896    
897     /* for AutoScrolling */
898     ::SetCapture(HVTWin);
899     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
900     }
901     }
902     }
903    
904     switch (LMR) {
905     case IdRightButton:
906     RButton = TRUE;
907     break;
908     case IdMiddleButton:
909     MButton = TRUE;
910     break;
911     case IdLeftButton:
912     LButton = TRUE;
913     break;
914     }
915     }
916     }
917    
918     // LogMeIn.exe -> LogMeTT.exe �����l�[�� (2005.2.21 yutaka)
919     char *LogMeTTexename = "LogMeTT.exe";
920     static char LogMeTTMenuString[] = "Log&MeTT";
921     static BOOL isLogMeTTExist()
922     {
923     char LogMeTT[MAX_PATH];
924    
925     strncpy_s(LogMeTT, sizeof(LogMeTT), ts.HomeDir, _TRUNCATE);
926     AppendSlash(LogMeTT, sizeof(LogMeTT));
927     strncat_s(LogMeTT, sizeof(LogMeTT), LogMeTTexename, _TRUNCATE);
928    
929     if (_access(LogMeTT, 0) == -1) {
930     return FALSE;
931     }
932     return TRUE;
933     }
934    
935     void CVTWindow::InitMenu(HMENU *Menu)
936     {
937     *Menu = LoadMenu(AfxGetInstanceHandle(),
938     MAKEINTRESOURCE(IDR_MENU));
939     char uimsg[MAX_UIMSG];
940     int ret;
941    
942     FileMenu = GetSubMenu(*Menu,ID_FILE);
943     TransMenu = GetSubMenu(FileMenu,ID_TRANSFER);
944     EditMenu = GetSubMenu(*Menu,ID_EDIT);
945     SetupMenu = GetSubMenu(*Menu,ID_SETUP);
946     ControlMenu = GetSubMenu(*Menu,ID_CONTROL);
947     HelpMenu = GetSubMenu(*Menu,ID_HELPMENU);
948    
949     /* LogMeTT ���������m�F�������j���[���������� */
950     if (isLogMeTTExist()) {
951     ::InsertMenu(FileMenu, ID_FILE_PRINT2, MF_STRING | MF_ENABLED | MF_BYCOMMAND,
952     ID_FILE_LOGMEIN, LogMeTTMenuString);
953     ::InsertMenu(FileMenu, ID_FILE_PRINT2, MF_SEPARATOR, NULL, NULL);
954     DrawMenuBar();
955     }
956    
957     GetMenuString(*Menu, ID_FILE, uimsg, sizeof(uimsg), MF_BYPOSITION);
958     get_lang_msg("MENU_FILE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
959     ModifyMenu(*Menu, ID_FILE, MF_BYPOSITION, ID_FILE, ts.UIMsg);
960     GetMenuString(FileMenu, ID_FILE_NEWCONNECTION, uimsg, sizeof(uimsg), MF_BYCOMMAND);
961     get_lang_msg("MENU_FILE_NEW", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
962     ModifyMenu(FileMenu, ID_FILE_NEWCONNECTION, MF_BYCOMMAND, ID_FILE_NEWCONNECTION, ts.UIMsg);
963     GetMenuString(FileMenu, ID_FILE_DUPLICATESESSION, uimsg, sizeof(uimsg), MF_BYCOMMAND);
964     get_lang_msg("MENU_FILE_DUPLICATE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
965     ModifyMenu(FileMenu, ID_FILE_DUPLICATESESSION, MF_BYCOMMAND, ID_FILE_DUPLICATESESSION, ts.UIMsg);
966     GetMenuString(FileMenu, ID_FILE_CYGWINCONNECTION, uimsg, sizeof(uimsg), MF_BYCOMMAND);
967     get_lang_msg("MENU_FILE_GYGWIN", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
968     ModifyMenu(FileMenu, ID_FILE_CYGWINCONNECTION, MF_BYCOMMAND, ID_FILE_CYGWINCONNECTION, ts.UIMsg);
969     GetMenuString(FileMenu, ID_FILE_LOG, uimsg, sizeof(uimsg), MF_BYCOMMAND);
970     get_lang_msg("MENU_FILE_LOG", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
971     ModifyMenu(FileMenu, ID_FILE_LOG, MF_BYCOMMAND, ID_FILE_LOG, ts.UIMsg);
972     GetMenuString(FileMenu, ID_FILE_COMMENTTOLOG, uimsg, sizeof(uimsg), MF_BYCOMMAND);
973     get_lang_msg("MENU_FILE_COMMENTLOG", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
974     ModifyMenu(FileMenu, ID_FILE_COMMENTTOLOG, MF_BYCOMMAND, ID_FILE_COMMENTTOLOG, ts.UIMsg);
975     GetMenuString(FileMenu, ID_FILE_VIEWLOG, uimsg, sizeof(uimsg), MF_BYCOMMAND);
976     get_lang_msg("MENU_FILE_VIEWLOG", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
977     ModifyMenu(FileMenu, ID_FILE_VIEWLOG, MF_BYCOMMAND, ID_FILE_VIEWLOG, ts.UIMsg);
978     GetMenuString(FileMenu, ID_FILE_SHOWLOGDIALOG, uimsg, sizeof(uimsg), MF_BYCOMMAND);
979     get_lang_msg("MENU_FILE_SHOWLOGDIALOG", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
980     ModifyMenu(FileMenu, ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND, ID_FILE_SHOWLOGDIALOG, ts.UIMsg);
981     GetMenuString(FileMenu, ID_FILE_SENDFILE, uimsg, sizeof(uimsg), MF_BYCOMMAND);
982     get_lang_msg("MENU_FILE_SENDFILE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
983     ModifyMenu(FileMenu, ID_FILE_SENDFILE, MF_BYCOMMAND, ID_FILE_SENDFILE, ts.UIMsg);
984     GetMenuString(FileMenu, ID_FILE_REPLAYLOG, uimsg, sizeof(uimsg), MF_BYCOMMAND);
985     get_lang_msg("MENU_FILE_REPLAYLOG", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
986     ModifyMenu(FileMenu, ID_FILE_REPLAYLOG, MF_BYCOMMAND, ID_FILE_REPLAYLOG, ts.UIMsg);
987     GetMenuString(FileMenu, ID_FILE_CHANGEDIR, uimsg, sizeof(uimsg), MF_BYCOMMAND);
988     get_lang_msg("MENU_FILE_CHANGEDIR", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
989     ModifyMenu(FileMenu, ID_FILE_CHANGEDIR, MF_BYCOMMAND, ID_FILE_CHANGEDIR, ts.UIMsg);
990     ret = GetMenuString(FileMenu, ID_FILE_LOGMEIN, uimsg, sizeof(uimsg), MF_BYCOMMAND);
991     if (ret != 0) {
992     get_lang_msg("MENU_FILE_LOGMETT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
993     ModifyMenu(FileMenu, ID_FILE_LOGMEIN, MF_BYCOMMAND, ID_FILE_LOGMEIN, ts.UIMsg);
994     }
995     GetMenuString(FileMenu, ID_FILE_PRINT2, uimsg, sizeof(uimsg), MF_BYCOMMAND);
996     get_lang_msg("MENU_FILE_PRINT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
997     ModifyMenu(FileMenu, ID_FILE_PRINT2, MF_BYCOMMAND, ID_FILE_PRINT2, ts.UIMsg);
998     GetMenuString(FileMenu, ID_FILE_DISCONNECT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
999     get_lang_msg("MENU_FILE_DISCONNECT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1000     ModifyMenu(FileMenu, ID_FILE_DISCONNECT, MF_BYCOMMAND, ID_FILE_DISCONNECT, ts.UIMsg);
1001     GetMenuString(FileMenu, ID_FILE_EXIT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1002     get_lang_msg("MENU_FILE_EXIT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1003     ModifyMenu(FileMenu, ID_FILE_EXIT, MF_BYCOMMAND, ID_FILE_EXIT, ts.UIMsg);
1004    
1005     GetMenuString(FileMenu, 9, uimsg, sizeof(uimsg), MF_BYPOSITION);
1006     get_lang_msg("MENU_TRANS", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1007     ModifyMenu(FileMenu, 9, MF_BYPOSITION, 9, ts.UIMsg);
1008    
1009     GetMenuString(FileMenu, ID_FILE_KERMITRCV, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1010     get_lang_msg("MENU_TRANS_KERMIT_RCV", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1011     ModifyMenu(FileMenu, ID_FILE_KERMITRCV, MF_BYCOMMAND, ID_FILE_KERMITRCV, ts.UIMsg);
1012     GetMenuString(FileMenu, ID_FILE_KERMITGET, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1013     get_lang_msg("MENU_TRANS_KERMIT_GET", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1014     ModifyMenu(FileMenu, ID_FILE_KERMITGET, MF_BYCOMMAND, ID_FILE_KERMITGET, ts.UIMsg);
1015     GetMenuString(FileMenu, ID_FILE_KERMITSEND, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1016     get_lang_msg("MENU_TRANS_KERMIT_SEND", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1017     ModifyMenu(FileMenu, ID_FILE_KERMITSEND, MF_BYCOMMAND, ID_FILE_KERMITSEND, ts.UIMsg);
1018     GetMenuString(FileMenu, ID_FILE_KERMITFINISH, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1019     get_lang_msg("MENU_TRANS_KERMIT_FINISH", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1020     ModifyMenu(FileMenu, ID_FILE_KERMITFINISH, MF_BYCOMMAND, ID_FILE_KERMITFINISH, ts.UIMsg);
1021    
1022     GetMenuString(FileMenu, ID_FILE_XRCV, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1023     get_lang_msg("MENU_TRANS_X_RCV", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1024     ModifyMenu(FileMenu, ID_FILE_XRCV, MF_BYCOMMAND, ID_FILE_XRCV, ts.UIMsg);
1025     GetMenuString(FileMenu, ID_FILE_XSEND, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1026     get_lang_msg("MENU_TRANS_X_SEND", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1027     ModifyMenu(FileMenu, ID_FILE_XSEND, MF_BYCOMMAND, ID_FILE_XSEND, ts.UIMsg);
1028    
1029 yutakapon 2511 // TBD: YMODEM���������T�|�[�g�������A���j���[���B���B(2008.5.15 yutaka)
1030 yutakapon 2512 //#define YMODEM_TBD
1031     #ifndef YMODEM_TBD
1032 maya 2532 DeleteMenu(TransMenu, 2, MF_BYPOSITION);
1033 yutakapon 2511 DeleteMenu(FileMenu, ID_FILE_YRCV, MF_BYCOMMAND);
1034     DeleteMenu(FileMenu, ID_FILE_YSEND, MF_BYCOMMAND);
1035     DrawMenuBar();
1036 yutakapon 2512 #endif
1037     #undef YMODEM_TBD
1038 yutakapon 2511
1039 maya 2476 GetMenuString(FileMenu, ID_FILE_ZRCV, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1040     get_lang_msg("MENU_TRANS_Z_RCV", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1041     ModifyMenu(FileMenu, ID_FILE_ZRCV, MF_BYCOMMAND, ID_FILE_ZRCV, ts.UIMsg);
1042     GetMenuString(FileMenu, ID_FILE_ZSEND, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1043     get_lang_msg("MENU_TRANS_Z_SEND", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1044     ModifyMenu(FileMenu, ID_FILE_ZSEND, MF_BYCOMMAND, ID_FILE_ZSEND, ts.UIMsg);
1045    
1046     GetMenuString(FileMenu, ID_FILE_BPRCV, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1047     get_lang_msg("MENU_TRANS_BP_RCV", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1048     ModifyMenu(FileMenu, ID_FILE_BPRCV, MF_BYCOMMAND, ID_FILE_BPRCV, ts.UIMsg);
1049     GetMenuString(FileMenu, ID_FILE_BPSEND, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1050     get_lang_msg("MENU_TRANS_BP_SEND", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1051     ModifyMenu(FileMenu, ID_FILE_BPSEND, MF_BYCOMMAND, ID_FILE_BPSEND, ts.UIMsg);
1052    
1053     GetMenuString(FileMenu, ID_FILE_QVRCV, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1054     get_lang_msg("MENU_TRANS_QV_RCV", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1055     ModifyMenu(FileMenu, ID_FILE_QVRCV, MF_BYCOMMAND, ID_FILE_QVRCV, ts.UIMsg);
1056     GetMenuString(FileMenu, ID_FILE_QVSEND, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1057     get_lang_msg("MENU_TRANS_QV_SEND", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1058     ModifyMenu(FileMenu, ID_FILE_QVSEND, MF_BYCOMMAND, ID_FILE_QVSEND, ts.UIMsg);
1059    
1060     GetMenuString(*Menu, ID_EDIT, uimsg, sizeof(uimsg), MF_BYPOSITION);
1061     get_lang_msg("MENU_EDIT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1062     ModifyMenu(*Menu, ID_EDIT, MF_BYPOSITION, ID_EDIT, ts.UIMsg);
1063     GetMenuString(EditMenu, ID_EDIT_COPY2, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1064     get_lang_msg("MENU_EDIT_COPY", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1065     ModifyMenu(EditMenu, ID_EDIT_COPY2, MF_BYCOMMAND, ID_EDIT_COPY2, ts.UIMsg);
1066     GetMenuString(EditMenu, ID_EDIT_COPYTABLE, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1067     get_lang_msg("MENU_EDIT_COPYTABLE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1068     ModifyMenu(EditMenu, ID_EDIT_COPYTABLE, MF_BYCOMMAND, ID_EDIT_COPYTABLE, ts.UIMsg);
1069     GetMenuString(EditMenu, ID_EDIT_PASTE2, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1070     get_lang_msg("MENU_EDIT_PASTE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1071     ModifyMenu(EditMenu, ID_EDIT_PASTE2, MF_BYCOMMAND, ID_EDIT_PASTE2, ts.UIMsg);
1072     GetMenuString(EditMenu, ID_EDIT_PASTECR, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1073     get_lang_msg("MENU_EDIT_PASTECR", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1074     ModifyMenu(EditMenu, ID_EDIT_PASTECR, MF_BYCOMMAND, ID_EDIT_PASTECR, ts.UIMsg);
1075     GetMenuString(EditMenu, ID_EDIT_CLEARSCREEN, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1076     get_lang_msg("MENU_EDIT_CLSCREEN", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1077     ModifyMenu(EditMenu, ID_EDIT_CLEARSCREEN, MF_BYCOMMAND, ID_EDIT_CLEARSCREEN, ts.UIMsg);
1078     GetMenuString(EditMenu, ID_EDIT_CLEARBUFFER, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1079     get_lang_msg("MENU_EDIT_CLBUFFER", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1080     ModifyMenu(EditMenu, ID_EDIT_CLEARBUFFER, MF_BYCOMMAND, ID_EDIT_CLEARBUFFER, ts.UIMsg);
1081     GetMenuString(EditMenu, ID_EDIT_CANCELSELECT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1082     get_lang_msg("MENU_EDIT_CANCELSELECT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1083     ModifyMenu(EditMenu, ID_EDIT_CANCELSELECT, MF_BYCOMMAND, ID_EDIT_CANCELSELECT, ts.UIMsg);
1084     GetMenuString(EditMenu, ID_EDIT_SELECTSCREEN, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1085     get_lang_msg("MENU_EDIT_SELECTSCREEN", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1086     ModifyMenu(EditMenu, ID_EDIT_SELECTSCREEN, MF_BYCOMMAND, ID_EDIT_SELECTSCREEN, ts.UIMsg);
1087     GetMenuString(EditMenu, ID_EDIT_SELECTALL, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1088     get_lang_msg("MENU_EDIT_SELECTALL", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1089     ModifyMenu(EditMenu, ID_EDIT_SELECTALL, MF_BYCOMMAND, ID_EDIT_SELECTALL, ts.UIMsg);
1090    
1091     GetMenuString(*Menu, ID_SETUP, uimsg, sizeof(uimsg), MF_BYPOSITION);
1092     get_lang_msg("MENU_SETUP", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1093     ModifyMenu(*Menu, ID_SETUP, MF_BYPOSITION, ID_SETUP, ts.UIMsg);
1094     GetMenuString(SetupMenu, ID_SETUP_TERMINAL, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1095     get_lang_msg("MENU_SETUP_TERMINAL", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1096     ModifyMenu(SetupMenu, ID_SETUP_TERMINAL, MF_BYCOMMAND, ID_SETUP_TERMINAL, ts.UIMsg);
1097     GetMenuString(SetupMenu, ID_SETUP_WINDOW, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1098     get_lang_msg("MENU_SETUP_WINDOW", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1099     ModifyMenu(SetupMenu, ID_SETUP_WINDOW, MF_BYCOMMAND, ID_SETUP_WINDOW, ts.UIMsg);
1100     GetMenuString(SetupMenu, ID_SETUP_FONT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1101     get_lang_msg("MENU_SETUP_FONT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1102     ModifyMenu(SetupMenu, ID_SETUP_FONT, MF_BYCOMMAND, ID_SETUP_FONT, ts.UIMsg);
1103     GetMenuString(SetupMenu, ID_SETUP_KEYBOARD, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1104     get_lang_msg("MENU_SETUP_KEYBOARD", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1105     ModifyMenu(SetupMenu, ID_SETUP_KEYBOARD, MF_BYCOMMAND, ID_SETUP_KEYBOARD, ts.UIMsg);
1106     GetMenuString(SetupMenu, ID_SETUP_SERIALPORT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1107     get_lang_msg("MENU_SETUP_SERIALPORT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1108     ModifyMenu(SetupMenu, ID_SETUP_SERIALPORT, MF_BYCOMMAND, ID_SETUP_SERIALPORT, ts.UIMsg);
1109     GetMenuString(SetupMenu, ID_SETUP_TCPIP, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1110     get_lang_msg("MENU_SETUP_TCPIP", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1111     ModifyMenu(SetupMenu, ID_SETUP_TCPIP, MF_BYCOMMAND, ID_SETUP_TCPIP, ts.UIMsg);
1112     GetMenuString(SetupMenu, ID_SETUP_GENERAL, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1113     get_lang_msg("MENU_SETUP_GENERAL", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1114     ModifyMenu(SetupMenu, ID_SETUP_GENERAL, MF_BYCOMMAND, ID_SETUP_GENERAL, ts.UIMsg);
1115     GetMenuString(SetupMenu, ID_SETUP_ADDITIONALSETTINGS, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1116     get_lang_msg("MENU_SETUP_ADDITION", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1117     ModifyMenu(SetupMenu, ID_SETUP_ADDITIONALSETTINGS, MF_BYCOMMAND, ID_SETUP_ADDITIONALSETTINGS, ts.UIMsg);
1118     GetMenuString(SetupMenu, ID_SETUP_SAVE, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1119     get_lang_msg("MENU_SETUP_SAVE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1120     ModifyMenu(SetupMenu, ID_SETUP_SAVE, MF_BYCOMMAND, ID_SETUP_SAVE, ts.UIMsg);
1121     GetMenuString(SetupMenu, ID_SETUP_RESTORE, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1122     get_lang_msg("MENU_SETUP_RESTORE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1123     ModifyMenu(SetupMenu, ID_SETUP_RESTORE, MF_BYCOMMAND, ID_SETUP_RESTORE, ts.UIMsg);
1124     GetMenuString(SetupMenu, ID_SETUP_LOADKEYMAP, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1125     get_lang_msg("MENU_SETUP_LOADKEYMAP", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1126     ModifyMenu(SetupMenu, ID_SETUP_LOADKEYMAP, MF_BYCOMMAND, ID_SETUP_LOADKEYMAP, ts.UIMsg);
1127    
1128     GetMenuString(*Menu, ID_CONTROL, uimsg, sizeof(uimsg), MF_BYPOSITION);
1129     get_lang_msg("MENU_CONTROL", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1130     ModifyMenu(*Menu, ID_CONTROL, MF_BYPOSITION, ID_CONTROL, ts.UIMsg);
1131     GetMenuString(ControlMenu, ID_CONTROL_RESETTERMINAL, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1132     get_lang_msg("MENU_CONTROL_RESET", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1133     ModifyMenu(ControlMenu, ID_CONTROL_RESETTERMINAL, MF_BYCOMMAND, ID_CONTROL_RESETTERMINAL, ts.UIMsg);
1134     GetMenuString(ControlMenu, ID_CONTROL_AREYOUTHERE, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1135     get_lang_msg("MENU_CONTROL_AREYOUTHERE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1136     ModifyMenu(ControlMenu, ID_CONTROL_AREYOUTHERE, MF_BYCOMMAND, ID_CONTROL_AREYOUTHERE, ts.UIMsg);
1137     GetMenuString(ControlMenu, ID_CONTROL_SENDBREAK, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1138     get_lang_msg("MENU_CONTROL_SENDBREAK", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1139     ModifyMenu(ControlMenu, ID_CONTROL_SENDBREAK, MF_BYCOMMAND, ID_CONTROL_SENDBREAK, ts.UIMsg);
1140     GetMenuString(ControlMenu, ID_CONTROL_RESETPORT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1141     get_lang_msg("MENU_CONTROL_RESETPORT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1142     ModifyMenu(ControlMenu, ID_CONTROL_RESETPORT, MF_BYCOMMAND, ID_CONTROL_RESETPORT, ts.UIMsg);
1143     GetMenuString(ControlMenu, ID_CONTROL_BROADCASTCOMMAND, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1144     get_lang_msg("MENU_CONTROL_BROADCAST", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1145     ModifyMenu(ControlMenu, ID_CONTROL_BROADCASTCOMMAND, MF_BYCOMMAND, ID_CONTROL_BROADCASTCOMMAND, ts.UIMsg);
1146     GetMenuString(ControlMenu, ID_CONTROL_OPENTEK, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1147     get_lang_msg("MENU_CONTROL_OPENTEK", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1148     ModifyMenu(ControlMenu, ID_CONTROL_OPENTEK, MF_BYCOMMAND, ID_CONTROL_OPENTEK, ts.UIMsg);
1149     GetMenuString(ControlMenu, ID_CONTROL_CLOSETEK, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1150     get_lang_msg("MENU_CONTROL_CLOSETEK", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1151     ModifyMenu(ControlMenu, ID_CONTROL_CLOSETEK, MF_BYCOMMAND, ID_CONTROL_CLOSETEK, ts.UIMsg);
1152     GetMenuString(ControlMenu, ID_CONTROL_MACRO, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1153     get_lang_msg("MENU_CONTROL_MACRO", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1154     ModifyMenu(ControlMenu, ID_CONTROL_MACRO, MF_BYCOMMAND, ID_CONTROL_MACRO, ts.UIMsg);
1155    
1156     GetMenuString(*Menu, ID_HELPMENU, uimsg, sizeof(uimsg), MF_BYPOSITION);
1157     get_lang_msg("MENU_HELP", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1158     ModifyMenu(*Menu, ID_HELPMENU, MF_BYPOSITION, ID_HELPMENU, ts.UIMsg);
1159     GetMenuString(HelpMenu, ID_HELP_INDEX2, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1160     get_lang_msg("MENU_HELP_INDEX", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1161     ModifyMenu(HelpMenu, ID_HELP_INDEX2, MF_BYCOMMAND, ID_HELP_INDEX2, ts.UIMsg);
1162     GetMenuString(HelpMenu, ID_HELP_ABOUT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1163     get_lang_msg("MENU_HELP_ABOUT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1164     ModifyMenu(HelpMenu, ID_HELP_ABOUT, MF_BYCOMMAND, ID_HELP_ABOUT, ts.UIMsg);
1165    
1166     if ((ts.MenuFlag & MF_SHOWWINMENU) !=0) {
1167     WinMenu = CreatePopupMenu();
1168     get_lang_msg("MENU_WINDOW", ts.UIMsg, sizeof(ts.UIMsg),
1169     "&Window", ts.UILanguageFile);
1170     ::InsertMenu(*Menu,ID_HELPMENU,
1171     MF_STRING | MF_ENABLED | MF_POPUP | MF_BYPOSITION,
1172     (int)WinMenu, ts.UIMsg);
1173     }
1174    
1175     TTXModifyMenu(*Menu); /* TTPLUG */
1176     }
1177    
1178     void CVTWindow::InitMenuPopup(HMENU SubMenu)
1179     {
1180     if ( SubMenu == FileMenu )
1181     {
1182     if ( Connecting ) {
1183     EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_GRAYED);
1184     } else {
1185     EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_ENABLED);
1186     }
1187    
1188     if ( (! cv.Ready) || (SendVar!=NULL) ||
1189     (FileVar!=NULL) || (cv.PortType==IdFile) ) {
1190     EnableMenuItem(FileMenu,ID_FILE_SENDFILE,MF_BYCOMMAND | MF_GRAYED);
1191     EnableMenuItem(FileMenu,ID_TRANSFER,MF_BYPOSITION | MF_GRAYED); /* Transfer */
1192     EnableMenuItem(FileMenu,ID_FILE_CHANGEDIR,MF_BYCOMMAND | MF_GRAYED);
1193     EnableMenuItem(FileMenu,ID_FILE_DISCONNECT,MF_BYCOMMAND | MF_GRAYED);
1194     EnableMenuItem(FileMenu,ID_FILE_DUPLICATESESSION,MF_BYCOMMAND | MF_GRAYED);
1195     }
1196     else {
1197     EnableMenuItem(FileMenu,ID_FILE_SENDFILE,MF_BYCOMMAND | MF_ENABLED);
1198     EnableMenuItem(FileMenu,ID_TRANSFER,MF_BYPOSITION | MF_ENABLED); /* Transfer */
1199     EnableMenuItem(FileMenu,ID_FILE_CHANGEDIR,MF_BYCOMMAND | MF_ENABLED);
1200     EnableMenuItem(FileMenu,ID_FILE_DISCONNECT,MF_BYCOMMAND | MF_ENABLED);
1201     EnableMenuItem(FileMenu,ID_FILE_DUPLICATESESSION,MF_BYCOMMAND | MF_ENABLED);
1202     }
1203    
1204     // �V�K���j���[������ (2004.12.5 yutaka)
1205     EnableMenuItem(FileMenu,ID_FILE_CYGWINCONNECTION,MF_BYCOMMAND | MF_ENABLED);
1206     EnableMenuItem(FileMenu,ID_FILE_TERATERMMENU,MF_BYCOMMAND | MF_ENABLED);
1207     EnableMenuItem(FileMenu,ID_FILE_LOGMEIN,MF_BYCOMMAND | MF_ENABLED);
1208    
1209     // XXX: �������u�����������Alog���O���C�����������B (2005.2.1 yutaka)
1210     if (LogVar!=NULL) { // ���O�������[�h������
1211     EnableMenuItem(FileMenu,ID_FILE_LOG,MF_BYCOMMAND | MF_GRAYED);
1212     EnableMenuItem(FileMenu,ID_FILE_COMMENTTOLOG, MF_BYCOMMAND | MF_ENABLED);
1213     EnableMenuItem(FileMenu,ID_FILE_VIEWLOG, MF_BYCOMMAND | MF_ENABLED);
1214     if (ts.LogHideDialog) {
1215     EnableMenuItem(FileMenu,ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND | MF_ENABLED);
1216     }
1217     else {
1218     EnableMenuItem(FileMenu,ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND | MF_GRAYED);
1219     }
1220     } else {
1221     EnableMenuItem(FileMenu,ID_FILE_LOG,MF_BYCOMMAND | MF_ENABLED);
1222     EnableMenuItem(FileMenu,ID_FILE_COMMENTTOLOG, MF_BYCOMMAND | MF_GRAYED);
1223     EnableMenuItem(FileMenu,ID_FILE_VIEWLOG, MF_BYCOMMAND | MF_GRAYED);
1224     EnableMenuItem(FileMenu,ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND | MF_GRAYED);
1225     }
1226    
1227     }
1228     else if ( SubMenu == TransMenu )
1229     {
1230     if ((cv.PortType==IdSerial) &&
1231     ((ts.DataBit==IdDataBit7) || (ts.Flow==IdFlowX))) {
1232     EnableMenuItem(TransMenu,1,MF_BYPOSITION | MF_GRAYED); /* XMODEM */
1233     EnableMenuItem(TransMenu,4,MF_BYPOSITION | MF_GRAYED); /* Quick-VAN */
1234     }
1235     else {
1236     EnableMenuItem(TransMenu,1,MF_BYPOSITION | MF_ENABLED); /* XMODEM */
1237     EnableMenuItem(TransMenu,4,MF_BYPOSITION | MF_ENABLED); /* Quick-VAN */
1238     }
1239     if ((cv.PortType==IdSerial) &&
1240     (ts.DataBit==IdDataBit7)) {
1241     EnableMenuItem(TransMenu,2,MF_BYPOSITION | MF_GRAYED); /* ZMODEM */
1242     EnableMenuItem(TransMenu,3,MF_BYPOSITION | MF_GRAYED); /* B-Plus */
1243     }
1244     else {
1245     EnableMenuItem(TransMenu,2,MF_BYPOSITION | MF_ENABLED); /* ZMODEM */
1246     EnableMenuItem(TransMenu,3,MF_BYPOSITION | MF_ENABLED); /* B-Plus */
1247     }
1248     }
1249     else if (SubMenu == EditMenu)
1250     {
1251     if (Selected) {
1252     EnableMenuItem(EditMenu,ID_EDIT_COPY2,MF_BYCOMMAND | MF_ENABLED);
1253     EnableMenuItem(EditMenu,ID_EDIT_COPYTABLE,MF_BYCOMMAND | MF_ENABLED);
1254     }
1255     else {
1256     EnableMenuItem(EditMenu,ID_EDIT_COPY2,MF_BYCOMMAND | MF_GRAYED);
1257     EnableMenuItem(EditMenu,ID_EDIT_COPYTABLE,MF_BYCOMMAND | MF_GRAYED);
1258     }
1259     if (cv.Ready &&
1260     (SendVar==NULL) && (FileVar==NULL) &&
1261     (cv.PortType!=IdFile) &&
1262     (IsClipboardFormatAvailable(CF_TEXT) ||
1263     IsClipboardFormatAvailable(CF_OEMTEXT))) {
1264     EnableMenuItem(EditMenu,ID_EDIT_PASTE2,MF_BYCOMMAND | MF_ENABLED);
1265     EnableMenuItem(EditMenu,ID_EDIT_PASTECR,MF_BYCOMMAND | MF_ENABLED);
1266     }
1267     else {
1268     EnableMenuItem(EditMenu,ID_EDIT_PASTE2,MF_BYCOMMAND | MF_GRAYED);
1269     EnableMenuItem(EditMenu,ID_EDIT_PASTECR,MF_BYCOMMAND | MF_GRAYED);
1270     }
1271     }
1272     else if (SubMenu == SetupMenu)
1273     if (cv.Ready &&
1274     ((cv.PortType==IdTCPIP) || (cv.PortType==IdFile)) ||
1275     (SendVar!=NULL) || (FileVar!=NULL) || Connecting)
1276     EnableMenuItem(SetupMenu,ID_SETUP_SERIALPORT,MF_BYCOMMAND | MF_GRAYED);
1277     else
1278     EnableMenuItem(SetupMenu,ID_SETUP_SERIALPORT,MF_BYCOMMAND | MF_ENABLED);
1279    
1280     else if (SubMenu == ControlMenu)
1281     {
1282     if (cv.Ready &&
1283     (SendVar==NULL) && (FileVar==NULL)) {
1284     EnableMenuItem(ControlMenu,ID_CONTROL_SENDBREAK,MF_BYCOMMAND | MF_ENABLED);
1285     if (cv.PortType==IdSerial)
1286     EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_ENABLED);
1287     else
1288     EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_GRAYED);
1289     }
1290     else {
1291     EnableMenuItem(ControlMenu,ID_CONTROL_SENDBREAK,MF_BYCOMMAND | MF_GRAYED);
1292     EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_GRAYED);
1293     }
1294    
1295     if (cv.Ready && cv.TelFlag && (FileVar==NULL))
1296     EnableMenuItem(ControlMenu,ID_CONTROL_AREYOUTHERE,MF_BYCOMMAND | MF_ENABLED);
1297     else
1298     EnableMenuItem(ControlMenu,ID_CONTROL_AREYOUTHERE,MF_BYCOMMAND | MF_GRAYED);
1299    
1300     if (HTEKWin==0)
1301     EnableMenuItem(ControlMenu,ID_CONTROL_CLOSETEK,MF_BYCOMMAND | MF_GRAYED);
1302     else
1303     EnableMenuItem(ControlMenu,ID_CONTROL_CLOSETEK,MF_BYCOMMAND | MF_ENABLED);
1304    
1305     if ((ConvH!=0) || (FileVar!=NULL))
1306     EnableMenuItem(ControlMenu,ID_CONTROL_MACRO,MF_BYCOMMAND | MF_GRAYED);
1307     else
1308     EnableMenuItem(ControlMenu,ID_CONTROL_MACRO,MF_BYCOMMAND | MF_ENABLED);
1309    
1310     }
1311     else if (SubMenu == WinMenu)
1312     {
1313     SetWinMenu(WinMenu, ts.UIMsg, sizeof(ts.UIMsg), ts.UILanguageFile, 1);
1314     }
1315    
1316     TTXModifyPopupMenu(SubMenu); /* TTPLUG */
1317     }
1318    
1319     // added ConfirmPasteMouseRButton (2007.3.17 maya)
1320     void CVTWindow::InitPasteMenu(HMENU *Menu)
1321     {
1322     char uimsg[MAX_UIMSG];
1323    
1324     *Menu = LoadMenu(AfxGetInstanceHandle(),
1325     MAKEINTRESOURCE(IDR_PASTEMENU));
1326    
1327     GetMenuString(*Menu, ID_EDIT_PASTE2, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1328     get_lang_msg("MENU_EDIT_PASTE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1329     ModifyMenu(*Menu, ID_EDIT_PASTE2, MF_BYCOMMAND, ID_EDIT_PASTE2, ts.UIMsg);
1330     GetMenuString(*Menu, ID_EDIT_PASTECR, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1331     get_lang_msg("MENU_EDIT_PASTECR", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1332     ModifyMenu(*Menu, ID_EDIT_PASTECR, MF_BYCOMMAND, ID_EDIT_PASTECR, ts.UIMsg);
1333     }
1334    
1335     void CVTWindow::ResetSetup()
1336     {
1337     ChangeFont();
1338     BuffChangeWinSize(WinWidth,WinHeight);
1339     ChangeCaret();
1340    
1341     if (cv.Ready) {
1342     ts.PortType = cv.PortType;
1343     if (cv.PortType==IdSerial) {
1344     /* if serial port, change port parameters */
1345     ts.ComPort = cv.ComPort;
1346     CommResetSerial(&ts, &cv, TRUE);
1347     }
1348     }
1349    
1350     /* setup terminal */
1351     SetupTerm();
1352    
1353 doda 2529 /* background and ANSI color */
1354     #ifdef ALPHABLEND_TYPE2
1355     BGInitialize();
1356     BGSetupPrimary(TRUE);
1357     // 2006/03/17 by 337 : Alpha�l���������X
1358     // Layered��������������������������������
1359     if (ts.EtermLookfeel.BGUseAlphaBlendAPI) {
1360     MySetLayeredWindowAttributes(HVTWin, 0, ts.AlphaBlend, LWA_ALPHA);
1361     }
1362     #else
1363     DispApplyANSIColor();
1364     #endif
1365     DispSetNearestColors(IdBack, IdFore+8, NULL);
1366    
1367 maya 2476 /* setup window */
1368     ChangeWin();
1369    
1370     /* Language & IME */
1371     ResetIME();
1372    
1373     /* change TEK window */
1374     if (pTEKWin != NULL)
1375     ((CTEKWindow *)pTEKWin)->RestoreSetup();
1376     }
1377    
1378     void CVTWindow::RestoreSetup()
1379     {
1380     char TempDir[MAXPATHLEN];
1381     char TempName[MAXPATHLEN];
1382    
1383     if ( strlen(ts.SetupFName)==0 )
1384     return;
1385    
1386     ExtractFileName(ts.SetupFName,TempName,sizeof(TempName));
1387     ExtractDirName(ts.SetupFName,TempDir);
1388     if (TempDir[0]==0)
1389     strncpy_s(TempDir, sizeof(TempDir),ts.HomeDir, _TRUNCATE);
1390     FitFileName(TempName,sizeof(TempName),".INI");
1391    
1392     strncpy_s(ts.SetupFName, sizeof(ts.SetupFName),TempDir, _TRUNCATE);
1393     AppendSlash(ts.SetupFName,sizeof(ts.SetupFName));
1394     strncat_s(ts.SetupFName,sizeof(ts.SetupFName),TempName,_TRUNCATE);
1395    
1396     if (LoadTTSET())
1397     (*ReadIniFile)(ts.SetupFName,&ts);
1398     FreeTTSET();
1399    
1400 maya 2482 #if 0
1401 maya 2476 ChangeDefaultSet(&ts,NULL);
1402 maya 2482 #endif
1403 maya 2476
1404     ResetSetup();
1405     }
1406    
1407     /* called by the [Setup] Terminal command */
1408     void CVTWindow::SetupTerm()
1409     {
1410     if (ts.Language==IdJapanese)
1411     ResetCharSet();
1412     cv.CRSend = ts.CRSend;
1413    
1414     // for russian mode
1415     cv.RussHost = ts.RussHost;
1416     cv.RussClient = ts.RussClient;
1417    
1418     if (cv.Ready && cv.TelFlag && (ts.TelEcho>0))
1419     TelChangeEcho();
1420    
1421     if ((ts.TerminalWidth!=NumOfColumns) ||
1422     (ts.TerminalHeight!=NumOfLines-StatusLine)) {
1423     LockBuffer();
1424     HideStatusLine();
1425     ChangeTerminalSize(ts.TerminalWidth,
1426     ts.TerminalHeight);
1427     UnlockBuffer();
1428     }
1429     else if ((ts.TermIsWin>0) &&
1430     ((ts.TerminalWidth!=WinWidth) ||
1431     (ts.TerminalHeight!=WinHeight-StatusLine)))
1432     BuffChangeWinSize(ts.TerminalWidth,ts.TerminalHeight+StatusLine);
1433     }
1434    
1435     void CVTWindow::Startup()
1436     {
1437     /* auto log */
1438     /* OnCommOpen ���J�n�������������������J�n������ (2007.5.14 maya) */
1439    
1440     if ((TopicName[0]==0) && (ts.MacroFN[0]!=0)) {
1441     // start the macro specified in the command line or setup file
1442     RunMacro(ts.MacroFN,TRUE);
1443     ts.MacroFN[0] = 0;
1444     }
1445     else {// start connection
1446     if (TopicName[0]!=0)
1447     cv.NoMsg=1; /* suppress error messages */
1448     ::PostMessage(HVTWin,WM_USER_COMMSTART,0,0);
1449     }
1450     }
1451    
1452     void CVTWindow::OpenTEK()
1453     {
1454     ActiveWin = IdTEK;
1455     if (HTEKWin==NULL) {
1456     pTEKWin = new CTEKWindow();
1457     }
1458     else {
1459     ::ShowWindow(HTEKWin,SW_SHOWNORMAL);
1460     ::SetFocus(HTEKWin);
1461     }
1462     }
1463    
1464     /////////////////////////////////////////////////////////////////////////////
1465     // CVTWindow message handler
1466    
1467     LRESULT CVTWindow::DefWindowProc(UINT message, WPARAM wParam, LPARAM lParam)
1468     {
1469     LRESULT Result;
1470    
1471     if (message == MsgDlgHelp) {
1472     OnDlgHelp(wParam,lParam);
1473     return 0;
1474     }
1475     else if ((ts.HideTitle>0) &&
1476     (message == WM_NCHITTEST)) {
1477     Result = CFrameWnd::DefWindowProc(message,wParam,lParam);
1478     if ((Result==HTCLIENT) && AltKey())
1479     #ifdef ALPHABLEND_TYPE2
1480     if(ShiftKey())
1481     Result = HTBOTTOMRIGHT;
1482     else
1483     Result = HTCAPTION;
1484     #else
1485     Result = HTCAPTION;
1486     #endif
1487     return Result;
1488     }
1489    
1490     return (CFrameWnd::DefWindowProc(message,wParam,lParam));
1491     }
1492    
1493     BOOL CVTWindow::OnCommand(WPARAM wParam, LPARAM lParam)
1494     {
1495     WORD wID = LOWORD(wParam);
1496     WORD wNotifyCode = HIWORD(wParam);
1497    
1498     if (wNotifyCode==1) {
1499     switch (wID) {
1500     case ID_ACC_SENDBREAK:
1501     // added DisableAcceleratorSendBreak (2007.3.17 maya)
1502     if (!ts.DisableAcceleratorSendBreak)
1503     OnControlSendBreak();
1504     return TRUE;
1505     case ID_ACC_PASTECR:
1506     OnEditPasteCR();
1507     return TRUE;
1508     case ID_ACC_AREYOUTHERE:
1509     OnControlAreYouThere();
1510     return TRUE;
1511     case ID_ACC_PASTE:
1512     OnEditPaste();
1513     return TRUE;
1514     case ID_ACC_DISCONNECT:
1515     OnFileDisconnect();
1516     return TRUE;
1517     }
1518     if (ActiveWin==IdVT) {
1519     switch (wID) {
1520     case ID_ACC_NEWCONNECTION:
1521     OnFileNewConnection();
1522     return TRUE;
1523     case ID_ACC_COPY:
1524     OnEditCopy();
1525     return TRUE;
1526     case ID_ACC_PRINT:
1527     OnFilePrint();
1528     return TRUE;
1529     case ID_ACC_EXIT:
1530     OnFileExit();
1531     return TRUE;
1532     }
1533     }
1534     else { // transfer accelerator message to TEK win
1535     switch (wID) {
1536     case ID_ACC_COPY:
1537     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKEDIT_COPY,0);
1538     return TRUE;
1539     case ID_ACC_PRINT:
1540     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKFILE_PRINT,0);
1541     return TRUE;
1542     case ID_ACC_EXIT:
1543     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKFILE_EXIT,0);
1544     return TRUE;
1545     }
1546     }
1547     }
1548    
1549     if ((wID>=ID_WINDOW_1) && (wID<ID_WINDOW_1+9)) {
1550     SelectWin(wID-ID_WINDOW_1);
1551     return TRUE;
1552     }
1553     else {
1554     if (TTXProcessCommand(HVTWin, wID))
1555     return TRUE;
1556     else /* TTPLUG */
1557     return CFrameWnd::OnCommand(wParam, lParam);
1558     }
1559     }
1560    
1561     void CVTWindow::OnActivate(UINT nState, CWnd* pWndOther, BOOL bMinimized)
1562     {
1563     DispSetActive(nState!=WA_INACTIVE);
1564     }
1565    
1566     void CVTWindow::OnChar(UINT nChar, UINT nRepCnt, UINT nFlags)
1567     {
1568     unsigned int i;
1569     char Code;
1570    
1571     if (!KeybEnabled || (TalkStatus!=IdTalkKeyb))
1572     return;
1573    
1574     if ((ts.MetaKey>0) && AltKey()) {
1575     ::PostMessage(HVTWin,WM_SYSCHAR,nChar,MAKELONG(nRepCnt,nFlags));
1576     return;
1577     }
1578     Code = nChar;
1579    
1580     if ((ts.Language==IdRussian) &&
1581     ((BYTE)Code>=128))
1582     Code = (char)RussConv(ts.RussKeyb,ts.RussClient,(BYTE)Code);
1583    
1584     for (i=1 ; i<=nRepCnt ; i++) {
1585     CommTextOut(&cv,&Code,1);
1586     if (ts.LocalEcho>0)
1587     CommTextEcho(&cv,&Code,1);
1588     }
1589 salarm 2503
1590     /* �����s�����������X�N���[����������������
1591     �����[�g�����L�[�������M���X�N���[�������� */
1592     if (ts.AutoScrollOnlyInBottomLine != 0 && WinOrgY != 0) {
1593     DispVScroll(SCROLL_BOTTOM, 0);
1594     }
1595 maya 2476 }
1596    
1597     /* copy from ttset.c*/
1598     static void WriteInt2(PCHAR Sect, PCHAR Key, PCHAR FName, int i1, int i2)
1599     {
1600     char Temp[32];
1601     _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d,%d", i1, i2);
1602     WritePrivateProfileString(Sect, Key, Temp, FName);
1603     }
1604    
1605     static void SaveVTPos()
1606     {
1607     #define Section "Tera Term"
1608     if (ts.SaveVTWinPos) {
1609     /* VT win position */
1610     WriteInt2(Section, "VTPos", ts.SetupFName, ts.VTPos.x, ts.VTPos.y);
1611    
1612     /* VT terminal size */
1613     WriteInt2(Section, "TerminalSize", ts.SetupFName,
1614     ts.TerminalWidth, ts.TerminalHeight);
1615     }
1616     }
1617    
1618     void CVTWindow::OnClose()
1619     {
1620     if ((HTEKWin!=NULL) && ! ::IsWindowEnabled(HTEKWin)) {
1621     MessageBeep(0);
1622     return;
1623     }
1624     get_lang_msg("MSG_DISCONNECT_CONF", ts.UIMsg, sizeof(ts.UIMsg),
1625     "Disconnect?", ts.UILanguageFile);
1626     if (cv.Ready && (cv.PortType==IdTCPIP) &&
1627     ((ts.PortFlag & PF_CONFIRMDISCONN) != 0) &&
1628     ! CloseTT &&
1629     (::MessageBox(HVTWin, ts.UIMsg, "Tera Term",
1630     MB_OKCANCEL | MB_ICONEXCLAMATION | MB_DEFBUTTON2)==IDCANCEL))
1631     return;
1632    
1633     FileTransEnd(0);
1634     ProtoEnd();
1635    
1636     SaveVTPos();
1637     DestroyWindow();
1638     }
1639    
1640     void CVTWindow::OnDestroy()
1641     {
1642     // remove this window from the window list
1643     UnregWin(HVTWin);
1644    
1645     EndKeyboard();
1646    
1647     /* Disable drag-drop */
1648     ::DragAcceptFiles(HVTWin,FALSE);
1649    
1650     EndDDE();
1651    
1652     if (cv.TelFlag)
1653     EndTelnet();
1654     CommClose(&cv);
1655    
1656     OpenHelp(HVTWin,HH_CLOSE_ALL,0);
1657    
1658     FreeIME();
1659     FreeTTSET();
1660     do { }
1661     while (FreeTTDLG());
1662    
1663     do { }
1664     while (FreeTTFILE());
1665    
1666     if (HTEKWin != NULL)
1667     ::DestroyWindow(HTEKWin);
1668    
1669     EndDisp();
1670    
1671     FreeBuffer();
1672    
1673     CFrameWnd::OnDestroy();
1674     TTXEnd(); /* TTPLUG */
1675     }
1676    
1677     // MessageBox���{�^�������X�p�n���h��
1678     static LRESULT CALLBACK MsgBoxHootProc( INT hc, WPARAM wParam, LPARAM lParam )
1679     {
1680     if ( hc == HCBT_ACTIVATE ) {
1681     // &Send file �� S&CP ���������A�N�Z�����[�^�L�[����������
1682     get_lang_msg("FILEDLG_TRANS_TITLE_SENDFILE", ts.UIMsg, sizeof(ts.UIMsg),
1683     "Send file", ts.UILanguageFile);
1684     SetDlgItemText( (HWND)wParam, IDOK, ts.UIMsg );
1685     SetDlgItemText( (HWND)wParam, IDYES, ts.UIMsg );
1686     SetDlgItemText( (HWND)wParam, IDNO, "SCP" );
1687    
1688     return FALSE;
1689     }
1690    
1691     return CallNextHookEx( NULL, hc, wParam, lParam );
1692     }
1693    
1694     void CVTWindow::OnDropFiles(HDROP hDropInfo)
1695     {
1696     ::SetForegroundWindow(HVTWin);
1697     if (cv.Ready && (SendVar==NULL) && NewFileVar(&SendVar))
1698     {
1699     if (DragQueryFile(hDropInfo,0,SendVar->FullName,
1700     sizeof(SendVar->FullName))>0)
1701     {
1702     DWORD attr;
1703     char *ptr, *q;
1704     char tmpbuf[_MAX_PATH * 2];
1705    
1706     // �f�B���N�g�����������t���p�X�����\���t���� (2004.11.3 yutaka)
1707     attr = GetFileAttributes(SendVar->FullName);
1708     if (attr != -1 && (attr & FILE_ATTRIBUTE_DIRECTORY)) {
1709     ptr = SendVar->FullName;
1710     // �p�X���������� \ -> / ��
1711     setlocale(LC_ALL, ts.Locale);
1712     while (*ptr) {
1713     if (isleadbyte(*ptr)) { // multi-byte
1714     ptr += 2;
1715     continue;
1716     }
1717     if (*ptr == '\\')
1718     *ptr = '/';
1719     ptr++;
1720     }
1721    
1722     // �p�X���������������G�X�P�[�v����
1723     q = tmpbuf;
1724     ptr = SendVar->FullName;
1725     while (*ptr) {
1726     if (*ptr == ' ')
1727     *q++ = '\\';
1728     *q++ = *ptr;
1729     ptr++;
1730     }
1731     *q = '\0'; // null-terminate
1732    
1733     ptr = tmpbuf;
1734    
1735     // console�����M
1736     while (*ptr) {
1737     FSOut1(*ptr);
1738     if (ts.LocalEcho > 0) {
1739     FSEcho1(*ptr);
1740     }
1741     ptr++;
1742     }
1743     FreeFileVar(&SendVar); // �������Y������
1744    
1745     } else {
1746     // Confirm send a file when drag and drop (2007.12.28 maya)
1747     if (ts.ConfirmFileDragAndDrop) {
1748     // ���������t�@�C�������e�����������O���A���[�U���������������s���B(2006.1.21 yutaka)
1749     // MessageBox��SCP���I�������������������B(2008.1.25 yutaka)
1750     char uimsg[MAX_UIMSG];
1751     HHOOK hook = NULL;
1752     DWORD dwThreadID = GetCurrentThreadId();
1753     int ret;
1754    
1755     get_lang_msg("MSG_DANDD_CONF_TITLE", uimsg, sizeof(uimsg),
1756     "Tera Term: File Drag and Drop", ts.UILanguageFile);
1757     get_lang_msg("MSG_DANDD_CONF", ts.UIMsg, sizeof(ts.UIMsg),
1758     "Are you sure that you want to send the file content?", ts.UILanguageFile);
1759    
1760     hook = SetWindowsHookEx( WH_CBT, MsgBoxHootProc, NULL, dwThreadID );
1761     if (cv.isSSH == 2) {
1762     ret = MessageBox(ts.UIMsg, uimsg, MB_YESNOCANCEL | MB_ICONINFORMATION | MB_DEFBUTTON3);
1763     }
1764     else {
1765     // SSH2 �������������������� "SCP" ���o������ (2008.1.25 maya)
1766     ret = MessageBox(ts.UIMsg, uimsg, MB_OKCANCEL | MB_ICONINFORMATION | MB_DEFBUTTON2);
1767     }
1768     UnhookWindowsHookEx( hook );
1769    
1770     if (ret == IDOK || ret == IDYES) { // sendfile
1771     SendVar->DirLen = 0;
1772     ts.TransBin = 0;
1773     FileSendStart();
1774    
1775     } else if (ret == IDNO) { // SCP
1776     typedef int (CALLBACK *PSSH_start_scp)(char *, char *);
1777     static PSSH_start_scp func = NULL;
1778     static HMODULE h = NULL, h2 = NULL;
1779     char msg[128];
1780    
1781     if (func == NULL) {
1782     h2 = LoadLibrary("ttxssh.dll");
1783     if ( ((h = GetModuleHandle("ttxssh.dll")) == NULL) ) {
1784     _snprintf_s(msg, sizeof(msg), _TRUNCATE, "GetModuleHandle(\"ttxssh.dll\")) %d", GetLastError());
1785     goto scp_send_error;
1786     }
1787     func = (PSSH_start_scp)GetProcAddress(h, "TTXScpSendfile");
1788     if (func == NULL) {
1789     _snprintf_s(msg, sizeof(msg), _TRUNCATE, "GetProcAddress(\"TTXScpSendfile\")) %d", GetLastError());
1790     goto scp_send_error;
1791     }
1792     }
1793    
1794     if (func != NULL) {
1795     func(SendVar->FullName, NULL);
1796     goto send_success;
1797     }
1798    
1799     scp_send_error:
1800     ::MessageBox(NULL, msg, "Tera Term: scpsend command error", MB_OK | MB_ICONERROR);
1801     FreeLibrary(h2);
1802     send_success:
1803     FreeFileVar(&SendVar); // �������Y������
1804    
1805     } else {
1806     FreeFileVar(&SendVar);
1807    
1808     }
1809     }
1810     else {
1811     SendVar->DirLen = 0;
1812     ts.TransBin = 0;
1813     FileSendStart();
1814    
1815     }
1816     }
1817     }
1818     else
1819     FreeFileVar(&SendVar);
1820     }
1821     DragFinish(hDropInfo);
1822     }
1823    
1824     void CVTWindow::OnGetMinMaxInfo(MINMAXINFO FAR* lpMMI)
1825     {
1826     #ifndef WINDOW_MAXMIMUM_ENABLED
1827     lpMMI->ptMaxSize.x = 10000;
1828     lpMMI->ptMaxSize.y = 10000;
1829     lpMMI->ptMaxTrackSize.x = 10000;
1830     lpMMI->ptMaxTrackSize.y = 10000;
1831     #endif
1832     }
1833    
1834     void CVTWindow::OnHScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar)
1835     {
1836     int Func;
1837    
1838     switch (nSBCode) {
1839     case SB_BOTTOM:
1840     Func = SCROLL_BOTTOM;
1841     break;
1842     case SB_ENDSCROLL:
1843     return;
1844     case SB_LINEDOWN:
1845     Func = SCROLL_LINEDOWN;
1846     break;
1847     case SB_LINEUP:
1848     Func = SCROLL_LINEUP;
1849     break;
1850     case SB_PAGEDOWN:
1851     Func = SCROLL_PAGEDOWN;
1852     break;
1853     case SB_PAGEUP:
1854     Func = SCROLL_PAGEUP;
1855     break;
1856     case SB_THUMBPOSITION:
1857     case SB_THUMBTRACK:
1858     Func = SCROLL_POS;
1859     break;
1860     case SB_TOP:
1861     Func = SCROLL_TOP;
1862     break;
1863     default:
1864     return;
1865     }
1866     DispHScroll(Func,nPos);
1867     }
1868    
1869     void CVTWindow::OnInitMenuPopup(CMenu* pPopupMenu, UINT nIndex, BOOL bSysMenu)
1870     {
1871     InitMenuPopup(pPopupMenu->m_hMenu);
1872     }
1873    
1874     void CVTWindow::OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags)
1875     {
1876     BYTE KeyState[256];
1877     MSG M;
1878    
1879 salarm 2503 switch (KeyDown(HVTWin,nChar,nRepCnt,nFlags & 0x1ff)) {
1880     case KEYDOWN_OTHER:
1881     break;
1882     case KEYDOWN_CONTROL:
1883 maya 2476 return;
1884 salarm 2503 case KEYDOWN_COMMOUT:
1885     /* �����s�����������X�N���[����������������
1886     �����[�g�����L�[�������M���X�N���[�������� */
1887     if (ts.AutoScrollOnlyInBottomLine != 0 && WinOrgY != 0) {
1888     DispVScroll(SCROLL_BOTTOM, 0);
1889     }
1890     return;
1891     }
1892 maya 2476
1893 salarm 2503
1894 maya 2476 if ((ts.MetaKey>0) && ((nFlags & 0x2000) != 0)) {
1895     /* for Ctrl+Alt+Key combination */
1896     GetKeyboardState((PBYTE)KeyState);
1897     KeyState[VK_MENU] = 0;
1898     SetKeyboardState((PBYTE)KeyState);
1899     M.hwnd = HVTWin;
1900     M.message = WM_KEYDOWN;
1901     M.wParam = nChar;
1902     M.lParam = MAKELONG(nRepCnt,nFlags & 0xdfff);
1903     TranslateMessage(&M);
1904    
1905     } else {
1906     // ScrollLock�L�[���_�����������������A�}�E�X���N���b�N����������������������
1907     // �������B���������A�p�[�W���O�������������~�����B
1908     // ���Y�L�[���������������A���������J�������B(2006.11.14 yutaka)
1909     #if 0
1910     GetKeyboardState((PBYTE)KeyState);
1911     if (KeyState[VK_SCROLL] == 0x81) { // on : scroll locked
1912     ScrollLock = TRUE;
1913     } else if (KeyState[VK_SCROLL] == 0x80) { // off : scroll unlocked
1914     ScrollLock = FALSE;
1915     } else {
1916     // do nothing
1917     }
1918     #endif
1919     }
1920    
1921     }
1922    
1923     void CVTWindow::OnKeyUp(UINT nChar, UINT nRepCnt, UINT nFlags)
1924     {
1925     KeyUp(nChar);
1926     }
1927    
1928     void CVTWindow::OnKillFocus(CWnd* pNewWnd)
1929     {
1930     DispDestroyCaret();
1931     FocusReport(FALSE);
1932     CFrameWnd::OnKillFocus(pNewWnd);
1933    
1934     if (IsCaretOn())
1935     CaretKillFocus(TRUE);
1936     }
1937    
1938     void CVTWindow::OnLButtonDblClk(UINT nFlags, CPoint point)
1939     {
1940     if (LButton || MButton || RButton)
1941     return;
1942    
1943     DblClkX = point.x;
1944     DblClkY = point.y;
1945    
1946    
1947 doda 2519 if (! MouseReport(IdMouseEventBtnDown, IdLeftButton, DblClkX, DblClkY) &&
1948     BuffUrlDblClk(DblClkX, DblClkY)) // �u���E�U�����o���������������������B (2005.4.3 yutaka)
1949 maya 2476 return;
1950    
1951 doda 2519 BuffDblClk(DblClkX, DblClkY);
1952    
1953 maya 2476 LButton = TRUE;
1954     DblClk = TRUE;
1955     AfterDblClk = TRUE;
1956     ::SetTimer(HVTWin, IdDblClkTimer, GetDoubleClickTime(), NULL);
1957    
1958     /* for AutoScrolling */
1959     ::SetCapture(HVTWin);
1960     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
1961     }
1962    
1963     void CVTWindow::OnLButtonDown(UINT nFlags, CPoint point)
1964     {
1965     POINT p;
1966    
1967     p.x = point.x;
1968     p.y = point.y;
1969     ButtonDown(p,IdLeftButton);
1970     }
1971    
1972     void CVTWindow::OnLButtonUp(UINT nFlags, CPoint point)
1973     {
1974     MouseReport(IdMouseEventBtnUp, IdLeftButton, point.x, point.y);
1975    
1976     if (! LButton)
1977     return;
1978    
1979     ButtonUp(FALSE);
1980     }
1981    
1982     void CVTWindow::OnMButtonDown(UINT nFlags, CPoint point)
1983     {
1984     POINT p;
1985    
1986     p.x = point.x;
1987     p.y = point.y;
1988     ButtonDown(p,IdMiddleButton);
1989     }
1990    
1991     void CVTWindow::OnMButtonUp(UINT nFlags, CPoint point)
1992     {
1993     BOOL mousereport;
1994    
1995     mousereport = MouseReport(IdMouseEventBtnUp, IdMiddleButton, point.x, point.y);
1996    
1997     if (! MButton)
1998     return;
1999    
2000     // added DisablePasteMouseMButton (2008.3.2 maya)
2001     if (ts.DisablePasteMouseMButton)
2002     ButtonUp(FALSE);
2003     else
2004     ButtonUp(TRUE);
2005     }
2006    
2007     int CVTWindow::OnMouseActivate(CWnd* pDesktopWnd, UINT nHitTest, UINT message)
2008     {
2009     if ((ts.SelOnActive==0) &&
2010     (nHitTest==HTCLIENT)) //disable mouse event for text selection
2011     return MA_ACTIVATEANDEAT; // when window is activated
2012     else
2013     return MA_ACTIVATE;
2014     }
2015    
2016     void CVTWindow::OnMouseMove(UINT nFlags, CPoint point)
2017     {
2018     int i;
2019    
2020     if (! (LButton || MButton || RButton)) {
2021     // �}�E�X�J�[�\��������URL������������������������ (2005.4.2 yutaka)
2022     BuffChangeSelect(point.x, point.y,0);
2023     return;
2024     }
2025    
2026     if (DblClk)
2027     i = 2;
2028     else if (TplClk)
2029     i = 3;
2030     else
2031     i = 1;
2032    
2033     if (!ts.SelectOnlyByLButton ||
2034     (ts.SelectOnlyByLButton && LButton) ) {
2035     // SelectOnlyByLButton == TRUE ���������A���{�^���_�E���������I������ (2007.11.21 maya)
2036     BuffChangeSelect(point.x, point.y,i);
2037     }
2038     }
2039    
2040     void CVTWindow::OnMove(int x, int y)
2041     {
2042     DispSetWinPos();
2043     }
2044    
2045     // �}�E�X�z�C�[�������]
2046     BOOL CVTWindow::OnMouseWheel(
2047     UINT nFlags, // ���z�L�[
2048     short zDelta, // ���]����
2049     CPoint pt // �J�[�\�����u
2050     )
2051     {
2052     int line, i;
2053    
2054     ::ScreenToClient(HVTWin, &pt);
2055    
2056     line = abs(zDelta) / WHEEL_DELTA; // ���C����
2057     if (line < 1) line = 1;
2058    
2059     // ���X�N���[�����������s������������ (2008.4.6 yutaka)
2060     if (line == 1 && ts.MouseWheelScrollLine > 0)
2061     line *= ts.MouseWheelScrollLine;
2062    
2063     if (MouseReport(IdMouseEventWheel, zDelta<0, pt.x, pt.y))
2064     return TRUE;
2065    
2066     if (ts.TranslateWheelToCursor && AppliCursorMode) {
2067     if (zDelta < 0) {
2068     KeyDown(HVTWin, VK_DOWN, line, MapVirtualKey(VK_DOWN, 0) | 0x100);
2069     KeyUp(VK_DOWN);
2070     } else {
2071     KeyDown(HVTWin, VK_UP, line, MapVirtualKey(VK_UP, 0) | 0x100);
2072     KeyUp(VK_UP);
2073     }
2074     } else {
2075     for (i = 0 ; i < line ; i++) {
2076     if (zDelta < 0) {
2077     OnVScroll(SB_LINEDOWN, 0, NULL);
2078     } else {
2079     OnVScroll(SB_LINEUP, 0, NULL);
2080     }
2081     }
2082     }
2083    
2084     return (TRUE);
2085     }
2086    
2087    
2088     void CVTWindow::OnNcLButtonDblClk(UINT nHitTest, CPoint point)
2089     {
2090     if (! Minimized && (nHitTest == HTCAPTION))
2091     DispRestoreWinSize();
2092     else
2093     CFrameWnd::OnNcLButtonDblClk(nHitTest,point);
2094     }
2095    
2096     void CVTWindow::OnNcRButtonDown(UINT nHitTest, CPoint point)
2097     {
2098     if ((nHitTest==HTCAPTION) &&
2099     (ts.HideTitle>0) &&
2100     AltKey())
2101     ::CloseWindow(HVTWin); /* iconize */
2102     }
2103    
2104     void CVTWindow::OnPaint()
2105     {
2106     PAINTSTRUCT ps;
2107     CDC *cdc;
2108     HDC PaintDC;
2109     int Xs, Ys, Xe, Ye;
2110    
2111     #ifdef ALPHABLEND_TYPE2
2112     //<!--by AKASI
2113     BGSetupPrimary(FALSE);
2114     //-->
2115     #endif
2116    
2117     cdc = BeginPaint(&ps);
2118     PaintDC = cdc->GetSafeHdc();
2119    
2120     PaintWindow(PaintDC,ps.rcPaint,ps.fErase, &Xs,&Ys,&Xe,&Ye);
2121     LockBuffer();
2122     BuffUpdateRect(Xs,Ys,Xe,Ye);
2123     UnlockBuffer();
2124     DispEndPaint();
2125    
2126     EndPaint(&ps);
2127    
2128     if (FirstPaint) {
2129     if (strlen(TopicName)>0) {
2130     InitDDE();
2131     SendDDEReady();
2132     }
2133     FirstPaint = FALSE;
2134     Startup();
2135     }
2136     }
2137    
2138     void CVTWindow::OnRButtonDown(UINT nFlags, CPoint point)
2139     {
2140     POINT p;
2141    
2142     p.x = point.x;
2143     p.y = point.y;
2144     ButtonDown(p,IdRightButton);
2145     }
2146    
2147     void CVTWindow::OnRButtonUp(UINT nFlags, CPoint point)
2148     {
2149     BOOL mousereport;
2150    
2151     mousereport = MouseReport(IdMouseEventBtnUp, IdRightButton, point.x, point.y);
2152    
2153     if (! RButton) return;
2154    
2155     // �E�{�^�����������y�[�X�g�����~���� (2005.3.16 yutaka)
2156     if (ts.DisablePasteMouseRButton || mousereport) {
2157     ButtonUp(FALSE);
2158     } else {
2159     ButtonUp(TRUE);
2160     }
2161     }
2162    
2163     void CVTWindow::OnSetFocus(CWnd* pOldWnd)
2164     {
2165     ChangeCaret();
2166     FocusReport(TRUE);
2167     CFrameWnd::OnSetFocus(pOldWnd);
2168     }
2169    
2170     void CVTWindow::OnSize(UINT nType, int cx, int cy)
2171     {
2172     RECT R;
2173     int w, h;
2174    
2175     Minimized = (nType==SIZE_MINIMIZED);
2176    
2177     if (FirstPaint && Minimized)
2178     {
2179     if (strlen(TopicName)>0)
2180     {
2181     InitDDE();
2182     SendDDEReady();
2183     }
2184     FirstPaint = FALSE;
2185     Startup();
2186     return;
2187     }
2188     if (Minimized || DontChangeSize) return;
2189    
2190     if (nType == SIZE_MAXIMIZED) {
2191     ts.TerminalOldWidth = ts.TerminalWidth;
2192     ts.TerminalOldHeight = ts.TerminalHeight;
2193     }
2194    
2195     ::GetWindowRect(HVTWin,&R);
2196     w = R.right - R.left;
2197     h = R.bottom - R.top;
2198     if (AdjustSize)
2199     ResizeWindow(R.left,R.top,w,h,cx,cy);
2200     else {
2201     w = cx / FontWidth;
2202     h = cy / FontHeight;
2203     HideStatusLine();
2204     BuffChangeWinSize(w,h);
2205     }
2206    
2207     #ifdef WINDOW_MAXMIMUM_ENABLED
2208     if (nType == SIZE_MAXIMIZED) {
2209     AdjustSize = 0;
2210     }
2211     #endif
2212     }
2213    
2214     void CVTWindow::OnSysChar(UINT nChar, UINT nRepCnt, UINT nFlags)
2215     {
2216     char e = ESC;
2217     char Code;
2218     unsigned int i;
2219    
2220     #ifdef WINDOW_MAXMIMUM_ENABLED
2221     // ALT + x������������ WM_SYSCHAR �������������B
2222     // ALT + Enter���E�B���h�E�������� (2005.4.24 yutaka)
2223     if (AltKey() && nChar == 13) {
2224     if (IsZoomed()) { // window is maximum
2225     ShowWindow(SW_RESTORE);
2226     } else {
2227     ShowWindow(SW_MAXIMIZE);
2228     }
2229     }
2230     #endif
2231    
2232     if (ts.MetaKey>0)
2233     {
2234     if (!KeybEnabled || (TalkStatus!=IdTalkKeyb)) return;
2235     Code = nChar;
2236     for (i=1 ; i<=nRepCnt ; i++)
2237     {
2238     CommTextOut(&cv,&e,1);
2239     CommTextOut(&cv,&Code,1);
2240     if (ts.LocalEcho>0)
2241     {
2242     CommTextEcho(&cv,&e,1);
2243     CommTextEcho(&cv,&Code,1);
2244     }
2245     }
2246     return;
2247     }
2248     CFrameWnd::OnSysChar(nChar, nRepCnt, nFlags);
2249     }
2250    
2251     void CVTWindow::OnSysColorChange()
2252     {
2253     CFrameWnd::OnSysColorChange();
2254     }
2255    
2256     void CVTWindow::OnSysCommand(UINT nID, LPARAM lParam)
2257     {
2258     if (nID==ID_SHOWMENUBAR) {
2259     ts.PopupMenu = 0;
2260     SwitchMenu();
2261     }
2262     else if (((nID & 0xfff0)==SC_CLOSE) && (cv.PortType==IdTCPIP) &&
2263     cv.Open && ! cv.Ready && (cv.ComPort>0))
2264     // now getting host address (see CommOpen() in commlib.c)
2265     ::PostMessage(HVTWin,WM_SYSCOMMAND,nID,lParam);
2266     else
2267     CFrameWnd::OnSysCommand(nID,lParam);
2268     }
2269    
2270     void CVTWindow::OnSysKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags)
2271     {
2272     if ((nChar==VK_F10) ||
2273     (ts.MetaKey>0) &&
2274     ((MainMenu==NULL) || (nChar!=VK_MENU)) &&
2275     ((nFlags & 0x2000) != 0))
2276     KeyDown(HVTWin,nChar,nRepCnt,nFlags & 0x1ff);
2277     // OnKeyDown(nChar,nRepCnt,nFlags);
2278     else
2279     CFrameWnd::OnSysKeyDown(nChar,nRepCnt,nFlags);
2280     }
2281    
2282     void CVTWindow::OnSysKeyUp(UINT nChar, UINT nRepCnt, UINT nFlags)
2283     {
2284     if (nChar==VK_F10)
2285     OnKeyUp(nChar,nRepCnt,nFlags);
2286     else
2287     CFrameWnd::OnSysKeyUp(nChar,nRepCnt,nFlags);
2288     }
2289    
2290     void CVTWindow::OnTimer(UINT nIDEvent)
2291     {
2292     POINT Point;
2293     WORD PortType;
2294     UINT T;
2295    
2296     if (nIDEvent==IdCaretTimer) {
2297     if (ts.NonblinkingCursor!=0) {
2298     T = GetCaretBlinkTime();
2299     SetCaretBlinkTime(T);
2300     }
2301     else
2302     ::KillTimer(HVTWin,IdCaretTimer);
2303     return;
2304     }
2305     else if (nIDEvent==IdScrollTimer) {
2306     GetCursorPos(&Point);
2307     ::ScreenToClient(HVTWin,&Point);
2308     DispAutoScroll(Point);
2309     if ((Point.x < 0) || (Point.x >= ScreenWidth) ||
2310     (Point.y < 0) || (Point.y >= ScreenHeight))
2311     ::PostMessage(HVTWin,WM_MOUSEMOVE,MK_LBUTTON,MAKELONG(Point.x,Point.y));
2312     return;
2313     }
2314     else if (nIDEvent == IdCancelConnectTimer) {
2315     // �����������������������������A�\�P�b�g�������N���[�Y�B
2316     // CloseSocket()�������������A�����������������������A����Win32API���R�[�������B
2317     if (!cv.Ready) {
2318     closesocket(cv.s);
2319     //::PostMessage(HVTWin, WM_USER_COMMNOTIFY, 0, FD_CLOSE);
2320     }
2321     }
2322    
2323     ::KillTimer(HVTWin, nIDEvent);
2324    
2325     switch (nIDEvent) {
2326     case IdDelayTimer:
2327     cv.CanSend = TRUE;
2328     break;
2329     case IdProtoTimer:
2330     ProtoDlgTimeOut();
2331     case IdDblClkTimer:
2332     AfterDblClk = FALSE;
2333     break;
2334     case IdComEndTimer:
2335     if (! CommCanClose(&cv)) {
2336     // wait if received data remains
2337     SetTimer(IdComEndTimer,1,NULL);
2338     break;
2339     }
2340     cv.Ready = FALSE;
2341     if (cv.TelFlag)
2342     EndTelnet();
2343     PortType = cv.PortType;
2344     CommClose(&cv);
2345     SetDdeComReady(0);
2346     if ((PortType==IdTCPIP) &&
2347     ((ts.PortFlag & PF_BEEPONCONNECT) != 0))
2348     MessageBeep(0);
2349     if ((PortType==IdTCPIP) &&
2350     (ts.AutoWinClose>0) &&
2351     ::IsWindowEnabled(HVTWin) &&
2352     ((HTEKWin==NULL) || ::IsWindowEnabled(HTEKWin)) )
2353     OnClose();
2354     else
2355     ChangeTitle();
2356     break;
2357     case IdPrnStartTimer:
2358     PrnFileStart();
2359     break;
2360     case IdPrnProcTimer:
2361     PrnFileDirectProc();
2362     break;
2363     }
2364     <