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 2476 - (hide annotations) (download) (as text)
Mon Apr 14 17:35:50 2008 UTC (16 years ago) by maya
Original Path: teraterm/trunk/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 165443 byte(s)
ファイル移動に伴う修正

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