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 2567 - (hide annotations) (download) (as text)
Mon Jul 28 02:23:11 2008 UTC (15 years, 8 months ago) by maya
Original Path: teraterm/trunk/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 121258 byte(s)
メニューアイテムの変更時にはDrawMenuBarを呼ぶ必要がなさそうなので削除。
メニューバーの変更時には呼ぶ必要がある。
http://msdn.microsoft.com/ja-jp/library/cc410774.aspx

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