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 2500 - (hide annotations) (download) (as text)
Wed May 7 06:51:43 2008 UTC (15 years, 11 months ago) by salarm
Original Path: teraterm/trunk/teraterm/vtwin.cpp
File MIME type: text/x-c++src
File size: 166497 byte(s)
最下行でだけ自動スクロールする設定の場合はキー入力で最下行に
スクロールするようにしていたが、CTRL+PageUpなどのスクロールが
できなくなるため削除

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 maya 2482 #if 0
535 maya 2476 ChangeDefaultSet(&ts,tempkm);
536 maya 2482 #else
537     ChangeDefaultSet(NULL,tempkm);
538     #endif
539 maya 2476 if (tempkm!=NULL) free(tempkm);
540     }
541    
542     } else {
543     // 2�������~���v���Z�X�����������A�f�B�X�N���� TERATERM.INI �������B(2004.11.4 yutaka)
544     if (LoadTTSET()) {
545     /* read setup info from "teraterm.ini" */
546     (*ReadIniFile)(ts.SetupFName, &ts);
547     /* read keycode map from "keyboard.cnf" */
548     tempkm = (PKeyMap)malloc(sizeof(TKeyMap));
549     if (tempkm!=NULL) {
550     strncpy_s(Temp, sizeof(Temp, ts.HomeDir), ts.HomeDir, _TRUNCATE);
551     AppendSlash(Temp,sizeof(Temp));
552     strncat_s(Temp,sizeof(Temp),"KEYBOARD.CNF",_TRUNCATE);
553     (*ReadKeyboardCnf)(Temp,tempkm,TRUE);
554     }
555     FreeTTSET();
556     /* store default sets in TTCMN */
557     if (tempkm!=NULL) free(tempkm);
558     }
559    
560     }
561    
562     /* Parse command line parameters*/
563     // 256�o�C�g�������R�}���h���C���p�����[�^�w�����������ABOF(Buffer Over Flow)��
564     // �������o�O���C���B(2007.6.12 maya)
565     Param = GetCommandLine();
566     if (LoadTTSET())
567     (*ParseParam)(Param, &ts, &(TopicName[0]));
568     FreeTTSET();
569    
570     // duplicate session���w�������������A���L�����������R�s�[���� (2004.12.7 yutaka)
571     if (ts.DuplicateSession == 1) {
572     CopyShmemToTTSet(&ts);
573     }
574    
575     InitKeyboard();
576     SetKeyMap();
577    
578     // �R�}���h���C�����������t�@�C���������X���������������������� (2008.1.25 maya)
579     cv.isSSH = 0;
580    
581     /* window status */
582     AdjustSize = TRUE;
583     Minimized = FALSE;
584     LButton = FALSE;
585     MButton = FALSE;
586     RButton = FALSE;
587     DblClk = FALSE;
588     AfterDblClk = FALSE;
589     TplClk = FALSE;
590     Hold = FALSE;
591     FirstPaint = TRUE;
592     ScrollLock = FALSE; // �����l������ (2006.11.14 yutaka)
593    
594     /* Initialize scroll buffer */
595     InitBuffer();
596    
597     InitDisp();
598    
599     if (ts.HideTitle>0) {
600     Style = WS_VSCROLL | WS_HSCROLL |
601     WS_BORDER | WS_THICKFRAME | WS_POPUP;
602    
603     #ifdef ALPHABLEND_TYPE2
604     if(BGNoFrame)
605     Style &= ~(WS_BORDER | WS_THICKFRAME);
606     #endif
607     }
608     else
609     #ifdef WINDOW_MAXMIMUM_ENABLED
610     Style = WS_VSCROLL | WS_HSCROLL |
611     WS_BORDER | WS_THICKFRAME |
612     WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX | WS_MAXIMIZEBOX;
613     #else
614     Style = WS_VSCROLL | WS_HSCROLL |
615     WS_BORDER | WS_THICKFRAME |
616     WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX;
617     #endif
618    
619     wc.style = CS_DBLCLKS | CS_HREDRAW | CS_VREDRAW;
620     wc.lpfnWndProc = AfxWndProc;
621     wc.cbClsExtra = 0;
622     wc.cbWndExtra = 0;
623     wc.hInstance = AfxGetInstanceHandle();
624 doda 2497 wc.hIcon = LoadIcon(wc.hInstance, MAKEINTRESOURCE((ts.VTIcon!=IdIconDefault)?ts.VTIcon:IDI_VT));
625 maya 2476 //wc.hCursor = LoadCursor(NULL,IDC_IBEAM);
626     wc.hCursor = NULL; // �}�E�X�J�[�\�������I�����X���� (2005.4.2 yutaka)
627     wc.hbrBackground = NULL;
628     wc.lpszMenuName = NULL;
629     wc.lpszClassName = VTClassName;
630    
631     RegisterClass(&wc);
632     LoadAccelTable(MAKEINTRESOURCE(IDR_ACC));
633    
634     if (ts.VTPos.x==CW_USEDEFAULT)
635     rect = rectDefault;
636     else {
637     rect.left = ts.VTPos.x;
638     rect.top = ts.VTPos.y;
639     rect.right = rect.left + 100;
640     rect.bottom = rect.top + 100;
641     }
642     Create(VTClassName, "Tera Term", Style, rect, NULL, NULL);
643    
644     /*--------- Init2 -----------------*/
645     HVTWin = GetSafeHwnd();
646     if (HVTWin == NULL) return;
647     // register this window to the window list
648     SerialNo = RegWin(HVTWin,NULL);
649    
650     logfile_lock_initialize();
651     SetWindowStyle(&ts);
652     // ���P�[��������
653     // wctomb ������
654     setlocale(LC_ALL, ts.Locale);
655    
656     #ifdef ALPHABLEND_TYPE2
657     //<!--by AKASI
658     if(BGNoFrame && ts.HideTitle > 0) {
659     ExStyle = GetWindowLong(HVTWin,GWL_EXSTYLE);
660     ExStyle &= ~WS_EX_CLIENTEDGE;
661     SetWindowLong(HVTWin,GWL_EXSTYLE,ExStyle);
662     }
663     //-->
664     #endif
665    
666     // set the small icon
667     ::PostMessage(HVTWin,WM_SETICON,0,
668     (LPARAM)LoadImage(AfxGetInstanceHandle(),
669 doda 2497 MAKEINTRESOURCE((ts.VTIcon!=IdIconDefault)?ts.VTIcon:IDI_VT),
670 maya 2476 IMAGE_ICON,16,16,0));
671     MainMenu = NULL;
672     WinMenu = NULL;
673     if ((ts.HideTitle==0) && (ts.PopupMenu==0)) {
674     InitMenu(&MainMenu);
675     ::SetMenu(HVTWin,MainMenu);
676     }
677    
678     /* Reset Terminal */
679     ResetTerminal();
680    
681     if ((ts.PopupMenu>0) || (ts.HideTitle>0))
682     ::PostMessage(HVTWin,WM_USER_CHANGEMENU,0,0);
683    
684     ChangeFont();
685    
686     ResetIME();
687    
688     BuffChangeWinSize(NumOfColumns,NumOfLines);
689    
690     ChangeTitle();
691     /* Enable drag-drop */
692     ::DragAcceptFiles(HVTWin,TRUE);
693    
694     if (ts.HideWindow>0) {
695     if (strlen(TopicName)>0) {
696     InitDDE();
697     SendDDEReady();
698     }
699     FirstPaint = FALSE;
700     Startup();
701     return;
702     }
703     CmdShow = SW_SHOWDEFAULT;
704     if (ts.Minimize>0)
705     CmdShow = SW_SHOWMINIMIZED;
706     ShowWindow(CmdShow);
707     ChangeCaret();
708     }
709    
710     /////////////////////////////////////////////////////////////////////////////
711    
712     #ifdef _DEBUG
713     void CVTWindow::AssertValid() const
714     {
715     CFrameWnd::AssertValid();
716     }
717    
718     void CVTWindow::Dump(CDumpContext& dc) const
719     {
720     CFrameWnd::Dump(dc);
721     }
722    
723     #endif //_DEBUG
724    
725     /////////////////////////////////////////////////////////////////////////////
726    
727     int CVTWindow::Parse()
728     {
729     // added ScrollLock (2006.11.14 yutaka)
730     if (LButton || MButton || RButton || ScrollLock)
731     return 0;
732     return (VTParse()); // Parse received characters
733     }
734    
735     void CVTWindow::ButtonUp(BOOL Paste)
736     {
737     BOOL disableBuffEndSelect = false;
738     BOOL pasteRButton = RButton && Paste;
739     BOOL pasteMButton = MButton && Paste;
740    
741     /* disable autoscrolling */
742     ::KillTimer(HVTWin,IdScrollTimer);
743     ReleaseCapture();
744    
745     if (ts.SelectOnlyByLButton &&
746     (MButton || RButton)) {
747     disableBuffEndSelect = true;
748     }
749    
750     LButton = FALSE;
751     MButton = FALSE;
752     RButton = FALSE;
753     DblClk = FALSE;
754     TplClk = FALSE;
755     CaretOn();
756    
757     // SelectOnlyByLButton �� on �� ���E�E�N���b�N����������
758     // �o�b�t�@���I���������������A�I�����e���N���b�v�{�[�h��
759     // �R�s�[�������������������C�� (2007.12.6 maya)
760     if (!disableBuffEndSelect) {
761     BuffEndSelect();
762     }
763    
764     // added ConfirmPasteMouseRButton (2007.3.17 maya)
765     if (pasteRButton && !ts.ConfirmPasteMouseRButton) {
766     if (CBStartPasteConfirmChange(HVTWin))
767     CBStartPaste(HVTWin,FALSE,0,NULL,0);
768     }
769     else if (pasteMButton) {
770     if (CBStartPasteConfirmChange(HVTWin))
771     CBStartPaste(HVTWin,FALSE,0,NULL,0);
772     }
773     }
774    
775     void CVTWindow::ButtonDown(POINT p, int LMR)
776     {
777     HMENU PopupMenu, PopupBase;
778     BOOL mousereport;
779    
780     if ((LMR==IdLeftButton) && ControlKey() && (MainMenu==NULL) &&
781     ((ts.MenuFlag & MF_NOPOPUP)==0)) {
782     int i, numItems;
783     char itemText[256];
784    
785     InitMenu(&PopupMenu);
786    
787     PopupBase = CreatePopupMenu();
788     numItems = GetMenuItemCount(PopupMenu);
789    
790     for (i = 0; i < numItems; i++) {
791     HMENU submenu = GetSubMenu(PopupMenu, i);
792    
793     if (submenu != NULL) {
794     InitMenuPopup(submenu);
795     }
796    
797     if (GetMenuString(PopupMenu, i, itemText, sizeof(itemText), MF_BYPOSITION) != 0) {
798     int state = GetMenuState(PopupMenu, i, MF_BYPOSITION) &
799     (MF_CHECKED | MF_DISABLED | MF_GRAYED | MF_HILITE |
800     MF_MENUBARBREAK | MF_MENUBREAK | MF_SEPARATOR);
801    
802     AppendMenu(PopupBase,
803     submenu != NULL ? LOBYTE(state) | MF_POPUP : state,
804     submenu != NULL ? (UINT)submenu : GetMenuItemID(PopupMenu, i),
805     itemText);
806     }
807     }
808    
809     ::ClientToScreen(HVTWin, &p);
810     TrackPopupMenu(PopupBase,TPM_LEFTALIGN | TPM_LEFTBUTTON,
811     p.x,p.y,0,HVTWin,NULL);
812     if (WinMenu!=NULL) {
813     DestroyMenu(WinMenu);
814     WinMenu = NULL;
815     }
816     DestroyMenu(PopupBase);
817     DestroyMenu(PopupMenu);
818     PopupMenu = 0;
819     return;
820     }
821    
822     mousereport = MouseReport(IdMouseEventBtnDown, LMR, p.x, p.y);
823    
824     // added ConfirmPasteMouseRButton (2007.3.17 maya)
825     if ((LMR == IdRightButton) &&
826     !ts.DisablePasteMouseRButton &&
827     ts.ConfirmPasteMouseRButton &&
828     cv.Ready &&
829     !mousereport &&
830     (SendVar==NULL) && (FileVar==NULL) &&
831     (cv.PortType!=IdFile) &&
832     (IsClipboardFormatAvailable(CF_TEXT) ||
833     IsClipboardFormatAvailable(CF_OEMTEXT))) {
834    
835     int i, numItems;
836     char itemText[256];
837    
838     InitPasteMenu(&PopupMenu);
839     PopupBase = CreatePopupMenu();
840     numItems = GetMenuItemCount(PopupMenu);
841    
842     for (i = 0; i < numItems; i++) {
843     if (GetMenuString(PopupMenu, i, itemText, sizeof(itemText), MF_BYPOSITION) != 0) {
844     int state = GetMenuState(PopupMenu, i, MF_BYPOSITION) &
845     (MF_CHECKED | MF_DISABLED | MF_GRAYED | MF_HILITE |
846     MF_MENUBARBREAK | MF_MENUBREAK | MF_SEPARATOR);
847    
848     AppendMenu(PopupBase, state,
849     GetMenuItemID(PopupMenu, i), itemText);
850     }
851     }
852    
853     ::ClientToScreen(HVTWin, &p);
854     TrackPopupMenu(PopupBase,TPM_LEFTALIGN | TPM_LEFTBUTTON,
855     p.x,p.y,0,HVTWin,NULL);
856     if (WinMenu!=NULL) {
857     DestroyMenu(WinMenu);
858     WinMenu = NULL;
859     }
860     DestroyMenu(PopupBase);
861     DestroyMenu(PopupMenu);
862     PopupMenu = 0;
863     return;
864     }
865    
866     if (AfterDblClk && (LMR==IdLeftButton) &&
867     (abs(p.x-DblClkX)<=GetSystemMetrics(SM_CXDOUBLECLK)) &&
868     (abs(p.y-DblClkY)<=GetSystemMetrics(SM_CYDOUBLECLK))) {
869     /* triple click */
870     ::KillTimer(HVTWin, IdDblClkTimer);
871     AfterDblClk = FALSE;
872     BuffTplClk(p.y);
873     LButton = TRUE;
874     TplClk = TRUE;
875     /* for AutoScrolling */
876     ::SetCapture(HVTWin);
877     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
878     }
879     else {
880     if (! (LButton || MButton || RButton)) {
881     BOOL box = FALSE;
882    
883     // select several pages of output from TeraTerm window (2005.5.15 yutaka)
884     if (LMR == IdLeftButton && ShiftKey()) {
885     BuffSeveralPagesSelect(p.x, p.y);
886    
887     } else {
888     // Select rectangular block with Alt Key. Delete Shift key.(2005.5.15 yutaka)
889     if (LMR == IdLeftButton && AltKey()) {
890     box = TRUE;
891     }
892    
893     // Starting the selection only by a left button.(2007.11.20 maya)
894     if (!ts.SelectOnlyByLButton ||
895     (ts.SelectOnlyByLButton && LMR == IdLeftButton) ) {
896     BuffStartSelect(p.x,p.y, box);
897     TplClk = FALSE;
898    
899     /* for AutoScrolling */
900     ::SetCapture(HVTWin);
901     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
902     }
903     }
904     }
905    
906     switch (LMR) {
907     case IdRightButton:
908     RButton = TRUE;
909     break;
910     case IdMiddleButton:
911     MButton = TRUE;
912     break;
913     case IdLeftButton:
914     LButton = TRUE;
915     break;
916     }
917     }
918     }
919    
920     // LogMeIn.exe -> LogMeTT.exe �����l�[�� (2005.2.21 yutaka)
921     char *LogMeTTexename = "LogMeTT.exe";
922     static char LogMeTTMenuString[] = "Log&MeTT";
923     static BOOL isLogMeTTExist()
924     {
925     char LogMeTT[MAX_PATH];
926    
927     strncpy_s(LogMeTT, sizeof(LogMeTT), ts.HomeDir, _TRUNCATE);
928     AppendSlash(LogMeTT, sizeof(LogMeTT));
929     strncat_s(LogMeTT, sizeof(LogMeTT), LogMeTTexename, _TRUNCATE);
930    
931     if (_access(LogMeTT, 0) == -1) {
932     return FALSE;
933     }
934     return TRUE;
935     }
936    
937     void CVTWindow::InitMenu(HMENU *Menu)
938     {
939     *Menu = LoadMenu(AfxGetInstanceHandle(),
940     MAKEINTRESOURCE(IDR_MENU));
941     char uimsg[MAX_UIMSG];
942     int ret;
943    
944     FileMenu = GetSubMenu(*Menu,ID_FILE);
945     TransMenu = GetSubMenu(FileMenu,ID_TRANSFER);
946     EditMenu = GetSubMenu(*Menu,ID_EDIT);
947     SetupMenu = GetSubMenu(*Menu,ID_SETUP);
948     ControlMenu = GetSubMenu(*Menu,ID_CONTROL);
949     HelpMenu = GetSubMenu(*Menu,ID_HELPMENU);
950    
951     /* LogMeTT ���������m�F�������j���[���������� */
952     if (isLogMeTTExist()) {
953     ::InsertMenu(FileMenu, ID_FILE_PRINT2, MF_STRING | MF_ENABLED | MF_BYCOMMAND,
954     ID_FILE_LOGMEIN, LogMeTTMenuString);
955     ::InsertMenu(FileMenu, ID_FILE_PRINT2, MF_SEPARATOR, NULL, NULL);
956     DrawMenuBar();
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     GetMenuString(FileMenu, ID_FILE_ZRCV, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1032     get_lang_msg("MENU_TRANS_Z_RCV", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1033     ModifyMenu(FileMenu, ID_FILE_ZRCV, MF_BYCOMMAND, ID_FILE_ZRCV, ts.UIMsg);
1034     GetMenuString(FileMenu, ID_FILE_ZSEND, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1035     get_lang_msg("MENU_TRANS_Z_SEND", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1036     ModifyMenu(FileMenu, ID_FILE_ZSEND, MF_BYCOMMAND, ID_FILE_ZSEND, ts.UIMsg);
1037    
1038     GetMenuString(FileMenu, ID_FILE_BPRCV, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1039     get_lang_msg("MENU_TRANS_BP_RCV", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1040     ModifyMenu(FileMenu, ID_FILE_BPRCV, MF_BYCOMMAND, ID_FILE_BPRCV, ts.UIMsg);
1041     GetMenuString(FileMenu, ID_FILE_BPSEND, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1042     get_lang_msg("MENU_TRANS_BP_SEND", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1043     ModifyMenu(FileMenu, ID_FILE_BPSEND, MF_BYCOMMAND, ID_FILE_BPSEND, ts.UIMsg);
1044    
1045     GetMenuString(FileMenu, ID_FILE_QVRCV, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1046     get_lang_msg("MENU_TRANS_QV_RCV", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1047     ModifyMenu(FileMenu, ID_FILE_QVRCV, MF_BYCOMMAND, ID_FILE_QVRCV, ts.UIMsg);
1048     GetMenuString(FileMenu, ID_FILE_QVSEND, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1049     get_lang_msg("MENU_TRANS_QV_SEND", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1050     ModifyMenu(FileMenu, ID_FILE_QVSEND, MF_BYCOMMAND, ID_FILE_QVSEND, ts.UIMsg);
1051    
1052     GetMenuString(*Menu, ID_EDIT, uimsg, sizeof(uimsg), MF_BYPOSITION);
1053     get_lang_msg("MENU_EDIT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1054     ModifyMenu(*Menu, ID_EDIT, MF_BYPOSITION, ID_EDIT, ts.UIMsg);
1055     GetMenuString(EditMenu, ID_EDIT_COPY2, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1056     get_lang_msg("MENU_EDIT_COPY", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1057     ModifyMenu(EditMenu, ID_EDIT_COPY2, MF_BYCOMMAND, ID_EDIT_COPY2, ts.UIMsg);
1058     GetMenuString(EditMenu, ID_EDIT_COPYTABLE, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1059     get_lang_msg("MENU_EDIT_COPYTABLE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1060     ModifyMenu(EditMenu, ID_EDIT_COPYTABLE, MF_BYCOMMAND, ID_EDIT_COPYTABLE, ts.UIMsg);
1061     GetMenuString(EditMenu, ID_EDIT_PASTE2, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1062     get_lang_msg("MENU_EDIT_PASTE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1063     ModifyMenu(EditMenu, ID_EDIT_PASTE2, MF_BYCOMMAND, ID_EDIT_PASTE2, ts.UIMsg);
1064     GetMenuString(EditMenu, ID_EDIT_PASTECR, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1065     get_lang_msg("MENU_EDIT_PASTECR", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1066     ModifyMenu(EditMenu, ID_EDIT_PASTECR, MF_BYCOMMAND, ID_EDIT_PASTECR, ts.UIMsg);
1067     GetMenuString(EditMenu, ID_EDIT_CLEARSCREEN, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1068     get_lang_msg("MENU_EDIT_CLSCREEN", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1069     ModifyMenu(EditMenu, ID_EDIT_CLEARSCREEN, MF_BYCOMMAND, ID_EDIT_CLEARSCREEN, ts.UIMsg);
1070     GetMenuString(EditMenu, ID_EDIT_CLEARBUFFER, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1071     get_lang_msg("MENU_EDIT_CLBUFFER", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1072     ModifyMenu(EditMenu, ID_EDIT_CLEARBUFFER, MF_BYCOMMAND, ID_EDIT_CLEARBUFFER, ts.UIMsg);
1073     GetMenuString(EditMenu, ID_EDIT_CANCELSELECT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1074     get_lang_msg("MENU_EDIT_CANCELSELECT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1075     ModifyMenu(EditMenu, ID_EDIT_CANCELSELECT, MF_BYCOMMAND, ID_EDIT_CANCELSELECT, ts.UIMsg);
1076     GetMenuString(EditMenu, ID_EDIT_SELECTSCREEN, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1077     get_lang_msg("MENU_EDIT_SELECTSCREEN", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1078     ModifyMenu(EditMenu, ID_EDIT_SELECTSCREEN, MF_BYCOMMAND, ID_EDIT_SELECTSCREEN, ts.UIMsg);
1079     GetMenuString(EditMenu, ID_EDIT_SELECTALL, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1080     get_lang_msg("MENU_EDIT_SELECTALL", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1081     ModifyMenu(EditMenu, ID_EDIT_SELECTALL, MF_BYCOMMAND, ID_EDIT_SELECTALL, ts.UIMsg);
1082    
1083     GetMenuString(*Menu, ID_SETUP, uimsg, sizeof(uimsg), MF_BYPOSITION);
1084     get_lang_msg("MENU_SETUP", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1085     ModifyMenu(*Menu, ID_SETUP, MF_BYPOSITION, ID_SETUP, ts.UIMsg);
1086     GetMenuString(SetupMenu, ID_SETUP_TERMINAL, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1087     get_lang_msg("MENU_SETUP_TERMINAL", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1088     ModifyMenu(SetupMenu, ID_SETUP_TERMINAL, MF_BYCOMMAND, ID_SETUP_TERMINAL, ts.UIMsg);
1089     GetMenuString(SetupMenu, ID_SETUP_WINDOW, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1090     get_lang_msg("MENU_SETUP_WINDOW", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1091     ModifyMenu(SetupMenu, ID_SETUP_WINDOW, MF_BYCOMMAND, ID_SETUP_WINDOW, ts.UIMsg);
1092     GetMenuString(SetupMenu, ID_SETUP_FONT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1093     get_lang_msg("MENU_SETUP_FONT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1094     ModifyMenu(SetupMenu, ID_SETUP_FONT, MF_BYCOMMAND, ID_SETUP_FONT, ts.UIMsg);
1095     GetMenuString(SetupMenu, ID_SETUP_KEYBOARD, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1096     get_lang_msg("MENU_SETUP_KEYBOARD", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1097     ModifyMenu(SetupMenu, ID_SETUP_KEYBOARD, MF_BYCOMMAND, ID_SETUP_KEYBOARD, ts.UIMsg);
1098     GetMenuString(SetupMenu, ID_SETUP_SERIALPORT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1099     get_lang_msg("MENU_SETUP_SERIALPORT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1100     ModifyMenu(SetupMenu, ID_SETUP_SERIALPORT, MF_BYCOMMAND, ID_SETUP_SERIALPORT, ts.UIMsg);
1101     GetMenuString(SetupMenu, ID_SETUP_TCPIP, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1102     get_lang_msg("MENU_SETUP_TCPIP", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1103     ModifyMenu(SetupMenu, ID_SETUP_TCPIP, MF_BYCOMMAND, ID_SETUP_TCPIP, ts.UIMsg);
1104     GetMenuString(SetupMenu, ID_SETUP_GENERAL, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1105     get_lang_msg("MENU_SETUP_GENERAL", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1106     ModifyMenu(SetupMenu, ID_SETUP_GENERAL, MF_BYCOMMAND, ID_SETUP_GENERAL, ts.UIMsg);
1107     GetMenuString(SetupMenu, ID_SETUP_ADDITIONALSETTINGS, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1108     get_lang_msg("MENU_SETUP_ADDITION", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1109     ModifyMenu(SetupMenu, ID_SETUP_ADDITIONALSETTINGS, MF_BYCOMMAND, ID_SETUP_ADDITIONALSETTINGS, ts.UIMsg);
1110     GetMenuString(SetupMenu, ID_SETUP_SAVE, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1111     get_lang_msg("MENU_SETUP_SAVE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1112     ModifyMenu(SetupMenu, ID_SETUP_SAVE, MF_BYCOMMAND, ID_SETUP_SAVE, ts.UIMsg);
1113     GetMenuString(SetupMenu, ID_SETUP_RESTORE, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1114     get_lang_msg("MENU_SETUP_RESTORE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1115     ModifyMenu(SetupMenu, ID_SETUP_RESTORE, MF_BYCOMMAND, ID_SETUP_RESTORE, ts.UIMsg);
1116     GetMenuString(SetupMenu, ID_SETUP_LOADKEYMAP, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1117     get_lang_msg("MENU_SETUP_LOADKEYMAP", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1118     ModifyMenu(SetupMenu, ID_SETUP_LOADKEYMAP, MF_BYCOMMAND, ID_SETUP_LOADKEYMAP, ts.UIMsg);
1119    
1120     GetMenuString(*Menu, ID_CONTROL, uimsg, sizeof(uimsg), MF_BYPOSITION);
1121     get_lang_msg("MENU_CONTROL", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1122     ModifyMenu(*Menu, ID_CONTROL, MF_BYPOSITION, ID_CONTROL, ts.UIMsg);
1123     GetMenuString(ControlMenu, ID_CONTROL_RESETTERMINAL, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1124     get_lang_msg("MENU_CONTROL_RESET", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1125     ModifyMenu(ControlMenu, ID_CONTROL_RESETTERMINAL, MF_BYCOMMAND, ID_CONTROL_RESETTERMINAL, ts.UIMsg);
1126     GetMenuString(ControlMenu, ID_CONTROL_AREYOUTHERE, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1127     get_lang_msg("MENU_CONTROL_AREYOUTHERE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1128     ModifyMenu(ControlMenu, ID_CONTROL_AREYOUTHERE, MF_BYCOMMAND, ID_CONTROL_AREYOUTHERE, ts.UIMsg);
1129     GetMenuString(ControlMenu, ID_CONTROL_SENDBREAK, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1130     get_lang_msg("MENU_CONTROL_SENDBREAK", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1131     ModifyMenu(ControlMenu, ID_CONTROL_SENDBREAK, MF_BYCOMMAND, ID_CONTROL_SENDBREAK, ts.UIMsg);
1132     GetMenuString(ControlMenu, ID_CONTROL_RESETPORT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1133     get_lang_msg("MENU_CONTROL_RESETPORT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1134     ModifyMenu(ControlMenu, ID_CONTROL_RESETPORT, MF_BYCOMMAND, ID_CONTROL_RESETPORT, ts.UIMsg);
1135     GetMenuString(ControlMenu, ID_CONTROL_BROADCASTCOMMAND, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1136     get_lang_msg("MENU_CONTROL_BROADCAST", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1137     ModifyMenu(ControlMenu, ID_CONTROL_BROADCASTCOMMAND, MF_BYCOMMAND, ID_CONTROL_BROADCASTCOMMAND, ts.UIMsg);
1138     GetMenuString(ControlMenu, ID_CONTROL_OPENTEK, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1139     get_lang_msg("MENU_CONTROL_OPENTEK", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1140     ModifyMenu(ControlMenu, ID_CONTROL_OPENTEK, MF_BYCOMMAND, ID_CONTROL_OPENTEK, ts.UIMsg);
1141     GetMenuString(ControlMenu, ID_CONTROL_CLOSETEK, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1142     get_lang_msg("MENU_CONTROL_CLOSETEK", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1143     ModifyMenu(ControlMenu, ID_CONTROL_CLOSETEK, MF_BYCOMMAND, ID_CONTROL_CLOSETEK, ts.UIMsg);
1144     GetMenuString(ControlMenu, ID_CONTROL_MACRO, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1145     get_lang_msg("MENU_CONTROL_MACRO", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1146     ModifyMenu(ControlMenu, ID_CONTROL_MACRO, MF_BYCOMMAND, ID_CONTROL_MACRO, ts.UIMsg);
1147    
1148     GetMenuString(*Menu, ID_HELPMENU, uimsg, sizeof(uimsg), MF_BYPOSITION);
1149     get_lang_msg("MENU_HELP", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1150     ModifyMenu(*Menu, ID_HELPMENU, MF_BYPOSITION, ID_HELPMENU, ts.UIMsg);
1151     GetMenuString(HelpMenu, ID_HELP_INDEX2, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1152     get_lang_msg("MENU_HELP_INDEX", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1153     ModifyMenu(HelpMenu, ID_HELP_INDEX2, MF_BYCOMMAND, ID_HELP_INDEX2, ts.UIMsg);
1154     GetMenuString(HelpMenu, ID_HELP_ABOUT, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1155     get_lang_msg("MENU_HELP_ABOUT", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1156     ModifyMenu(HelpMenu, ID_HELP_ABOUT, MF_BYCOMMAND, ID_HELP_ABOUT, ts.UIMsg);
1157    
1158     if ((ts.MenuFlag & MF_SHOWWINMENU) !=0) {
1159     WinMenu = CreatePopupMenu();
1160     get_lang_msg("MENU_WINDOW", ts.UIMsg, sizeof(ts.UIMsg),
1161     "&Window", ts.UILanguageFile);
1162     ::InsertMenu(*Menu,ID_HELPMENU,
1163     MF_STRING | MF_ENABLED | MF_POPUP | MF_BYPOSITION,
1164     (int)WinMenu, ts.UIMsg);
1165     }
1166    
1167     TTXModifyMenu(*Menu); /* TTPLUG */
1168     }
1169    
1170     void CVTWindow::InitMenuPopup(HMENU SubMenu)
1171     {
1172     if ( SubMenu == FileMenu )
1173     {
1174     if ( Connecting ) {
1175     EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_GRAYED);
1176     } else {
1177     EnableMenuItem(FileMenu,ID_FILE_NEWCONNECTION,MF_BYCOMMAND | MF_ENABLED);
1178     }
1179    
1180     if ( (! cv.Ready) || (SendVar!=NULL) ||
1181     (FileVar!=NULL) || (cv.PortType==IdFile) ) {
1182     EnableMenuItem(FileMenu,ID_FILE_SENDFILE,MF_BYCOMMAND | MF_GRAYED);
1183     EnableMenuItem(FileMenu,ID_TRANSFER,MF_BYPOSITION | MF_GRAYED); /* Transfer */
1184     EnableMenuItem(FileMenu,ID_FILE_CHANGEDIR,MF_BYCOMMAND | MF_GRAYED);
1185     EnableMenuItem(FileMenu,ID_FILE_DISCONNECT,MF_BYCOMMAND | MF_GRAYED);
1186     EnableMenuItem(FileMenu,ID_FILE_DUPLICATESESSION,MF_BYCOMMAND | MF_GRAYED);
1187     }
1188     else {
1189     EnableMenuItem(FileMenu,ID_FILE_SENDFILE,MF_BYCOMMAND | MF_ENABLED);
1190     EnableMenuItem(FileMenu,ID_TRANSFER,MF_BYPOSITION | MF_ENABLED); /* Transfer */
1191     EnableMenuItem(FileMenu,ID_FILE_CHANGEDIR,MF_BYCOMMAND | MF_ENABLED);
1192     EnableMenuItem(FileMenu,ID_FILE_DISCONNECT,MF_BYCOMMAND | MF_ENABLED);
1193     EnableMenuItem(FileMenu,ID_FILE_DUPLICATESESSION,MF_BYCOMMAND | MF_ENABLED);
1194     }
1195    
1196     // �V�K���j���[������ (2004.12.5 yutaka)
1197     EnableMenuItem(FileMenu,ID_FILE_CYGWINCONNECTION,MF_BYCOMMAND | MF_ENABLED);
1198     EnableMenuItem(FileMenu,ID_FILE_TERATERMMENU,MF_BYCOMMAND | MF_ENABLED);
1199     EnableMenuItem(FileMenu,ID_FILE_LOGMEIN,MF_BYCOMMAND | MF_ENABLED);
1200    
1201     // XXX: �������u�����������Alog���O���C�����������B (2005.2.1 yutaka)
1202     if (LogVar!=NULL) { // ���O�������[�h������
1203     EnableMenuItem(FileMenu,ID_FILE_LOG,MF_BYCOMMAND | MF_GRAYED);
1204     EnableMenuItem(FileMenu,ID_FILE_COMMENTTOLOG, MF_BYCOMMAND | MF_ENABLED);
1205     EnableMenuItem(FileMenu,ID_FILE_VIEWLOG, MF_BYCOMMAND | MF_ENABLED);
1206     if (ts.LogHideDialog) {
1207     EnableMenuItem(FileMenu,ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND | MF_ENABLED);
1208     }
1209     else {
1210     EnableMenuItem(FileMenu,ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND | MF_GRAYED);
1211     }
1212     } else {
1213     EnableMenuItem(FileMenu,ID_FILE_LOG,MF_BYCOMMAND | MF_ENABLED);
1214     EnableMenuItem(FileMenu,ID_FILE_COMMENTTOLOG, MF_BYCOMMAND | MF_GRAYED);
1215     EnableMenuItem(FileMenu,ID_FILE_VIEWLOG, MF_BYCOMMAND | MF_GRAYED);
1216     EnableMenuItem(FileMenu,ID_FILE_SHOWLOGDIALOG, MF_BYCOMMAND | MF_GRAYED);
1217     }
1218    
1219     }
1220     else if ( SubMenu == TransMenu )
1221     {
1222     if ((cv.PortType==IdSerial) &&
1223     ((ts.DataBit==IdDataBit7) || (ts.Flow==IdFlowX))) {
1224     EnableMenuItem(TransMenu,1,MF_BYPOSITION | MF_GRAYED); /* XMODEM */
1225     EnableMenuItem(TransMenu,4,MF_BYPOSITION | MF_GRAYED); /* Quick-VAN */
1226     }
1227     else {
1228     EnableMenuItem(TransMenu,1,MF_BYPOSITION | MF_ENABLED); /* XMODEM */
1229     EnableMenuItem(TransMenu,4,MF_BYPOSITION | MF_ENABLED); /* Quick-VAN */
1230     }
1231     if ((cv.PortType==IdSerial) &&
1232     (ts.DataBit==IdDataBit7)) {
1233     EnableMenuItem(TransMenu,2,MF_BYPOSITION | MF_GRAYED); /* ZMODEM */
1234     EnableMenuItem(TransMenu,3,MF_BYPOSITION | MF_GRAYED); /* B-Plus */
1235     }
1236     else {
1237     EnableMenuItem(TransMenu,2,MF_BYPOSITION | MF_ENABLED); /* ZMODEM */
1238     EnableMenuItem(TransMenu,3,MF_BYPOSITION | MF_ENABLED); /* B-Plus */
1239     }
1240     }
1241     else if (SubMenu == EditMenu)
1242     {
1243     if (Selected) {
1244     EnableMenuItem(EditMenu,ID_EDIT_COPY2,MF_BYCOMMAND | MF_ENABLED);
1245     EnableMenuItem(EditMenu,ID_EDIT_COPYTABLE,MF_BYCOMMAND | MF_ENABLED);
1246     }
1247     else {
1248     EnableMenuItem(EditMenu,ID_EDIT_COPY2,MF_BYCOMMAND | MF_GRAYED);
1249     EnableMenuItem(EditMenu,ID_EDIT_COPYTABLE,MF_BYCOMMAND | MF_GRAYED);
1250     }
1251     if (cv.Ready &&
1252     (SendVar==NULL) && (FileVar==NULL) &&
1253     (cv.PortType!=IdFile) &&
1254     (IsClipboardFormatAvailable(CF_TEXT) ||
1255     IsClipboardFormatAvailable(CF_OEMTEXT))) {
1256     EnableMenuItem(EditMenu,ID_EDIT_PASTE2,MF_BYCOMMAND | MF_ENABLED);
1257     EnableMenuItem(EditMenu,ID_EDIT_PASTECR,MF_BYCOMMAND | MF_ENABLED);
1258     }
1259     else {
1260     EnableMenuItem(EditMenu,ID_EDIT_PASTE2,MF_BYCOMMAND | MF_GRAYED);
1261     EnableMenuItem(EditMenu,ID_EDIT_PASTECR,MF_BYCOMMAND | MF_GRAYED);
1262     }
1263     }
1264     else if (SubMenu == SetupMenu)
1265     if (cv.Ready &&
1266     ((cv.PortType==IdTCPIP) || (cv.PortType==IdFile)) ||
1267     (SendVar!=NULL) || (FileVar!=NULL) || Connecting)
1268     EnableMenuItem(SetupMenu,ID_SETUP_SERIALPORT,MF_BYCOMMAND | MF_GRAYED);
1269     else
1270     EnableMenuItem(SetupMenu,ID_SETUP_SERIALPORT,MF_BYCOMMAND | MF_ENABLED);
1271    
1272     else if (SubMenu == ControlMenu)
1273     {
1274     if (cv.Ready &&
1275     (SendVar==NULL) && (FileVar==NULL)) {
1276     EnableMenuItem(ControlMenu,ID_CONTROL_SENDBREAK,MF_BYCOMMAND | MF_ENABLED);
1277     if (cv.PortType==IdSerial)
1278     EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_ENABLED);
1279     else
1280     EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_GRAYED);
1281     }
1282     else {
1283     EnableMenuItem(ControlMenu,ID_CONTROL_SENDBREAK,MF_BYCOMMAND | MF_GRAYED);
1284     EnableMenuItem(ControlMenu,ID_CONTROL_RESETPORT,MF_BYCOMMAND | MF_GRAYED);
1285     }
1286    
1287     if (cv.Ready && cv.TelFlag && (FileVar==NULL))
1288     EnableMenuItem(ControlMenu,ID_CONTROL_AREYOUTHERE,MF_BYCOMMAND | MF_ENABLED);
1289     else
1290     EnableMenuItem(ControlMenu,ID_CONTROL_AREYOUTHERE,MF_BYCOMMAND | MF_GRAYED);
1291    
1292     if (HTEKWin==0)
1293     EnableMenuItem(ControlMenu,ID_CONTROL_CLOSETEK,MF_BYCOMMAND | MF_GRAYED);
1294     else
1295     EnableMenuItem(ControlMenu,ID_CONTROL_CLOSETEK,MF_BYCOMMAND | MF_ENABLED);
1296    
1297     if ((ConvH!=0) || (FileVar!=NULL))
1298     EnableMenuItem(ControlMenu,ID_CONTROL_MACRO,MF_BYCOMMAND | MF_GRAYED);
1299     else
1300     EnableMenuItem(ControlMenu,ID_CONTROL_MACRO,MF_BYCOMMAND | MF_ENABLED);
1301    
1302     }
1303     else if (SubMenu == WinMenu)
1304     {
1305     SetWinMenu(WinMenu, ts.UIMsg, sizeof(ts.UIMsg), ts.UILanguageFile, 1);
1306     }
1307    
1308     TTXModifyPopupMenu(SubMenu); /* TTPLUG */
1309     }
1310    
1311     // added ConfirmPasteMouseRButton (2007.3.17 maya)
1312     void CVTWindow::InitPasteMenu(HMENU *Menu)
1313     {
1314     char uimsg[MAX_UIMSG];
1315    
1316     *Menu = LoadMenu(AfxGetInstanceHandle(),
1317     MAKEINTRESOURCE(IDR_PASTEMENU));
1318    
1319     GetMenuString(*Menu, ID_EDIT_PASTE2, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1320     get_lang_msg("MENU_EDIT_PASTE", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1321     ModifyMenu(*Menu, ID_EDIT_PASTE2, MF_BYCOMMAND, ID_EDIT_PASTE2, ts.UIMsg);
1322     GetMenuString(*Menu, ID_EDIT_PASTECR, uimsg, sizeof(uimsg), MF_BYCOMMAND);
1323     get_lang_msg("MENU_EDIT_PASTECR", ts.UIMsg, sizeof(ts.UIMsg), uimsg, ts.UILanguageFile);
1324     ModifyMenu(*Menu, ID_EDIT_PASTECR, MF_BYCOMMAND, ID_EDIT_PASTECR, ts.UIMsg);
1325     }
1326    
1327     void CVTWindow::ResetSetup()
1328     {
1329     ChangeFont();
1330     BuffChangeWinSize(WinWidth,WinHeight);
1331     ChangeCaret();
1332    
1333     if (cv.Ready) {
1334     ts.PortType = cv.PortType;
1335     if (cv.PortType==IdSerial) {
1336     /* if serial port, change port parameters */
1337     ts.ComPort = cv.ComPort;
1338     CommResetSerial(&ts, &cv, TRUE);
1339     }
1340     }
1341    
1342     /* setup terminal */
1343     SetupTerm();
1344    
1345     /* setup window */
1346     ChangeWin();
1347    
1348     /* Language & IME */
1349     ResetIME();
1350    
1351     /* change TEK window */
1352     if (pTEKWin != NULL)
1353     ((CTEKWindow *)pTEKWin)->RestoreSetup();
1354     }
1355    
1356     void CVTWindow::RestoreSetup()
1357     {
1358     char TempDir[MAXPATHLEN];
1359     char TempName[MAXPATHLEN];
1360    
1361     if ( strlen(ts.SetupFName)==0 )
1362     return;
1363    
1364     ExtractFileName(ts.SetupFName,TempName,sizeof(TempName));
1365     ExtractDirName(ts.SetupFName,TempDir);
1366     if (TempDir[0]==0)
1367     strncpy_s(TempDir, sizeof(TempDir),ts.HomeDir, _TRUNCATE);
1368     FitFileName(TempName,sizeof(TempName),".INI");
1369    
1370     strncpy_s(ts.SetupFName, sizeof(ts.SetupFName),TempDir, _TRUNCATE);
1371     AppendSlash(ts.SetupFName,sizeof(ts.SetupFName));
1372     strncat_s(ts.SetupFName,sizeof(ts.SetupFName),TempName,_TRUNCATE);
1373    
1374     if (LoadTTSET())
1375     (*ReadIniFile)(ts.SetupFName,&ts);
1376     FreeTTSET();
1377    
1378     #ifdef ALPHABLEND_TYPE2
1379     BGInitialize();
1380     BGSetupPrimary(TRUE);
1381     // 2006/03/17 by 337 : Alpha�l���������X
1382     // Layered��������������������������������
1383     if (ts.EtermLookfeel.BGUseAlphaBlendAPI) {
1384     MySetLayeredWindowAttributes(HVTWin, 0, ts.AlphaBlend, LWA_ALPHA);
1385     }
1386     #endif
1387    
1388 maya 2482 #if 0
1389 maya 2476 ChangeDefaultSet(&ts,NULL);
1390 maya 2482 #endif
1391 maya 2476
1392     ResetSetup();
1393     }
1394    
1395     /* called by the [Setup] Terminal command */
1396     void CVTWindow::SetupTerm()
1397     {
1398     if (ts.Language==IdJapanese)
1399     ResetCharSet();
1400     cv.CRSend = ts.CRSend;
1401    
1402     // for russian mode
1403     cv.RussHost = ts.RussHost;
1404     cv.RussClient = ts.RussClient;
1405    
1406     if (cv.Ready && cv.TelFlag && (ts.TelEcho>0))
1407     TelChangeEcho();
1408    
1409     if ((ts.TerminalWidth!=NumOfColumns) ||
1410     (ts.TerminalHeight!=NumOfLines-StatusLine)) {
1411     LockBuffer();
1412     HideStatusLine();
1413     ChangeTerminalSize(ts.TerminalWidth,
1414     ts.TerminalHeight);
1415     UnlockBuffer();
1416     }
1417     else if ((ts.TermIsWin>0) &&
1418     ((ts.TerminalWidth!=WinWidth) ||
1419     (ts.TerminalHeight!=WinHeight-StatusLine)))
1420     BuffChangeWinSize(ts.TerminalWidth,ts.TerminalHeight+StatusLine);
1421     }
1422    
1423     void CVTWindow::Startup()
1424     {
1425     /* auto log */
1426     /* OnCommOpen ���J�n�������������������J�n������ (2007.5.14 maya) */
1427    
1428     if ((TopicName[0]==0) && (ts.MacroFN[0]!=0)) {
1429     // start the macro specified in the command line or setup file
1430     RunMacro(ts.MacroFN,TRUE);
1431     ts.MacroFN[0] = 0;
1432     }
1433     else {// start connection
1434     if (TopicName[0]!=0)
1435     cv.NoMsg=1; /* suppress error messages */
1436     ::PostMessage(HVTWin,WM_USER_COMMSTART,0,0);
1437     }
1438     }
1439    
1440     void CVTWindow::OpenTEK()
1441     {
1442     ActiveWin = IdTEK;
1443     if (HTEKWin==NULL) {
1444     pTEKWin = new CTEKWindow();
1445     }
1446     else {
1447     ::ShowWindow(HTEKWin,SW_SHOWNORMAL);
1448     ::SetFocus(HTEKWin);
1449     }
1450     }
1451    
1452     /////////////////////////////////////////////////////////////////////////////
1453     // CVTWindow message handler
1454    
1455     LRESULT CVTWindow::DefWindowProc(UINT message, WPARAM wParam, LPARAM lParam)
1456     {
1457     LRESULT Result;
1458    
1459     if (message == MsgDlgHelp) {
1460     OnDlgHelp(wParam,lParam);
1461     return 0;
1462     }
1463     else if ((ts.HideTitle>0) &&
1464     (message == WM_NCHITTEST)) {
1465     Result = CFrameWnd::DefWindowProc(message,wParam,lParam);
1466     if ((Result==HTCLIENT) && AltKey())
1467     #ifdef ALPHABLEND_TYPE2
1468     if(ShiftKey())
1469     Result = HTBOTTOMRIGHT;
1470     else
1471     Result = HTCAPTION;
1472     #else
1473     Result = HTCAPTION;
1474     #endif
1475     return Result;
1476     }
1477    
1478     return (CFrameWnd::DefWindowProc(message,wParam,lParam));
1479     }
1480    
1481     BOOL CVTWindow::OnCommand(WPARAM wParam, LPARAM lParam)
1482     {
1483     WORD wID = LOWORD(wParam);
1484     WORD wNotifyCode = HIWORD(wParam);
1485    
1486     if (wNotifyCode==1) {
1487     switch (wID) {
1488     case ID_ACC_SENDBREAK:
1489     // added DisableAcceleratorSendBreak (2007.3.17 maya)
1490     if (!ts.DisableAcceleratorSendBreak)
1491     OnControlSendBreak();
1492     return TRUE;
1493     case ID_ACC_PASTECR:
1494     OnEditPasteCR();
1495     return TRUE;
1496     case ID_ACC_AREYOUTHERE:
1497     OnControlAreYouThere();
1498     return TRUE;
1499     case ID_ACC_PASTE:
1500     OnEditPaste();
1501     return TRUE;
1502     case ID_ACC_DISCONNECT:
1503     OnFileDisconnect();
1504     return TRUE;
1505     }
1506     if (ActiveWin==IdVT) {
1507     switch (wID) {
1508     case ID_ACC_NEWCONNECTION:
1509     OnFileNewConnection();
1510     return TRUE;
1511     case ID_ACC_COPY:
1512     OnEditCopy();
1513     return TRUE;
1514     case ID_ACC_PRINT:
1515     OnFilePrint();
1516     return TRUE;
1517     case ID_ACC_EXIT:
1518     OnFileExit();
1519     return TRUE;
1520     }
1521     }
1522     else { // transfer accelerator message to TEK win
1523     switch (wID) {
1524     case ID_ACC_COPY:
1525     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKEDIT_COPY,0);
1526     return TRUE;
1527     case ID_ACC_PRINT:
1528     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKFILE_PRINT,0);
1529     return TRUE;
1530     case ID_ACC_EXIT:
1531     ::PostMessage(HTEKWin,WM_COMMAND,ID_TEKFILE_EXIT,0);
1532     return TRUE;
1533     }
1534     }
1535     }
1536    
1537     if ((wID>=ID_WINDOW_1) && (wID<ID_WINDOW_1+9)) {
1538     SelectWin(wID-ID_WINDOW_1);
1539     return TRUE;
1540     }
1541     else {
1542     if (TTXProcessCommand(HVTWin, wID))
1543     return TRUE;
1544     else /* TTPLUG */
1545     return CFrameWnd::OnCommand(wParam, lParam);
1546     }
1547     }
1548    
1549     void CVTWindow::OnActivate(UINT nState, CWnd* pWndOther, BOOL bMinimized)
1550     {
1551     DispSetActive(nState!=WA_INACTIVE);
1552     }
1553    
1554     void CVTWindow::OnChar(UINT nChar, UINT nRepCnt, UINT nFlags)
1555     {
1556     unsigned int i;
1557     char Code;
1558    
1559     if (!KeybEnabled || (TalkStatus!=IdTalkKeyb))
1560     return;
1561    
1562     if ((ts.MetaKey>0) && AltKey()) {
1563     ::PostMessage(HVTWin,WM_SYSCHAR,nChar,MAKELONG(nRepCnt,nFlags));
1564     return;
1565     }
1566     Code = nChar;
1567    
1568     if ((ts.Language==IdRussian) &&
1569     ((BYTE)Code>=128))
1570     Code = (char)RussConv(ts.RussKeyb,ts.RussClient,(BYTE)Code);
1571    
1572     for (i=1 ; i<=nRepCnt ; i++) {
1573     CommTextOut(&cv,&Code,1);
1574     if (ts.LocalEcho>0)
1575     CommTextEcho(&cv,&Code,1);
1576     }
1577     }
1578    
1579     /* copy from ttset.c*/
1580     static void WriteInt2(PCHAR Sect, PCHAR Key, PCHAR FName, int i1, int i2)
1581     {
1582     char Temp[32];
1583     _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d,%d", i1, i2);
1584     WritePrivateProfileString(Sect, Key, Temp, FName);
1585     }
1586    
1587     static void SaveVTPos()
1588     {
1589     #define Section "Tera Term"
1590     if (ts.SaveVTWinPos) {
1591     /* VT win position */
1592     WriteInt2(Section, "VTPos", ts.SetupFName, ts.VTPos.x, ts.VTPos.y);
1593    
1594     /* VT terminal size */
1595     WriteInt2(Section, "TerminalSize", ts.SetupFName,
1596     ts.TerminalWidth, ts.TerminalHeight);
1597     }
1598     }
1599    
1600     void CVTWindow::OnClose()
1601     {
1602     if ((HTEKWin!=NULL) && ! ::IsWindowEnabled(HTEKWin)) {
1603     MessageBeep(0);
1604     return;
1605     }
1606     get_lang_msg("MSG_DISCONNECT_CONF", ts.UIMsg, sizeof(ts.UIMsg),
1607     "Disconnect?", ts.UILanguageFile);
1608     if (cv.Ready && (cv.PortType==IdTCPIP) &&
1609     ((ts.PortFlag & PF_CONFIRMDISCONN) != 0) &&
1610     ! CloseTT &&
1611     (::MessageBox(HVTWin, ts.UIMsg, "Tera Term",
1612     MB_OKCANCEL | MB_ICONEXCLAMATION | MB_DEFBUTTON2)==IDCANCEL))
1613     return;
1614    
1615     FileTransEnd(0);
1616     ProtoEnd();
1617    
1618     SaveVTPos();
1619     DestroyWindow();
1620     }
1621    
1622     void CVTWindow::OnDestroy()
1623     {
1624     // remove this window from the window list
1625     UnregWin(HVTWin);
1626    
1627     EndKeyboard();
1628    
1629     /* Disable drag-drop */
1630     ::DragAcceptFiles(HVTWin,FALSE);
1631    
1632     EndDDE();
1633    
1634     if (cv.TelFlag)
1635     EndTelnet();
1636     CommClose(&cv);
1637    
1638     OpenHelp(HVTWin,HH_CLOSE_ALL,0);
1639    
1640     FreeIME();
1641     FreeTTSET();
1642     do { }
1643     while (FreeTTDLG());
1644    
1645     do { }
1646     while (FreeTTFILE());
1647    
1648     if (HTEKWin != NULL)
1649     ::DestroyWindow(HTEKWin);
1650    
1651     EndDisp();
1652    
1653     FreeBuffer();
1654    
1655     CFrameWnd::OnDestroy();
1656     TTXEnd(); /* TTPLUG */
1657     }
1658    
1659     // MessageBox���{�^�������X�p�n���h��
1660     static LRESULT CALLBACK MsgBoxHootProc( INT hc, WPARAM wParam, LPARAM lParam )
1661     {
1662     if ( hc == HCBT_ACTIVATE ) {
1663     // &Send file �� S&CP ���������A�N�Z�����[�^�L�[����������
1664     get_lang_msg("FILEDLG_TRANS_TITLE_SENDFILE", ts.UIMsg, sizeof(ts.UIMsg),
1665     "Send file", ts.UILanguageFile);
1666     SetDlgItemText( (HWND)wParam, IDOK, ts.UIMsg );
1667     SetDlgItemText( (HWND)wParam, IDYES, ts.UIMsg );
1668     SetDlgItemText( (HWND)wParam, IDNO, "SCP" );
1669    
1670     return FALSE;
1671     }
1672    
1673     return CallNextHookEx( NULL, hc, wParam, lParam );
1674     }
1675    
1676     void CVTWindow::OnDropFiles(HDROP hDropInfo)
1677     {
1678     ::SetForegroundWindow(HVTWin);
1679     if (cv.Ready && (SendVar==NULL) && NewFileVar(&SendVar))
1680     {
1681     if (DragQueryFile(hDropInfo,0,SendVar->FullName,
1682     sizeof(SendVar->FullName))>0)
1683     {
1684     DWORD attr;
1685     char *ptr, *q;
1686     char tmpbuf[_MAX_PATH * 2];
1687    
1688     // �f�B���N�g�����������t���p�X�����\���t���� (2004.11.3 yutaka)
1689     attr = GetFileAttributes(SendVar->FullName);
1690     if (attr != -1 && (attr & FILE_ATTRIBUTE_DIRECTORY)) {
1691     ptr = SendVar->FullName;
1692     // �p�X���������� \ -> / ��
1693     setlocale(LC_ALL, ts.Locale);
1694     while (*ptr) {
1695     if (isleadbyte(*ptr)) { // multi-byte
1696     ptr += 2;
1697     continue;
1698     }
1699     if (*ptr == '\\')
1700     *ptr = '/';
1701     ptr++;
1702     }
1703    
1704     // �p�X���������������G�X�P�[�v����
1705     q = tmpbuf;
1706     ptr = SendVar->FullName;
1707     while (*ptr) {
1708     if (*ptr == ' ')
1709     *q++ = '\\';
1710     *q++ = *ptr;
1711     ptr++;
1712     }
1713     *q = '\0'; // null-terminate
1714    
1715     ptr = tmpbuf;
1716    
1717     // console�����M
1718     while (*ptr) {
1719     FSOut1(*ptr);
1720     if (ts.LocalEcho > 0) {
1721     FSEcho1(*ptr);
1722     }
1723     ptr++;
1724     }
1725     FreeFileVar(&SendVar); // �������Y������
1726    
1727     } else {
1728     // Confirm send a file when drag and drop (2007.12.28 maya)
1729     if (ts.ConfirmFileDragAndDrop) {
1730     // ���������t�@�C�������e�����������O���A���[�U���������������s���B(2006.1.21 yutaka)
1731     // MessageBox��SCP���I�������������������B(2008.1.25 yutaka)
1732     char uimsg[MAX_UIMSG];
1733     HHOOK hook = NULL;
1734     DWORD dwThreadID = GetCurrentThreadId();
1735     int ret;
1736    
1737     get_lang_msg("MSG_DANDD_CONF_TITLE", uimsg, sizeof(uimsg),
1738     "Tera Term: File Drag and Drop", ts.UILanguageFile);
1739     get_lang_msg("MSG_DANDD_CONF", ts.UIMsg, sizeof(ts.UIMsg),
1740     "Are you sure that you want to send the file content?", ts.UILanguageFile);
1741    
1742     hook = SetWindowsHookEx( WH_CBT, MsgBoxHootProc, NULL, dwThreadID );
1743     if (cv.isSSH == 2) {
1744     ret = MessageBox(ts.UIMsg, uimsg, MB_YESNOCANCEL | MB_ICONINFORMATION | MB_DEFBUTTON3);
1745     }
1746     else {
1747     // SSH2 �������������������� "SCP" ���o������ (2008.1.25 maya)
1748     ret = MessageBox(ts.UIMsg, uimsg, MB_OKCANCEL | MB_ICONINFORMATION | MB_DEFBUTTON2);
1749     }
1750     UnhookWindowsHookEx( hook );
1751    
1752     if (ret == IDOK || ret == IDYES) { // sendfile
1753     SendVar->DirLen = 0;
1754     ts.TransBin = 0;
1755     FileSendStart();
1756    
1757     } else if (ret == IDNO) { // SCP
1758     typedef int (CALLBACK *PSSH_start_scp)(char *, char *);
1759     static PSSH_start_scp func = NULL;
1760     static HMODULE h = NULL, h2 = NULL;
1761     char msg[128];
1762    
1763     if (func == NULL) {
1764     h2 = LoadLibrary("ttxssh.dll");
1765     if ( ((h = GetModuleHandle("ttxssh.dll")) == NULL) ) {
1766     _snprintf_s(msg, sizeof(msg), _TRUNCATE, "GetModuleHandle(\"ttxssh.dll\")) %d", GetLastError());
1767     goto scp_send_error;
1768     }
1769     func = (PSSH_start_scp)GetProcAddress(h, "TTXScpSendfile");
1770     if (func == NULL) {
1771     _snprintf_s(msg, sizeof(msg), _TRUNCATE, "GetProcAddress(\"TTXScpSendfile\")) %d", GetLastError());
1772     goto scp_send_error;
1773     }
1774     }
1775    
1776     if (func != NULL) {
1777     func(SendVar->FullName, NULL);
1778     goto send_success;
1779     }
1780    
1781     scp_send_error:
1782     ::MessageBox(NULL, msg, "Tera Term: scpsend command error", MB_OK | MB_ICONERROR);
1783     FreeLibrary(h2);
1784     send_success:
1785     FreeFileVar(&SendVar); // �������Y������
1786    
1787     } else {
1788     FreeFileVar(&SendVar);
1789    
1790     }
1791     }
1792     else {
1793     SendVar->DirLen = 0;
1794     ts.TransBin = 0;
1795     FileSendStart();
1796    
1797     }
1798     }
1799     }
1800     else
1801     FreeFileVar(&SendVar);
1802     }
1803     DragFinish(hDropInfo);
1804     }
1805    
1806     void CVTWindow::OnGetMinMaxInfo(MINMAXINFO FAR* lpMMI)
1807     {
1808     #ifndef WINDOW_MAXMIMUM_ENABLED
1809     lpMMI->ptMaxSize.x = 10000;
1810     lpMMI->ptMaxSize.y = 10000;
1811     lpMMI->ptMaxTrackSize.x = 10000;
1812     lpMMI->ptMaxTrackSize.y = 10000;
1813     #endif
1814     }
1815    
1816     void CVTWindow::OnHScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar)
1817     {
1818     int Func;
1819    
1820     switch (nSBCode) {
1821     case SB_BOTTOM:
1822     Func = SCROLL_BOTTOM;
1823     break;
1824     case SB_ENDSCROLL:
1825     return;
1826     case SB_LINEDOWN:
1827     Func = SCROLL_LINEDOWN;
1828     break;
1829     case SB_LINEUP:
1830     Func = SCROLL_LINEUP;
1831     break;
1832     case SB_PAGEDOWN:
1833     Func = SCROLL_PAGEDOWN;
1834     break;
1835     case SB_PAGEUP:
1836     Func = SCROLL_PAGEUP;
1837     break;
1838     case SB_THUMBPOSITION:
1839     case SB_THUMBTRACK:
1840     Func = SCROLL_POS;
1841     break;
1842     case SB_TOP:
1843     Func = SCROLL_TOP;
1844     break;
1845     default:
1846     return;
1847     }
1848     DispHScroll(Func,nPos);
1849     }
1850    
1851     void CVTWindow::OnInitMenuPopup(CMenu* pPopupMenu, UINT nIndex, BOOL bSysMenu)
1852     {
1853     InitMenuPopup(pPopupMenu->m_hMenu);
1854     }
1855    
1856     void CVTWindow::OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags)
1857     {
1858     BYTE KeyState[256];
1859     MSG M;
1860    
1861     if (KeyDown(HVTWin,nChar,nRepCnt,nFlags & 0x1ff))
1862     return;
1863    
1864     if ((ts.MetaKey>0) && ((nFlags & 0x2000) != 0)) {
1865     /* for Ctrl+Alt+Key combination */
1866     GetKeyboardState((PBYTE)KeyState);
1867     KeyState[VK_MENU] = 0;
1868     SetKeyboardState((PBYTE)KeyState);
1869     M.hwnd = HVTWin;
1870     M.message = WM_KEYDOWN;
1871     M.wParam = nChar;
1872     M.lParam = MAKELONG(nRepCnt,nFlags & 0xdfff);
1873     TranslateMessage(&M);
1874    
1875     } else {
1876     // ScrollLock�L�[���_�����������������A�}�E�X���N���b�N����������������������
1877     // �������B���������A�p�[�W���O�������������~�����B
1878     // ���Y�L�[���������������A���������J�������B(2006.11.14 yutaka)
1879     #if 0
1880     GetKeyboardState((PBYTE)KeyState);
1881     if (KeyState[VK_SCROLL] == 0x81) { // on : scroll locked
1882     ScrollLock = TRUE;
1883     } else if (KeyState[VK_SCROLL] == 0x80) { // off : scroll unlocked
1884     ScrollLock = FALSE;
1885     } else {
1886     // do nothing
1887     }
1888     #endif
1889     }
1890    
1891     }
1892    
1893     void CVTWindow::OnKeyUp(UINT nChar, UINT nRepCnt, UINT nFlags)
1894     {
1895     KeyUp(nChar);
1896     }
1897    
1898     void CVTWindow::OnKillFocus(CWnd* pNewWnd)
1899     {
1900     DispDestroyCaret();
1901     FocusReport(FALSE);
1902     CFrameWnd::OnKillFocus(pNewWnd);
1903    
1904     if (IsCaretOn())
1905     CaretKillFocus(TRUE);
1906     }
1907    
1908     void CVTWindow::OnLButtonDblClk(UINT nFlags, CPoint point)
1909     {
1910     if (LButton || MButton || RButton)
1911     return;
1912    
1913     DblClkX = point.x;
1914     DblClkY = point.y;
1915    
1916     if (MouseReport(IdMouseEventBtnDown, IdLeftButton, DblClkX, DblClkY))
1917     return;
1918    
1919     if (BuffDblClk(DblClkX, DblClkY)) // �u���E�U�����o���������������������B (2005.4.3 yutaka)
1920     return;
1921    
1922     LButton = TRUE;
1923     DblClk = TRUE;
1924     AfterDblClk = TRUE;
1925     ::SetTimer(HVTWin, IdDblClkTimer, GetDoubleClickTime(), NULL);
1926    
1927     /* for AutoScrolling */
1928     ::SetCapture(HVTWin);
1929     ::SetTimer(HVTWin, IdScrollTimer, 100, NULL);
1930     }
1931    
1932     void CVTWindow::OnLButtonDown(UINT nFlags, CPoint point)
1933     {
1934     POINT p;
1935    
1936     p.x = point.x;
1937     p.y = point.y;
1938     ButtonDown(p,IdLeftButton);
1939     }
1940    
1941     void CVTWindow::OnLButtonUp(UINT nFlags, CPoint point)
1942     {
1943     MouseReport(IdMouseEventBtnUp, IdLeftButton, point.x, point.y);
1944    
1945     if (! LButton)
1946     return;
1947    
1948     ButtonUp(FALSE);
1949     }
1950    
1951     void CVTWindow::OnMButtonDown(UINT nFlags, CPoint point)
1952     {
1953     POINT p;
1954    
1955     p.x = point.x;
1956     p.y = point.y;
1957     ButtonDown(p,IdMiddleButton);
1958     }
1959    
1960     void CVTWindow::OnMButtonUp(UINT nFlags, CPoint point)
1961     {
1962     BOOL mousereport;
1963    
1964     mousereport = MouseReport(IdMouseEventBtnUp, IdMiddleButton, point.x, point.y);
1965    
1966     if (! MButton)
1967     return;
1968    
1969     // added DisablePasteMouseMButton (2008.3.2 maya)
1970     if (ts.DisablePasteMouseMButton)
1971     ButtonUp(FALSE);
1972     else
1973     ButtonUp(TRUE);
1974     }
1975    
1976     int CVTWindow::OnMouseActivate(CWnd* pDesktopWnd, UINT nHitTest, UINT message)
1977     {
1978     if ((ts.SelOnActive==0) &&
1979     (nHitTest==HTCLIENT)) //disable mouse event for text selection
1980     return MA_ACTIVATEANDEAT; // when window is activated
1981     else
1982     return MA_ACTIVATE;
1983     }
1984    
1985     void CVTWindow::OnMouseMove(UINT nFlags, CPoint point)
1986     {
1987     int i;
1988    
1989     if (! (LButton || MButton || RButton)) {
1990     // �}�E�X�J�[�\��������URL������������������������ (2005.4.2 yutaka)
1991     BuffChangeSelect(point.x, point.y,0);
1992     return;
1993     }
1994    
1995     if (DblClk)
1996     i = 2;
1997     else if (TplClk)
1998     i = 3;
1999     else
2000     i = 1;
2001    
2002     if (!ts.SelectOnlyByLButton ||
2003     (ts.SelectOnlyByLButton && LButton) ) {
2004     // SelectOnlyByLButton == TRUE ���������A���{�^���_�E���������I������ (2007.11.21 maya)
2005     BuffChangeSelect(point.x, point.y,i);
2006     }
2007     }
2008    
2009     void CVTWindow::OnMove(int x, int y)
2010     {
2011     DispSetWinPos();
2012     }
2013    
2014     // �}�E�X�z�C�[�������]
2015     BOOL CVTWindow::OnMouseWheel(
2016     UINT nFlags, // ���z�L�[
2017     short zDelta, // ���]����
2018     CPoint pt // �J�[�\�����u
2019     )
2020     {
2021     int line, i;
2022    
2023     ::ScreenToClient(HVTWin, &pt);
2024    
2025     line = abs(zDelta) / WHEEL_DELTA; // ���C����
2026     if (line < 1) line = 1;
2027    
2028     // ���X�N���[�����������s������������ (2008.4.6 yutaka)
2029     if (line == 1 && ts.MouseWheelScrollLine > 0)
2030     line *= ts.MouseWheelScrollLine;
2031    
2032     if (MouseReport(IdMouseEventWheel, zDelta<0, pt.x, pt.y))
2033     return TRUE;
2034    
2035     if (ts.TranslateWheelToCursor && AppliCursorMode) {
2036     if (zDelta < 0) {
2037     KeyDown(HVTWin, VK_DOWN, line, MapVirtualKey(VK_DOWN, 0) | 0x100);
2038     KeyUp(VK_DOWN);
2039     } else {
2040     KeyDown(HVTWin, VK_UP, line, MapVirtualKey(VK_UP, 0) | 0x100);
2041     KeyUp(VK_UP);
2042     }
2043     } else {
2044     for (i = 0 ; i < line ; i++) {
2045     if (zDelta < 0) {
2046     OnVScroll(SB_LINEDOWN, 0, NULL);
2047     } else {
2048     OnVScroll(SB_LINEUP, 0, NULL);
2049     }
2050     }
2051     }
2052    
2053     return (TRUE);
2054     }
2055    
2056    
2057     void CVTWindow::OnNcLButtonDblClk(UINT nHitTest, CPoint point)
2058     {
2059     if (! Minimized && (nHitTest == HTCAPTION))
2060     DispRestoreWinSize();
2061     else
2062     CFrameWnd::OnNcLButtonDblClk(nHitTest,point);
2063     }
2064    
2065     void CVTWindow::OnNcRButtonDown(UINT nHitTest, CPoint point)
2066     {
2067     if ((nHitTest==HTCAPTION) &&
2068     (ts.HideTitle>0) &&
2069     AltKey())
2070     ::CloseWindow(HVTWin); /* iconize */
2071     }
2072    
2073     void CVTWindow::OnPaint()
2074     {
2075     PAINTSTRUCT ps;
2076     CDC *cdc;
2077     HDC PaintDC;
2078     int Xs, Ys, Xe, Ye;
2079    
2080     #ifdef ALPHABLEND_TYPE2
2081     //<!--by AKASI
2082     BGSetupPrimary(FALSE);
2083     //-->
2084     #endif
2085    
2086     cdc = BeginPaint(&ps);
2087     PaintDC = cdc->GetSafeHdc();
2088    
2089     PaintWindow(PaintDC,ps.rcPaint,ps.fErase, &Xs,&Ys,&Xe,&Ye);
2090     LockBuffer();
2091     BuffUpdateRect(Xs,Ys,Xe,Ye);
2092     UnlockBuffer();
2093     DispEndPaint();
2094    
2095     EndPaint(&ps);
2096    
2097     if (FirstPaint) {
2098     if (strlen(TopicName)>0) {
2099     InitDDE();
2100     SendDDEReady();
2101     }
2102     FirstPaint = FALSE;
2103     Startup();
2104     }
2105     }
2106    
2107     void CVTWindow::OnRButtonDown(UINT nFlags, CPoint point)
2108     {
2109     POINT p;
2110    
2111     p.x = point.x;
2112     p.y = point.y;
2113     ButtonDown(p,IdRightButton);
2114     }
2115    
2116     void CVTWindow::OnRButtonUp(UINT nFlags, CPoint point)
2117     {
2118     BOOL mousereport;
2119    
2120     mousereport = MouseReport(IdMouseEventBtnUp, IdRightButton, point.x, point.y);
2121    
2122     if (! RButton) return;
2123    
2124     // �E�{�^�����������y�[�X�g�����~���� (2005.3.16 yutaka)
2125     if (ts.DisablePasteMouseRButton || mousereport) {
2126     ButtonUp(FALSE);
2127     } else {
2128     ButtonUp(TRUE);
2129     }
2130     }
2131    
2132     void CVTWindow::OnSetFocus(CWnd* pOldWnd)
2133     {
2134     ChangeCaret();
2135     FocusReport(TRUE);
2136     CFrameWnd::OnSetFocus(pOldWnd);
2137     }
2138    
2139     void CVTWindow::OnSize(UINT nType, int cx, int cy)
2140     {
2141     RECT R;
2142     int w, h;
2143    
2144     Minimized = (nType==SIZE_MINIMIZED);
2145    
2146     if (FirstPaint && Minimized)
2147     {
2148     if (strlen(TopicName)>0)
2149     {
2150     InitDDE();
2151     SendDDEReady();
2152     }
2153     FirstPaint = FALSE;
2154     Startup();
2155     return;
2156     }
2157     if (Minimized || DontChangeSize) return;
2158    
2159     if (nType == SIZE_MAXIMIZED) {
2160     ts.TerminalOldWidth = ts.TerminalWidth;
2161     ts.TerminalOldHeight = ts.TerminalHeight;
2162     }
2163    
2164     ::GetWindowRect(HVTWin,&R);
2165     w = R.right - R.left;
2166     h = R.bottom - R.top;
2167     if (AdjustSize)
2168     ResizeWindow(R.left,R.top,w,h,cx,cy);
2169     else {
2170     w = cx / FontWidth;
2171     h = cy / FontHeight;
2172     HideStatusLine();
2173     BuffChangeWinSize(w,h);
2174     }
2175    
2176     #ifdef WINDOW_MAXMIMUM_ENABLED
2177     if (nType == SIZE_MAXIMIZED) {
2178     AdjustSize = 0;
2179     }
2180     #endif
2181     }
2182    
2183     void CVTWindow::OnSysChar(UINT nChar, UINT nRepCnt, UINT nFlags)
2184     {
2185     char e = ESC;
2186     char Code;
2187     unsigned int i;
2188    
2189     #ifdef WINDOW_MAXMIMUM_ENABLED
2190     // ALT + x������������ WM_SYSCHAR �������������B
2191     // ALT + Enter���E�B���h�E�������� (2005.4.24 yutaka)
2192     if (AltKey() && nChar == 13) {
2193     if (IsZoomed()) { // window is maximum
2194     ShowWindow(SW_RESTORE);
2195     } else {
2196     ShowWindow(SW_MAXIMIZE);
2197     }
2198     }
2199     #endif
2200    
2201     if (ts.MetaKey>0)
2202     {
2203     if (!KeybEnabled || (TalkStatus!=IdTalkKeyb)) return;
2204     Code = nChar;
2205     for (i=1 ; i<=nRepCnt ; i++)
2206     {
2207     CommTextOut(&cv,&e,1);
2208     CommTextOut(&cv,&Code,1);
2209     if (ts.LocalEcho>0)
2210     {
2211     CommTextEcho(&cv,&e,1);
2212     CommTextEcho(&cv,&Code,1);
2213     }
2214     }
2215     return;
2216     }
2217     CFrameWnd::OnSysChar(nChar, nRepCnt, nFlags);
2218     }
2219    
2220     void CVTWindow::OnSysColorChange()
2221     {
2222     CFrameWnd::OnSysColorChange();
2223     }
2224    
2225     void CVTWindow::OnSysCommand(UINT nID, LPARAM lParam)
2226     {
2227     if (nID==ID_SHOWMENUBAR) {
2228     ts.PopupMenu = 0;
2229     SwitchMenu();
2230     }
2231     else if (((nID & 0xfff0)==SC_CLOSE) && (cv.PortType==IdTCPIP) &&
2232     cv.Open && ! cv.Ready && (cv.ComPort>0))
2233     // now getting host address (see CommOpen() in commlib.c)
2234     ::PostMessage(HVTWin,WM_SYSCOMMAND,nID,lParam);
2235     else
2236     CFrameWnd::OnSysCommand(nID,lParam);
2237     }
2238    
2239     void CVTWindow::OnSysKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags)
2240     {
2241     if ((nChar==VK_F10) ||
2242     (ts.MetaKey>0) &&
2243     ((MainMenu==NULL) || (nChar!=VK_MENU)) &&
2244     ((nFlags & 0x2000) != 0))
2245     KeyDown(HVTWin,nChar,nRepCnt,nFlags & 0x1ff);
2246     // OnKeyDown(nChar,nRepCnt,nFlags);
2247     else
2248     CFrameWnd::OnSysKeyDown(nChar,nRepCnt,nFlags);
2249     }
2250    
2251     void CVTWindow::OnSysKeyUp(UINT nChar, UINT nRepCnt, UINT nFlags)
2252     {
2253     if (nChar==VK_F10)
2254     OnKeyUp(nChar,nRepCnt,nFlags);
2255     else
2256     CFrameWnd::OnSysKeyUp(nChar,nRepCnt,nFlags);
2257     }
2258    
2259     void CVTWindow::OnTimer(UINT nIDEvent)
2260     {
2261     POINT Point;
2262     WORD PortType;
2263     UINT T;
2264    
2265     if (nIDEvent==IdCaretTimer) {
2266     if (ts.NonblinkingCursor!=0) {
2267     T = GetCaretBlinkTime();
2268     SetCaretBlinkTime(T);
2269     }
2270     else
2271     ::KillTimer(HVTWin,IdCaretTimer);
2272     return;
2273     }
2274     else if (nIDEvent==IdScrollTimer) {
2275     GetCursorPos(&Point);
2276     ::ScreenToClient(HVTWin,&Point);
2277     DispAutoScroll(Point);
2278     if ((Point.x < 0) || (Point.x >= ScreenWidth) ||
2279     (Point.y < 0) || (Point.y >= ScreenHeight))
2280     ::PostMessage(HVTWin,WM_MOUSEMOVE,MK_LBUTTON,MAKELONG(Point.x,Point.y));
2281     return;
2282     }
2283     else if (nIDEvent == IdCancelConnectTimer) {
2284     // �����������������������������A�\�P�b�g�������N���[�Y�B
2285     // CloseSocket()�������������A�����������������������A����Win32API���R�[�������B
2286     if (!cv.Ready) {
2287     closesocket(cv.s);
2288     //::PostMessage(HVTWin, WM_USER_COMMNOTIFY, 0, FD_CLOSE);
2289     }
2290     }
2291    
2292     ::KillTimer(HVTWin, nIDEvent);
2293    
2294     switch (nIDEvent) {
2295     case IdDelayTimer:
2296     cv.CanSend = TRUE;
2297     break;
2298     case IdProtoTimer:
2299     ProtoDlgTimeOut();
2300     case IdDblClkTimer:
2301     AfterDblClk = FALSE;
2302     break;
2303     case IdComEndTimer:
2304     if (! CommCanClose(&cv)) {
2305     // wait if received data remains
2306     SetTimer(IdComEndTimer,1,NULL);
2307     break;
2308     }
2309     cv.Ready = FALSE;
2310     if (cv.TelFlag)
2311     EndTelnet();
2312     PortType = cv.PortType;
2313     CommClose(&cv);
2314     SetDdeComReady(0);
2315     if ((PortType==IdTCPIP) &&
2316     ((ts.PortFlag & PF_BEEPONCONNECT) != 0))
2317     MessageBeep(0);
2318     if ((PortType==IdTCPIP) &&
2319     (ts.AutoWinClose>0) &&
2320     ::IsWindowEnabled(HVTWin) &&
2321     ((HTEKWin==NULL) || ::IsWindowEnabled(HTEKWin)) )
2322     OnClose();
2323     else
2324     ChangeTitle();
2325     break;
2326     case IdPrnStartTimer:
2327     PrnFileStart();
2328     break;
2329     case IdPrnProcTimer:
2330     PrnFileDirectProc();
2331     break;
2332     }
2333     }
2334    
2335     void CVTWindow::OnVScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar)
2336     {
2337     int Func;
2338     SCROLLINFO si;
2339    
2340     switch (nSBCode) {
2341     case SB_BOTTOM: Func = SCROLL_BOTTOM; break;
2342     case SB_ENDSCROLL: return;
2343     case SB_LINEDOWN: Func = SCROLL_LINEDOWN; break;
2344     case SB_LINEUP: Func = SCROLL_LINEUP; break;
2345     case SB_PAGEDOWN: Func = SCROLL_PAGEDOWN; break;
2346     case SB_PAGEUP: Func = SCROLL_PAGEUP; break;
2347     case SB_THUMBPOSITION:
2348     case SB_THUMBTRACK: Func = SCROLL_POS; break;
2349     case SB_TOP: Func = SCROLL_TOP; break;
2350     default:
2351     return;
2352     }
2353    
2354     // �X�N���[�������W�� 16bit ���� 32bit ���g������ (2005.10.4 yutaka)
2355     ZeroMemory(&si, sizeof(SCROLLINFO));
2356     si.cbSize = sizeof(SCROLLINFO);
2357     si.fMask = SIF_TRACKPOS;
2358     if (::GetScrollInfo(HVTWin, SB_VERT, &si)) { // success
2359     nPos = si.nTrackPos;
2360     }
2361    
2362     DispVScroll(Func,nPos);
2363