Develop and Download Open Source Software

Browse Subversion Repository

Contents of /trunk/teraterm/teraterm/addsetting.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 10404 - (show annotations) (download) (as text)
Sun Dec 11 12:08:18 2022 UTC (15 months, 4 weeks ago) by zmatsuo
File MIME type: text/x-c++src
File size: 69581 byte(s)
Susie Plugin Pathを設定できるようにした
1 /*
2 * Copyright (C) 2008- TeraTerm Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * 3. The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29 /*
30 * Additional settings dialog
31 */
32
33 #include <stdio.h>
34 #include <windows.h>
35 #include <commctrl.h>
36 //#include <dwmapi.h> // compat_win.h �������`���g�p�������� include ������
37 #define _CRTDBG_MAP_ALLOC
38 #include <stdlib.h>
39 #include <crtdbg.h>
40 #include <assert.h>
41
42 #include "teraterm.h"
43 #include "tttypes.h"
44 #include "ttwinman.h" // for ts
45 #include "dlglib.h"
46 #include "compat_win.h"
47 #include "helpid.h"
48 #include "addsetting.h"
49 #include "debug_pp.h"
50 #include "tipwin.h"
51 #include "i18n.h"
52 #include "codeconv.h"
53 #include "coding_pp.h"
54 #include "font_pp.h"
55 #include "asprintf.h"
56 #include "win32helper.h"
57 #include "themedlg.h"
58 #include "theme.h"
59 #include "ttcmn_notify2.h"
60
61 const mouse_cursor_t MouseCursor[] = {
62 {"ARROW", IDC_ARROW},
63 {"IBEAM", IDC_IBEAM},
64 {"CROSS", IDC_CROSS},
65 {"HAND", IDC_HAND},
66 {NULL, NULL},
67 };
68 #define MOUSE_CURSOR_MAX (sizeof(MouseCursor)/sizeof(MouseCursor[0]) - 1)
69
70 // CGeneralPropPageDlg �_�C�A���O
71
72 // General Page
73 class CGeneralPropPageDlg : public TTCPropertyPage
74 {
75 public:
76 CGeneralPropPageDlg(HINSTANCE inst);
77 virtual ~CGeneralPropPageDlg();
78 private:
79 void OnInitDialog();
80 void OnOK();
81 enum { IDD = IDD_TABSHEET_GENERAL };
82 void OnHelp();
83 BOOL OnCommand(WPARAM wParam, LPARAM lParam);
84 };
85
86 CGeneralPropPageDlg::CGeneralPropPageDlg(HINSTANCE inst)
87 : TTCPropertyPage(inst, CGeneralPropPageDlg::IDD)
88 {
89 wchar_t *UIMsg;
90 GetI18nStrWW("Tera Term", "DLG_TABSHEET_TITLE_GENERAL",
91 L"General", ts.UILanguageFileW, &UIMsg);
92 m_psp.pszTitle = UIMsg;
93 m_psp.dwFlags |= (PSP_USETITLE | PSP_HASHELP);
94 }
95
96 CGeneralPropPageDlg::~CGeneralPropPageDlg()
97 {
98 free((void *)m_psp.pszTitle);
99 }
100
101 // CGeneralPropPageDlg ���b�Z�[�W �n���h��
102
103 void CGeneralPropPageDlg::OnInitDialog()
104 {
105 TTCPropertyPage::OnInitDialog();
106
107 static const DlgTextInfo TextInfos[] = {
108 { IDC_CLICKABLE_URL, "DLG_TAB_GENERAL_CLICKURL" },
109 { IDC_DISABLE_SENDBREAK, "DLG_TAB_GENERAL_DISABLESENDBREAK" },
110 { IDC_ACCEPT_BROADCAST, "DLG_TAB_GENERAL_ACCEPTBROADCAST" },
111 { IDC_MOUSEWHEEL_SCROLL_LINE, "DLG_TAB_GENERAL_MOUSEWHEEL_SCROLL_LINE" },
112 { IDC_AUTOSCROLL_ONLY_IN_BOTTOM_LINE, "DLG_TAB_GENERAL_AUTOSCROLL_ONLY_IN_BOTTOM_LINE" },
113 { IDC_CLEAR_ON_RESIZE, "DLG_TAB_GENERAL_CLEAR_ON_RESIZE" },
114 { IDC_CURSOR_CHANGE_IME, "DLG_TAB_GENERAL_CURSOR_CHANGE_IME" },
115 { IDC_LIST_HIDDEN_FONTS, "DLG_TAB_GENERAL_LIST_HIDDEN_FONTS" },
116 { IDC_TITLEFMT_GROUP, "DLG_TAB_GENERAL_TITLEFMT_GROUP" },
117 { IDC_TITLEFMT_DISPHOSTNAME, "DLG_TAB_GENERAL_TITLEFMT_DISPHOSTNAME" },
118 { IDC_TITLEFMT_DISPSESSION, "DLG_TAB_GENERAL_TITLEFMT_DISPSESSION" },
119 { IDC_TITLEFMT_DISPVTTEK, "DLG_TAB_GENERAL_TITLEFMT_DISPVTTEK" },
120 { IDC_TITLEFMT_SWAPHOSTTITLE, "DLG_TAB_GENERAL_TITLEFMT_SWAPHOSTTITLE" },
121 { IDC_TITLEFMT_DISPTCPPORT, "DLG_TAB_GENERAL_TITLEFMT_DISPTCPPORT" },
122 { IDC_TITLEFMT_DISPSERIALSPEED, "DLG_TAB_GENERAL_TITLEFMT_DISPSERIALSPEED" },
123 { IDC_NOTIFICATION_TITLE, "DLG_TAB_GENERAL_NOTIFICATION_TITLE" },
124 { IDC_NOTIFY_SOUND, "DLG_TAB_GENERAL_NOTIFIY_SOUND" },
125 { IDC_NOTIFICATION_TEST_POPUP, "DLG_TAB_GENERAL_NOTIFICATION_TEST_POPUP" },
126 { IDC_NOTIFICATION_TEST_TRAY, "DLG_TAB_GENERAL_NOTIFICATION_TEST_TRAY" },
127 };
128 SetDlgTextsW(m_hWnd, TextInfos, _countof(TextInfos), ts.UILanguageFileW);
129
130 // (1)DisableAcceleratorSendBreak
131 SetCheck(IDC_DISABLE_SENDBREAK, ts.DisableAcceleratorSendBreak);
132
133 // (2)EnableClickableUrl
134 SetCheck(IDC_CLICKABLE_URL, ts.EnableClickableUrl);
135
136 // (3)AcceptBroadcast 337: 2007/03/20
137 SetCheck(IDC_ACCEPT_BROADCAST, ts.AcceptBroadcast);
138
139 // (4)IDC_MOUSEWHEEL_SCROLL_LINE
140 SetDlgItemNum(IDC_SCROLL_LINE, ts.MouseWheelScrollLine);
141
142 // (5)IDC_AUTOSCROLL_ONLY_IN_BOTTOM_LINE
143 SetCheck(IDC_AUTOSCROLL_ONLY_IN_BOTTOM_LINE, ts.AutoScrollOnlyInBottomLine);
144
145 // (6)IDC_CLEAR_ON_RESIZE
146 SetCheck(IDC_CLEAR_ON_RESIZE, (ts.TermFlag & TF_CLEARONRESIZE) != 0);
147
148 // (7)IDC_CURSOR_CHANGE_IME
149 SetCheck(IDC_CURSOR_CHANGE_IME, (ts.WindowFlag & WF_IMECURSORCHANGE) != 0);
150
151 // (8)IDC_LIST_HIDDEN_FONTS
152 SetCheck(IDC_LIST_HIDDEN_FONTS, ts.ListHiddenFonts);
153
154 // (9) Title Format
155 SetCheck(IDC_TITLEFMT_DISPHOSTNAME, (ts.TitleFormat & 1) != 0);
156 SetCheck(IDC_TITLEFMT_DISPSESSION, (ts.TitleFormat & (1<<1)) != 0);
157 SetCheck(IDC_TITLEFMT_DISPVTTEK, (ts.TitleFormat & (1<<2)) != 0);
158 SetCheck(IDC_TITLEFMT_SWAPHOSTTITLE, (ts.TitleFormat & (1<<3)) != 0);
159 SetCheck(IDC_TITLEFMT_DISPTCPPORT, (ts.TitleFormat & (1<<4)) != 0);
160 SetCheck(IDC_TITLEFMT_DISPSERIALSPEED, (ts.TitleFormat & (1<<5)) != 0);
161
162 // Notify
163 SetCheck(IDC_NOTIFY_SOUND, ts.NotifySound);
164
165 // �_�C�A���O���t�H�[�J�X�������� (2004.12.7 yutaka)
166 ::SetFocus(::GetDlgItem(GetSafeHwnd(), IDC_CLICKABLE_URL));
167 }
168
169 void CGeneralPropPageDlg::OnOK()
170 {
171 char buf[64];
172 int val;
173
174 // (1)
175 ts.DisableAcceleratorSendBreak = GetCheck(IDC_DISABLE_SENDBREAK);
176
177 // (2)
178 ts.EnableClickableUrl = GetCheck(IDC_CLICKABLE_URL);
179
180 // (3) 337: 2007/03/20
181 ts.AcceptBroadcast = GetCheck(IDC_ACCEPT_BROADCAST);
182
183 // (4)IDC_MOUSEWHEEL_SCROLL_LINE
184 GetDlgItemText(IDC_SCROLL_LINE, buf, _countof(buf));
185 val = atoi(buf);
186 if (val > 0)
187 ts.MouseWheelScrollLine = val;
188
189 // (5)IDC_AUTOSCROLL_ONLY_IN_BOTTOM_LINE
190 ts.AutoScrollOnlyInBottomLine = GetCheck(IDC_AUTOSCROLL_ONLY_IN_BOTTOM_LINE);
191
192 // (6)IDC_CLEAR_ON_RESIZE
193 if (((ts.TermFlag & TF_CLEARONRESIZE) != 0) != GetCheck(IDC_CLEAR_ON_RESIZE)) {
194 ts.TermFlag ^= TF_CLEARONRESIZE;
195 }
196
197 // (7)IDC_CURSOR_CHANGE_IME
198 if (((ts.WindowFlag & WF_IMECURSORCHANGE) != 0) != GetCheck(IDC_CURSOR_CHANGE_IME)) {
199 ts.WindowFlag ^= WF_IMECURSORCHANGE;
200 }
201
202 // (8)IDC_LIST_HIDDEN_FONTS
203 ts.ListHiddenFonts = GetCheck(IDC_LIST_HIDDEN_FONTS);
204
205 // (9) Title Format
206 ts.TitleFormat = GetCheck(IDC_TITLEFMT_DISPHOSTNAME) == BST_CHECKED;
207 ts.TitleFormat |= (GetCheck(IDC_TITLEFMT_DISPSESSION) == BST_CHECKED) << 1;
208 ts.TitleFormat |= (GetCheck(IDC_TITLEFMT_DISPVTTEK) == BST_CHECKED) << 2;
209 ts.TitleFormat |= (GetCheck(IDC_TITLEFMT_SWAPHOSTTITLE) == BST_CHECKED) << 3;
210 ts.TitleFormat |= (GetCheck(IDC_TITLEFMT_DISPTCPPORT) == BST_CHECKED) << 4;
211 ts.TitleFormat |= (GetCheck(IDC_TITLEFMT_DISPSERIALSPEED) == BST_CHECKED) << 5;
212
213 // Notify
214 {
215 BOOL notify_sound = (BOOL)GetCheck(IDC_NOTIFY_SOUND);
216 if (notify_sound != ts.NotifySound) {
217 ts.NotifySound = notify_sound;
218 Notify2SetSound((NotifyIcon *)cv.NotifyIcon, notify_sound);
219 }
220 }
221 }
222
223 void CGeneralPropPageDlg::OnHelp()
224 {
225 PostMessage(HVTWin, WM_USER_DLGHELP2, HlpMenuSetupAdditional, 0);
226 }
227
228 BOOL CGeneralPropPageDlg::OnCommand(WPARAM wParam, LPARAM lParam)
229 {
230 switch (wParam) {
231 case IDC_NOTIFICATION_TEST_POPUP | (BN_CLICKED << 16): {
232 // popup���o���e�X�g
233 NotifyIcon *ni = (NotifyIcon *)cv.NotifyIcon;
234 const wchar_t *msg = L"Test button was pushed";
235 BOOL prev_sound = Notify2GetSound(ni);
236 BOOL notify_sound = (BOOL)GetCheck(IDC_NOTIFY_SOUND);
237 Notify2SetSound(ni, notify_sound);
238 Notify2SetMessageW(ni, msg, NULL, 1);
239 Notify2SetSound(ni, prev_sound);
240 break;
241 }
242 case IDC_NOTIFICATION_TEST_TRAY | (BN_CLICKED << 16): {
243 // tray��icon���o��(��������������)
244 NotifyIcon *ni = (NotifyIcon *)cv.NotifyIcon;
245 BOOL prev_sound = Notify2GetSound(ni);
246 BOOL notify_sound = (BOOL)GetCheck(IDC_NOTIFY_SOUND);
247 Notify2SetSound(ni, notify_sound);
248 Notify2SetBallonDontHide(ni, TRUE);
249 Notify2SetMessageW(ni, NULL, NULL, 1);
250 Notify2SetSound(ni, prev_sound);
251
252 static const TTMessageBoxInfoW info = {
253 "Tera Term",
254 "MSG_TT_NOTICE", L"Tera Term: Notice",
255 NULL, L"You can change notify setting",
256 MB_OK };
257 TTMessageBoxW(m_hWnd, &info, ts.UILanguageFileW);
258
259 // ���m�������A�C�R��������
260 Notify2Hide(ni);
261 Notify2SetBallonDontHide(ni, FALSE);
262 break;
263 }
264 default:
265 break;
266 }
267 return TTCPropertyPage::OnCommand(wParam, lParam);
268 }
269
270 // CSequencePropPageDlg �_�C�A���O
271
272 CSequencePropPageDlg::CSequencePropPageDlg(HINSTANCE inst)
273 : TTCPropertyPage(inst, CSequencePropPageDlg::IDD)
274 {
275 wchar_t *UIMsg;
276 GetI18nStrWW("Tera Term", "DLG_TABSHEET_TITLE_SEQUENCE",
277 L"Control Sequence", ts.UILanguageFileW, &UIMsg);
278 m_psp.pszTitle = UIMsg;
279 m_psp.dwFlags |= (PSP_USETITLE | PSP_HASHELP);
280 }
281
282 CSequencePropPageDlg::~CSequencePropPageDlg()
283 {
284 free((void *)m_psp.pszTitle);
285 }
286
287 // CSequencePropPageDlg ���b�Z�[�W �n���h��
288
289 void CSequencePropPageDlg::OnInitDialog()
290 {
291 TTCPropertyPage::OnInitDialog();
292
293 static const DlgTextInfo TextInfos[] = {
294 { IDC_ACCEPT_MOUSE_EVENT_TRACKING, "DLG_TAB_SEQUENCE_ACCEPT_MOUSE_EVENT_TRACKING" },
295 { IDC_DISABLE_MOUSE_TRACKING_CTRL, "DLG_TAB_SEQUENCE_DISABLE_MOUSE_TRACKING_CTRL" },
296 { IDC_ACCEPT_TITLE_CHANGING_LABEL, "DLG_TAB_SEQUENCE_ACCEPT_TITLE_CHANGING" },
297 { IDC_CURSOR_CTRL_SEQ, "DLG_TAB_SEQUENCE_CURSOR_CTRL" },
298 { IDC_WINDOW_CTRL, "DLG_TAB_SEQUENCE_WINDOW_CTRL" },
299 { IDC_WINDOW_REPORT, "DLG_TAB_SEQUENCE_WINDOW_REPORT" },
300 { IDC_TITLE_REPORT_LABEL, "DLG_TAB_SEQUENCE_TITLE_REPORT" },
301 { IDC_CLIPBOARD_ACCESS_LABEL, "DLG_TAB_SEQUENCE_CLIPBOARD_ACCESS" },
302 { IDC_CLIPBOARD_NOTIFY, "DLG_TAB_SEQUENCE_CLIPBOARD_NOTIFY" },
303 { IDC_ACCEPT_CLEAR_SBUFF, "DLG_TAB_SEQUENCE_ACCEPT_CLEAR_SBUFF" },
304 { IDC_DISABLE_PRINT_START, "DLG_TAB_SEQUENCE_PRINT_START" },
305 { IDC_BEEP_LABEL, "DLG_TAB_SEQUENCE_BEEP_LABEL" },
306 };
307 SetDlgTextsW(m_hWnd, TextInfos, _countof(TextInfos), ts.UILanguageFileW);
308
309 const static I18nTextInfo accept_title_changing[] = {
310 { "DLG_TAB_SEQUENCE_ACCEPT_TITLE_CHANGING_OFF", L"off" },
311 { "DLG_TAB_SEQUENCE_ACCEPT_TITLE_CHANGING_OVERWRITE", L"overwrite" },
312 { "DLG_TAB_SEQUENCE_ACCEPT_TITLE_CHANGING_AHEAD", L"ahead" },
313 { "DLG_TAB_SEQUENCE_ACCEPT_TITLE_CHANGING_LAST", L"last" },
314 };
315 SetI18nListW("Tera Term", m_hWnd, IDC_ACCEPT_TITLE_CHANGING, accept_title_changing, _countof(accept_title_changing),
316 ts.UILanguageFileW, 0);
317
318 const static I18nTextInfo sequence_title_report[] = {
319 { "DLG_TAB_SEQUENCE_TITLE_REPORT_IGNORE", L"ignore" },
320 { "DLG_TAB_SEQUENCE_TITLE_REPORT_ACCEPT", L"accept" },
321 { "DLG_TAB_SEQUENCE_TITLE_REPORT_EMPTY", L"empty" },
322 };
323 SetI18nListW("Tera Term", m_hWnd, IDC_TITLE_REPORT, sequence_title_report, _countof(sequence_title_report),
324 ts.UILanguageFileW, 0);
325
326 const static I18nTextInfo sequence_clipboard_access[] = {
327 { "DLG_TAB_SEQUENCE_CLIPBOARD_ACCESS_OFF", L"off" },
328 { "DLG_TAB_SEQUENCE_CLIPBOARD_ACCESS_WRITE", L"write only" },
329 { "DLG_TAB_SEQUENCE_CLIPBOARD_ACCESS_READ", L"read only" },
330 { "DLG_TAB_SEQUENCE_CLIPBOARD_ACCESS_ON", L"read/write" },
331 };
332 SetI18nListW("Tera Term", m_hWnd, IDC_CLIPBOARD_ACCESS, sequence_clipboard_access,
333 _countof(sequence_clipboard_access), ts.UILanguageFileW, 0);
334
335 // (1)IDC_ACCEPT_MOUSE_EVENT_TRACKING
336 SetCheck(IDC_ACCEPT_MOUSE_EVENT_TRACKING, ts.MouseEventTracking);
337 EnableDlgItem(IDC_DISABLE_MOUSE_TRACKING_CTRL, ts.MouseEventTracking ? TRUE : FALSE);
338
339 // (2)IDC_DISABLE_MOUSE_TRACKING_CTRL
340 SetCheck(IDC_DISABLE_MOUSE_TRACKING_CTRL, ts.DisableMouseTrackingByCtrl);
341
342 // (3)IDC_ACCEPT_TITLE_CHANGING
343 SetCurSel(IDC_ACCEPT_TITLE_CHANGING, ts.AcceptTitleChangeRequest);
344
345 // (4)IDC_TITLE_REPORT
346 SetCurSel(IDC_TITLE_REPORT,
347 (ts.WindowFlag & WF_TITLEREPORT) == IdTitleReportIgnore ? 0 :
348 (ts.WindowFlag & WF_TITLEREPORT) == IdTitleReportAccept ? 1
349 /*(ts.WindowFlag & WF_TITLEREPORT) == IdTitleReportEmptye ? */ : 2);
350
351 // (5)IDC_WINDOW_CTRL
352 SetCheck(IDC_WINDOW_CTRL, (ts.WindowFlag & WF_WINDOWCHANGE) != 0);
353
354 // (6)IDC_WINDOW_REPORT
355 SetCheck(IDC_WINDOW_REPORT, (ts.WindowFlag & WF_WINDOWREPORT) != 0);
356
357 // (7)IDC_CURSOR_CTRL_SEQ
358 SetCheck(IDC_CURSOR_CTRL_SEQ, (ts.WindowFlag & WF_CURSORCHANGE) != 0);
359
360 // (8)IDC_CLIPBOARD_ACCESS
361 SetCurSel(IDC_CLIPBOARD_ACCESS,
362 (ts.CtrlFlag & CSF_CBRW) == CSF_CBRW ? 3 :
363 (ts.CtrlFlag & CSF_CBRW) == CSF_CBREAD ? 2 :
364 (ts.CtrlFlag & CSF_CBRW) == CSF_CBWRITE ? 1 :
365 0); // off
366
367 // (9)IDC_CLIPBOARD_NOTIFY
368 SetCheck(IDC_CLIPBOARD_NOTIFY, ts.NotifyClipboardAccess);
369 EnableDlgItem(IDC_CLIPBOARD_NOTIFY, HasBalloonTipSupport() ? TRUE : FALSE);
370
371 // (10)IDC_ACCEPT_CLEAR_SBUFF
372 SetCheck(IDC_ACCEPT_CLEAR_SBUFF, (ts.TermFlag & TF_REMOTECLEARSBUFF) != 0);
373
374 SetCheck(IDC_DISABLE_PRINT_START, (ts.TermFlag & TF_PRINTERCTRL) == 0);
375
376 const static I18nTextInfo beep_type[] = {
377 { "DLG_TAB_SEQUENCE_BEEP_DISABLE", L"disable" }, // IdBeepOff = 0
378 { "DLG_TAB_SEQUENCE_BEEP_SOUND", L"sound" }, // IdBeepOn = 1
379 { "DLG_TAB_SEQUENCE_BEEP_VISUALBELL", L"visualbell" }, // IdBeepVisual = 2
380 };
381 SetI18nListW("Tera Term", m_hWnd, IDC_BEEP_DROPDOWN, beep_type,
382 _countof(beep_type), ts.UILanguageFileW, ts.Beep);
383
384 // �_�C�A���O���t�H�[�J�X�������� (2004.12.7 yutaka)
385 ::SetFocus(::GetDlgItem(GetSafeHwnd(), IDC_ACCEPT_MOUSE_EVENT_TRACKING));
386 }
387
388 BOOL CSequencePropPageDlg::OnCommand(WPARAM wParam, LPARAM lParam)
389 {
390 switch (wParam) {
391 case IDC_ACCEPT_MOUSE_EVENT_TRACKING | (BN_CLICKED << 16):
392 EnableDlgItem(IDC_DISABLE_MOUSE_TRACKING_CTRL,
393 GetCheck(IDC_ACCEPT_MOUSE_EVENT_TRACKING) ? TRUE : FALSE);
394 return TRUE;
395 }
396 return TTCPropertyPage::OnCommand(wParam, lParam);
397 }
398
399 void CSequencePropPageDlg::OnOK()
400 {
401 // (1)IDC_ACCEPT_MOUSE_EVENT_TRACKING
402 ts.MouseEventTracking = GetCheck(IDC_ACCEPT_MOUSE_EVENT_TRACKING);
403
404 // (2)IDC_DISABLE_MOUSE_TRACKING_CTRL
405 ts.DisableMouseTrackingByCtrl = GetCheck(IDC_DISABLE_MOUSE_TRACKING_CTRL);
406
407 // (3)IDC_ACCEPT_TITLE_CHANGING
408 int sel = GetCurSel(IDC_ACCEPT_TITLE_CHANGING);
409 if (0 <= sel && sel <= IdTitleChangeRequestMax) {
410 ts.AcceptTitleChangeRequest = sel;
411 }
412
413 // (4)IDC_TITLE_REPORT
414 switch (GetCurSel(IDC_TITLE_REPORT)) {
415 case 0:
416 ts.WindowFlag &= ~WF_TITLEREPORT;
417 break;
418 case 1:
419 ts.WindowFlag &= ~WF_TITLEREPORT;
420 ts.WindowFlag |= IdTitleReportAccept;
421 break;
422 case 2:
423 ts.WindowFlag |= IdTitleReportEmpty;
424 break;
425 default: // Invalid value.
426 break;
427 }
428
429 // (5)IDC_WINDOW_CTRL
430 if (((ts.WindowFlag & WF_WINDOWCHANGE) != 0) != GetCheck(IDC_WINDOW_CTRL)) {
431 ts.WindowFlag ^= WF_WINDOWCHANGE;
432 }
433
434 // (6)IDC_WINDOW_REPORT
435 if (((ts.WindowFlag & WF_WINDOWREPORT) != 0) != GetCheck(IDC_WINDOW_REPORT)) {
436 ts.WindowFlag ^= WF_WINDOWREPORT;
437 }
438
439 // (7)IDC_CURSOR_CTRL_SEQ
440 if (((ts.WindowFlag & WF_CURSORCHANGE) != 0) != GetCheck(IDC_CURSOR_CTRL_SEQ)) {
441 ts.WindowFlag ^= WF_CURSORCHANGE;
442 }
443
444 // (8)IDC_CLIPBOARD_ACCESS
445 switch (GetCurSel(IDC_CLIPBOARD_ACCESS)) {
446 case 0: // off
447 ts.CtrlFlag &= ~CSF_CBRW;
448 break;
449 case 1: // write only
450 ts.CtrlFlag &= ~CSF_CBRW;
451 ts.CtrlFlag |= CSF_CBWRITE;
452 break;
453 case 2: // read only
454 ts.CtrlFlag &= ~CSF_CBRW;
455 ts.CtrlFlag |= CSF_CBREAD;
456 break;
457 case 3: // read/write
458 ts.CtrlFlag |= CSF_CBRW;
459 break;
460 default: // Invalid value.
461 break;
462 }
463
464 // (9)IDC_CLIPBOARD_ACCESS
465 ts.NotifyClipboardAccess = GetCheck(IDC_CLIPBOARD_NOTIFY);
466
467 // (10)IDC_ACCEPT_CLEAR_SBUFF
468 if (((ts.TermFlag & TF_REMOTECLEARSBUFF) != 0) != GetCheck(IDC_ACCEPT_CLEAR_SBUFF)) {
469 ts.TermFlag ^= TF_REMOTECLEARSBUFF;
470 }
471
472 if (GetCheck(IDC_DISABLE_PRINT_START) == 0) {
473 ts.TermFlag |= TF_PRINTERCTRL;
474 } else {
475 ts.TermFlag &= ~TF_PRINTERCTRL;
476 }
477
478 ts.Beep = GetCurSel(IDC_BEEP_DROPDOWN);
479 }
480
481 void CSequencePropPageDlg::OnHelp()
482 {
483 PostMessage(HVTWin, WM_USER_DLGHELP2, HlpMenuSetupAdditional, 0);
484 }
485
486 // CCopypastePropPageDlg �_�C�A���O
487
488 CCopypastePropPageDlg::CCopypastePropPageDlg(HINSTANCE inst)
489 : TTCPropertyPage(inst, CCopypastePropPageDlg::IDD)
490 {
491 wchar_t *UIMsg;
492 GetI18nStrWW("Tera Term", "DLG_TABSHEET_TITLE_COPYPASTE",
493 L"Copy and Paste", ts.UILanguageFileW, &UIMsg);
494 m_psp.pszTitle = UIMsg;
495 m_psp.dwFlags |= (PSP_USETITLE | PSP_HASHELP);
496 }
497
498 CCopypastePropPageDlg::~CCopypastePropPageDlg()
499 {
500 free((void *)m_psp.pszTitle);
501 }
502
503 // CCopypastePropPageDlg ���b�Z�[�W �n���h��
504
505 void CCopypastePropPageDlg::OnInitDialog()
506 {
507 TTCPropertyPage::OnInitDialog();
508
509 static const DlgTextInfo TextInfos[] = {
510 { IDC_LINECOPY, "DLG_TAB_COPYPASTE_CONTINUE" },
511 { IDC_DISABLE_PASTE_RBUTTON, "DLG_TAB_COPYPASTE_MOUSEPASTE" },
512 { IDC_CONFIRM_PASTE_RBUTTON, "DLG_TAB_COPYPASTE_CONFIRMPASTE" },
513 { IDC_DISABLE_PASTE_MBUTTON, "DLG_TAB_COPYPASTE_MOUSEPASTEM" },
514 { IDC_SELECT_LBUTTON, "DLG_TAB_COPYPASTE_SELECTLBUTTON" },
515 { IDC_TRIMNLCHAR, "DLG_TAB_COPYPASTE_TRIM_TRAILING_NL" },
516 { IDC_CONFIRM_CHANGE_PASTE, "DLG_TAB_COPYPASTE_CONFIRM_CHANGE_PASTE" },
517 { IDC_CONFIRM_STRING_FILE_LABEL, "DLG_TAB_COPYPASTE_STRINGFILE" },
518 { IDC_DELIMITER, "DLG_TAB_COPYPASTE_DELIMITER" },
519 { IDC_PASTEDELAY_LABEL, "DLG_TAB_COPYPASTE_PASTEDELAY" },
520 { IDC_PASTEDELAY_LABEL2, "DLG_TAB_COPYPASTE_PASTEDELAY2" },
521 { IDC_SELECT_ON_ACTIVATE, "DLG_TAB_COPYPASTE_SELECT_ON_ACTIVATE" }
522 };
523 SetDlgTextsW(m_hWnd, TextInfos, _countof(TextInfos), ts.UILanguageFileW);
524
525 // (1)Enable continued-line copy
526 SetCheck(IDC_LINECOPY, ts.EnableContinuedLineCopy);
527
528 // (2)DisablePasteMouseRButton
529 if (ts.PasteFlag & CPF_DISABLE_RBUTTON) {
530 SetCheck(IDC_DISABLE_PASTE_RBUTTON, BST_CHECKED);
531 EnableDlgItem(IDC_CONFIRM_PASTE_RBUTTON, FALSE);
532 } else {
533 SetCheck(IDC_DISABLE_PASTE_RBUTTON, BST_UNCHECKED);
534 EnableDlgItem(IDC_CONFIRM_PASTE_RBUTTON, TRUE);
535 }
536
537 // (3)ConfirmPasteMouseRButton
538 SetCheck(IDC_CONFIRM_PASTE_RBUTTON, (ts.PasteFlag & CPF_CONFIRM_RBUTTON)?BST_CHECKED:BST_UNCHECKED);
539
540 // (4)DisablePasteMouseMButton
541 SetCheck(IDC_DISABLE_PASTE_MBUTTON, (ts.PasteFlag & CPF_DISABLE_MBUTTON)?BST_CHECKED:BST_UNCHECKED);
542
543 // (5)SelectOnlyByLButton
544 SetCheck(IDC_SELECT_LBUTTON, ts.SelectOnlyByLButton);
545
546 // (6)TrimTrailingNLonPaste
547 SetCheck(IDC_TRIMNLCHAR, (ts.PasteFlag & CPF_TRIM_TRAILING_NL)?BST_CHECKED:BST_UNCHECKED);
548
549 // (7)ConfirmChangePaste
550 SetCheck(IDC_CONFIRM_CHANGE_PASTE, (ts.PasteFlag & CPF_CONFIRM_CHANGEPASTE)?BST_CHECKED:BST_UNCHECKED);
551
552 // �t�@�C���p�X
553 SetDlgItemTextA(IDC_CONFIRM_STRING_FILE, ts.ConfirmChangePasteStringFile);
554 if (ts.PasteFlag & CPF_CONFIRM_CHANGEPASTE) {
555 EnableDlgItem(IDC_CONFIRM_STRING_FILE, TRUE);
556 EnableDlgItem(IDC_CONFIRM_STRING_FILE_PATH, TRUE);
557 } else {
558 EnableDlgItem(IDC_CONFIRM_STRING_FILE, FALSE);
559 EnableDlgItem(IDC_CONFIRM_STRING_FILE_PATH, FALSE);
560 }
561
562 // (8)delimiter characters
563 SetDlgItemTextA(IDC_DELIM_LIST, ts.DelimList);
564
565 // (9)PasteDelayPerLine
566 SetDlgItemNum(IDC_PASTEDELAY_EDIT, ts.PasteDelayPerLine);
567
568 // (10) SelectOnActivate
569 SetCheck(IDC_SELECT_ON_ACTIVATE, ts.SelOnActive ? BST_CHECKED : BST_UNCHECKED);
570
571 // �_�C�A���O���t�H�[�J�X��������
572 ::SetFocus(::GetDlgItem(GetSafeHwnd(), IDC_LINECOPY));
573 }
574
575 BOOL CCopypastePropPageDlg::OnCommand(WPARAM wParam, LPARAM lParam)
576 {
577 switch (wParam) {
578 case IDC_DISABLE_PASTE_RBUTTON | (BN_CLICKED << 16):
579 EnableDlgItem(IDC_CONFIRM_PASTE_RBUTTON,
580 GetCheck(IDC_DISABLE_PASTE_RBUTTON) ? FALSE : TRUE);
581 return TRUE;
582
583 case IDC_CONFIRM_CHANGE_PASTE | (BN_CLICKED << 16):
584 if (GetCheck(IDC_CONFIRM_CHANGE_PASTE)) {
585 EnableDlgItem(IDC_CONFIRM_STRING_FILE, TRUE);
586 EnableDlgItem(IDC_CONFIRM_STRING_FILE_PATH, TRUE);
587 } else {
588 EnableDlgItem(IDC_CONFIRM_STRING_FILE, FALSE);
589 EnableDlgItem(IDC_CONFIRM_STRING_FILE_PATH, FALSE);
590 }
591 return TRUE;
592
593 case IDC_CONFIRM_STRING_FILE_PATH | (BN_CLICKED << 16):
594 {
595 wchar_t *def;
596 hGetDlgItemTextW(m_hWnd, IDC_CONFIRM_STRING_FILE, &def);
597
598 TTOPENFILENAMEW ofn = {};
599 ofn.hwndOwner = m_hWnd;GetSafeHwnd();
600 ofn.lpstrFilter = TTGetLangStrW("Tera Term", "FILEDLG_SELECT_CONFIRM_STRING_APP_FILTER", L"txt(*.txt)\\0*.txt\\0all(*.*)\\0*.*\\0\\0", ts.UILanguageFile);
601 ofn.lpstrFile = def;
602 ofn.lpstrTitle = TTGetLangStrW("Tera Term", "FILEDLG_SELECT_CONFIRM_STRING_APP_TITLE", L"Choose a file including strings for ConfirmChangePaste", ts.UILanguageFile);
603 ofn.lpstrInitialDir = ts.HomeDirW;
604 ofn.Flags = OFN_FILEMUSTEXIST | OFN_HIDEREADONLY;
605 wchar_t *filename;
606 BOOL ok = TTGetOpenFileNameW(&ofn, &filename);
607 if (ok) {
608 SetDlgItemTextW(IDC_CONFIRM_STRING_FILE, filename);
609 free(filename);
610 }
611 free(def);
612 free((void *)ofn.lpstrFilter);
613 free((void *)ofn.lpstrTitle);
614 }
615 return TRUE;
616 }
617
618 return TTCPropertyPage::OnCommand(wParam, lParam);
619 }
620
621 void CCopypastePropPageDlg::OnOK()
622 {
623 int val;
624
625 // (1)
626 ts.EnableContinuedLineCopy = GetCheck(IDC_LINECOPY);
627
628 // (2)
629 if (GetCheck(IDC_DISABLE_PASTE_RBUTTON)) {
630 ts.PasteFlag |= CPF_DISABLE_RBUTTON;
631 }
632 else {
633 ts.PasteFlag &= ~CPF_DISABLE_RBUTTON;
634 }
635
636 // (3)
637 if (GetCheck(IDC_CONFIRM_PASTE_RBUTTON)) {
638 ts.PasteFlag |= CPF_CONFIRM_RBUTTON;
639 }
640 else {
641 ts.PasteFlag &= ~CPF_CONFIRM_RBUTTON;
642 }
643
644 // (4)
645 if (GetCheck(IDC_DISABLE_PASTE_MBUTTON)) {
646 ts.PasteFlag |= CPF_DISABLE_MBUTTON;
647 }
648 else {
649 ts.PasteFlag &= ~CPF_DISABLE_MBUTTON;
650 }
651
652 // (5)
653 ts.SelectOnlyByLButton = GetCheck(IDC_SELECT_LBUTTON);
654
655 // (6)
656 if (GetCheck(IDC_TRIMNLCHAR)) {
657 ts.PasteFlag |= CPF_TRIM_TRAILING_NL;
658 }
659 else {
660 ts.PasteFlag &= ~CPF_TRIM_TRAILING_NL;
661 }
662
663 // (7)IDC_CONFIRM_CHANGE_PASTE
664 if (GetCheck(IDC_CONFIRM_CHANGE_PASTE)) {
665 ts.PasteFlag |= CPF_CONFIRM_CHANGEPASTE;
666 }
667 else {
668 ts.PasteFlag &= ~CPF_CONFIRM_CHANGEPASTE;
669 }
670 GetDlgItemTextA(IDC_CONFIRM_STRING_FILE, ts.ConfirmChangePasteStringFile, sizeof(ts.ConfirmChangePasteStringFile));
671
672 // (8)
673 GetDlgItemTextA(IDC_DELIM_LIST, ts.DelimList, sizeof(ts.DelimList));
674
675 // (9)
676 val = GetDlgItemInt(IDC_PASTEDELAY_EDIT);
677 ts.PasteDelayPerLine =
678 (val < 0) ? 0 :
679 (val > 5000) ? 5000 : val;
680
681 // (10) SelectOnActivate
682 ts.SelOnActive = (GetCheck(IDC_SELECT_ON_ACTIVATE) == BST_CHECKED);
683 }
684
685 void CCopypastePropPageDlg::OnHelp()
686 {
687 PostMessage(HVTWin, WM_USER_DLGHELP2, HlpMenuSetupAdditional, 0);
688 }
689
690 // CVisualPropPageDlg �_�C�A���O
691 class CVisualPropPageDlg : public TTCPropertyPage
692 {
693 public:
694 CVisualPropPageDlg(HINSTANCE inst);
695 virtual ~CVisualPropPageDlg();
696 private:
697 void OnInitDialog();
698 void OnOK();
699 HBRUSH OnCtlColor(HDC hDC, HWND hWnd);
700 enum { IDD = IDD_TABSHEET_VISUAL };
701 BOOL OnCommand(WPARAM wParam, LPARAM lParam);
702 void OnHScroll(UINT nSBCode, UINT nPos, HWND pScrollBar);
703 void SetupRGBbox(int index);
704 void OnHelp();
705 BOOL CheckColorChanged();
706 BOOL CheckThemeColor();
707 CTipWin* TipWin;
708 COLORREF ANSIColor[16];
709 };
710
711 CVisualPropPageDlg::CVisualPropPageDlg(HINSTANCE inst)
712 : TTCPropertyPage(inst, CVisualPropPageDlg::IDD)
713 {
714 wchar_t *UIMsg;
715 GetI18nStrWW("Tera Term", "DLG_TABSHEET_TITLE_VISUAL",
716 L"Visual", ts.UILanguageFileW, &UIMsg);
717 m_psp.pszTitle = UIMsg;
718 m_psp.dwFlags |= (PSP_USETITLE | PSP_HASHELP);
719 TipWin = new CTipWin(inst);
720 }
721
722 CVisualPropPageDlg::~CVisualPropPageDlg()
723 {
724 free((void *)m_psp.pszTitle);
725 TipWin->Destroy();
726 delete TipWin;
727 TipWin = NULL;
728 }
729
730 void CVisualPropPageDlg::SetupRGBbox(int index)
731 {
732 COLORREF Color = ANSIColor[index];
733 BYTE c;
734
735 c = GetRValue(Color);
736 SetDlgItemNum(IDC_COLOR_RED, c);
737
738 c = GetGValue(Color);
739 SetDlgItemNum(IDC_COLOR_GREEN, c);
740
741 c = GetBValue(Color);
742 SetDlgItemNum(IDC_COLOR_BLUE, c);
743 }
744
745 // CVisualPropPageDlg ���b�Z�[�W �n���h��
746
747 void CVisualPropPageDlg::OnInitDialog()
748 {
749 TTCPropertyPage::OnInitDialog();
750
751 static const DlgTextInfo TextInfos[] = {
752 { IDC_ALPHABLEND, "DLG_TAB_VISUAL_ALPHA" },
753 { IDC_ALPHA_BLEND_ACTIVE_LABEL, "DLG_TAB_VISUAL_ALPHA_ACTIVE" },
754 { IDC_ALPHA_BLEND_INACTIVE_LABEL, "DLG_TAB_VISUAL_ALPHA_INACTIVE" },
755 { IDC_MOUSE, "DLG_TAB_VISUAL_MOUSE" },
756 { IDC_FONT_QUALITY_LABEL, "DLG_TAB_VISUAL_FONT_QUALITY" },
757 { IDC_ANSICOLOR, "DLG_TAB_VISUAL_ANSICOLOR" },
758 { IDC_RED, "DLG_TAB_VISUAL_RED" },
759 { IDC_GREEN, "DLG_TAB_VISUAL_GREEN" },
760 { IDC_BLUE, "DLG_TAB_VISUAL_BLUE" },
761 { IDC_CHECK_CORNERDONTROUND, "DLG_TAB_VISUAL_CORNER_DONT_ROUND" },
762 { IDC_ENABLE_ATTR_COLOR_BOLD, "DLG_TAB_VISUAL_BOLD_COLOR" }, // SGR 1
763 { IDC_ENABLE_ATTR_FONT_BOLD, "DLG_TAB_VISUAL_BOLD_FONT" },
764 { IDC_ENABLE_ATTR_COLOR_UNDERLINE, "DLG_TAB_VISUAL_UNDERLINE_COLOR" }, // SGR 4
765 { IDC_ENABLE_ATTR_FONT_UNDERLINE, "DLG_TAB_VISUAL_UNDERLINE_FONT" },
766 { IDC_ENABLE_ATTR_COLOR_BLINK, "DLG_TAB_VISUAL_BLINK" }, // SGR 5
767 { IDC_ENABLE_ATTR_COLOR_REVERSE, "DLG_TAB_VISUAL_REVERSE" }, // SGR 7
768 { IDC_ENABLE_ATTR_COLOR_URL, "DLG_TAB_VISUAL_URL_COLOR" }, // URL Attribute
769 { IDC_ENABLE_ATTR_FONT_URL, "DLG_TAB_VISUAL_URL_FONT" },
770 { IDC_ENABLE_ANSI_COLOR, "DLG_TAB_VISUAL_ANSI" },
771 { IDC_CHECK_FAST_SIZE_MOVE, "DLG_TAB_VISUAL_FAST_SIZE_MOVE" },
772 };
773 SetDlgTextsW(m_hWnd, TextInfos, _countof(TextInfos), ts.UILanguageFileW);
774
775 const static I18nTextInfo visual_font_quality[] = {
776 { "DLG_TAB_VISUAL_FONT_QUALITY_DEFAULT", L"Default" },
777 { "DLG_TAB_VISUAL_FONT_QUALITY_NONANTIALIASED", L"Non-Antialiased" },
778 { "DLG_TAB_VISUAL_FONT_QUALITY_ANTIALIASED", L"Antialiased" },
779 { "DLG_TAB_VISUAL_FONT_QUALITY_CLEARTYPE", L"ClearType" },
780 };
781 SetI18nListW("Tera Term", m_hWnd, IDC_FONT_QUALITY, visual_font_quality, _countof(visual_font_quality),
782 ts.UILanguageFileW, 0);
783
784 // (1)AlphaBlend
785
786 SetDlgItemNum(IDC_ALPHA_BLEND_ACTIVE, ts.AlphaBlendActive);
787 SendDlgItemMessage(IDC_ALPHA_BLEND_ACTIVE_TRACKBAR, TBM_SETRANGE, TRUE, MAKELPARAM(0, 255));
788 SendDlgItemMessage(IDC_ALPHA_BLEND_ACTIVE_TRACKBAR, TBM_SETPOS, TRUE, ts.AlphaBlendActive);
789
790 SetDlgItemNum(IDC_ALPHA_BLEND_INACTIVE, ts.AlphaBlendInactive);
791 SendDlgItemMessage(IDC_ALPHA_BLEND_INACTIVE_TRACKBAR, TBM_SETRANGE, TRUE, MAKELPARAM(0, 255));
792 SendDlgItemMessage(IDC_ALPHA_BLEND_INACTIVE_TRACKBAR, TBM_SETPOS, TRUE, ts.AlphaBlendInactive);
793
794 BOOL isLayeredWindowSupported = (pSetLayeredWindowAttributes != NULL);
795 EnableDlgItem(IDC_ALPHA_BLEND_ACTIVE, isLayeredWindowSupported);
796 EnableDlgItem(IDC_ALPHA_BLEND_ACTIVE_TRACKBAR, isLayeredWindowSupported);
797 EnableDlgItem(IDC_ALPHA_BLEND_INACTIVE, isLayeredWindowSupported);
798 EnableDlgItem(IDC_ALPHA_BLEND_INACTIVE_TRACKBAR, isLayeredWindowSupported);
799
800 // (2) theme file
801 {
802 const static I18nTextInfo theme_select[] = {
803 { "DLG_TAB_VISUAL_THEME_STARTUP_NO_USE", L"no use" },
804 { "DLG_TAB_VISUAL_THEME_STARTUP_FIXED_THEME", L"fixed theme file" },
805 { "DLG_TAB_VISUAL_THEME_STARTUP_RANDOM_THEME", L"random theme file" },
806 };
807
808 int sel = ts.EtermLookfeel.BGEnable;
809 if (sel < 0) sel = 0;
810 if (sel > 2) sel = 2;
811 SetI18nListW("Tera Term", m_hWnd, IDC_THEME_FILE, theme_select, _countof(theme_select),
812 ts.UILanguageFileW, sel);
813 BOOL enable = (sel == 1) ? TRUE : FALSE;
814 EnableDlgItem(IDC_THEME_EDIT, enable);
815 EnableDlgItem(IDC_THEME_BUTTON, enable);
816
817 SetDlgItemTextW(IDC_THEME_EDIT, ts.EtermLookfeel.BGThemeFileW);
818 }
819
820 // (3)Mouse cursor type
821 int sel = 0;
822 for (int i = 0 ; MouseCursor[i].name ; i++) {
823 const char *name = MouseCursor[i].name;
824 SendDlgItemMessageA(IDC_MOUSE_CURSOR, CB_ADDSTRING, i, (LPARAM)name);
825 if (_stricmp(name, ts.MouseCursorName) == 0) {
826 sel = i;
827 }
828 }
829 SetCurSel(IDC_MOUSE_CURSOR, sel);
830
831 // (4)Font quality
832 switch (ts.FontQuality) {
833 case DEFAULT_QUALITY:
834 SetCurSel(IDC_FONT_QUALITY, 0);
835 break;
836 case NONANTIALIASED_QUALITY:
837 SetCurSel(IDC_FONT_QUALITY, 1);
838 break;
839 case ANTIALIASED_QUALITY:
840 SetCurSel(IDC_FONT_QUALITY, 2);
841 break;
842 default: // CLEARTYPE_QUALITY
843 SetCurSel(IDC_FONT_QUALITY, 3);
844 break;
845 }
846
847 // (5)ANSI color
848 for (int i = 0; i < 16; i++) {
849 ANSIColor[i] = ts.ANSIColor[i];
850 }
851 for (int i = 0 ; i < 16 ; i++) {
852 char buf[4];
853 _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%d", i);
854 SendDlgItemMessageA(IDC_ANSI_COLOR, LB_INSERTSTRING, i, (LPARAM)buf);
855 }
856 SetupRGBbox(0);
857 SendDlgItemMessage(IDC_ANSI_COLOR, LB_SETCURSEL, 0, 0);
858 ::InvalidateRect(GetDlgItem(IDC_SAMPLE_COLOR), NULL, TRUE);
859
860 // (6)Bold Attr Color
861 SetCheck(IDC_ENABLE_ATTR_COLOR_BOLD, (ts.ColorFlag&CF_BOLDCOLOR) != 0);
862 SetCheck(IDC_ENABLE_ATTR_FONT_BOLD, (ts.FontFlag&FF_BOLD) != 0);
863
864 // (7)Blink Attr Color
865 SetCheck(IDC_ENABLE_ATTR_COLOR_BLINK, (ts.ColorFlag&CF_BLINKCOLOR) != 0);
866
867 // (8)Reverse Attr Color
868 SetCheck(IDC_ENABLE_ATTR_COLOR_REVERSE, (ts.ColorFlag&CF_REVERSECOLOR) != 0);
869
870 // Underline Attr
871 SetCheck(IDC_ENABLE_ATTR_COLOR_UNDERLINE, (ts.ColorFlag&CF_UNDERLINE) != 0);
872 SetCheck(IDC_ENABLE_ATTR_FONT_UNDERLINE, (ts.FontFlag&FF_UNDERLINE) != 0);
873
874 // URL Underline Attr
875 SetCheck(IDC_ENABLE_ATTR_COLOR_URL, (ts.ColorFlag&CF_URLCOLOR) != 0);
876 SetCheck(IDC_ENABLE_ATTR_FONT_URL, (ts.FontFlag&FF_URLUNDERLINE) != 0);
877
878 // Color
879 SetCheck(IDC_ENABLE_ANSI_COLOR, (ts.ColorFlag&CF_ANSICOLOR) != 0);
880
881 SetCheck(IDC_CHECK_FAST_SIZE_MOVE, ts.EtermLookfeel.BGFastSizeMove != 0);
882 SetCheck(IDC_CHECK_FLICKER_LESS_MOVE, ts.EtermLookfeel.BGNoCopyBits != 0);
883
884 // �E�B���h�E���p������������
885 SetCheck(IDC_CHECK_CORNERDONTROUND, (ts.WindowCornerDontround) != 0);
886 {
887 DWM_WINDOW_CORNER_PREFERENCE preference;
888 if (pDwmGetWindowAttribute == NULL ||
889 pDwmGetWindowAttribute(HVTWin, DWMWA_WINDOW_CORNER_PREFERENCE, &preference, sizeof(preference)) != S_OK) {
890 // �E�B���h�E���p�������������������������������� disable ������
891 // DwmGetWindowAttribute() API ������ or
892 // DwmGetWindowAttribute(DWMWA_WINDOW_CORNER_PREFERENCE) �� S_OK ����������
893 EnableDlgItem(IDC_CHECK_CORNERDONTROUND, FALSE);
894 }
895 }
896
897 SetCheck(IDC_THEME_ENABLE, ThemeGetEnable() ? BST_CHECKED : BST_UNCHECKED);
898
899 SetDlgItemTextW(IDC_SPIPATH_EDIT, ts.EtermLookfeel.BGSPIPathW);
900
901 // �_�C�A���O���t�H�[�J�X��������
902 ::SetFocus(GetDlgItem(IDC_ALPHA_BLEND_ACTIVE));
903
904 // �c�[���`�b�v����
905 TipWin->Create(m_hWnd);
906 }
907
908 void CVisualPropPageDlg::OnHScroll(UINT nSBCode, UINT nPos, HWND pScrollBar)
909 {
910 int pos;
911 if ( pScrollBar == GetDlgItem(IDC_ALPHA_BLEND_ACTIVE_TRACKBAR) ) {
912 switch (nSBCode) {
913 case SB_TOP:
914 case SB_BOTTOM:
915 case SB_LINEDOWN:
916 case SB_LINEUP:
917 case SB_PAGEDOWN:
918 case SB_PAGEUP:
919 case SB_THUMBPOSITION:
920 case SB_THUMBTRACK:
921 pos = (int)SendDlgItemMessage(IDC_ALPHA_BLEND_ACTIVE_TRACKBAR, TBM_GETPOS, NULL, NULL);
922 SetDlgItemNum(IDC_ALPHA_BLEND_ACTIVE, pos);
923 break;
924 case SB_ENDSCROLL:
925 default:
926 return;
927 }
928 }
929 else if ( pScrollBar == GetDlgItem(IDC_ALPHA_BLEND_INACTIVE_TRACKBAR) ) {
930 switch (nSBCode) {
931 case SB_TOP:
932 case SB_BOTTOM:
933 case SB_LINEDOWN:
934 case SB_LINEUP:
935 case SB_PAGEDOWN:
936 case SB_PAGEUP:
937 case SB_THUMBPOSITION:
938 case SB_THUMBTRACK:
939 pos = (int)SendDlgItemMessage(IDC_ALPHA_BLEND_INACTIVE_TRACKBAR, TBM_GETPOS, NULL, NULL);
940 SetDlgItemNum(IDC_ALPHA_BLEND_INACTIVE, pos);
941 break;
942 case SB_ENDSCROLL:
943 default:
944 return;
945 }
946 }
947 }
948
949 static void OpacityTooltip(CTipWin* tip, HWND hDlg, int trackbar, int pos, const wchar_t *UILanguageFile)
950 {
951 wchar_t *uimsg;
952 GetI18nStrWW("Tera Term", "TOOLTIP_TITLEBAR_OPACITY", L"Opacity %.1f %%", UILanguageFile, &uimsg);
953 wchar_t *tipbuf;
954 aswprintf(&tipbuf, uimsg, (pos / 255.0) * 100);
955 RECT rc;
956 ::GetWindowRect(::GetDlgItem(hDlg, trackbar), &rc);
957 tip->SetText(tipbuf);
958 tip->SetPos(rc.right, rc.bottom);
959 tip->SetHideTimer(1000);
960 if (! tip->IsVisible()) {
961 tip->SetVisible(TRUE);
962 }
963 free(tipbuf);
964 free(uimsg);
965 }
966
967 BOOL CVisualPropPageDlg::OnCommand(WPARAM wParam, LPARAM lParam)
968 {
969 switch (wParam) {
970 case IDC_THEME_EDITOR_BUTTON | (BN_CLICKED << 16): {
971 ThemeDialog(m_hInst, m_hWnd, &cv);
972 break;
973 }
974 case IDC_THEME_FILE | (CBN_SELCHANGE << 16): {
975 int r = GetCurSel(IDC_THEME_FILE);
976 // �����������A�t�@�C��������������������������
977 BOOL enable = (r == 1) ? TRUE : FALSE;
978 EnableDlgItem(IDC_THEME_EDIT, enable);
979 EnableDlgItem(IDC_THEME_BUTTON, enable);
980 break;
981 }
982 case IDC_THEME_BUTTON | (BN_CLICKED << 16): {
983 // �e�[�}�t�@�C�����I������
984 wchar_t *theme_file;
985 hGetDlgItemTextW(m_hWnd, IDC_THEME_EDIT, &theme_file);
986
987 wchar_t *theme_dir;
988 aswprintf(&theme_dir, L"%s\\theme", ts.HomeDirW);
989
990 TTOPENFILENAMEW ofn = {};
991 ofn.hwndOwner = m_hWnd;
992 ofn.lpstrFilter = L"Theme Files(*.ini)\0*.ini\0All Files(*.*)\0*.*\0";
993 ofn.lpstrTitle = L"select theme file";
994 ofn.lpstrFile = theme_file;
995 ofn.lpstrInitialDir = theme_dir;
996 ofn.Flags = OFN_FILEMUSTEXIST | OFN_HIDEREADONLY;
997 wchar_t *filename;
998 BOOL ok = TTGetOpenFileNameW(&ofn, &filename);
999 if (ok) {
1000 SetDlgItemTextW(IDC_THEME_EDIT, filename);
1001 free(filename);
1002 }
1003 free(theme_dir);
1004 free(theme_file);
1005 return TRUE;
1006 }
1007
1008 case IDC_ANSI_COLOR | (LBN_SELCHANGE << 16): {
1009 int sel = (int)SendDlgItemMessage(IDC_ANSI_COLOR, LB_GETCURSEL, 0, 0);
1010 if (sel != -1) {
1011 SetupRGBbox(sel);
1012 ::InvalidateRect(GetDlgItem(IDC_SAMPLE_COLOR), NULL, TRUE);
1013 }
1014 return TRUE;
1015 }
1016
1017 case IDC_COLOR_RED | (EN_CHANGE << 16) :
1018 case IDC_COLOR_GREEN | (EN_CHANGE << 16) :
1019 case IDC_COLOR_BLUE | (EN_CHANGE << 16) :
1020 {
1021 int r, g, b;
1022 int sel;
1023
1024 sel = GetCurSel(IDC_ANSI_COLOR);
1025 if (sel < 0 || sel > _countof(ANSIColor)-1) {
1026 return TRUE;
1027 }
1028
1029 r = GetDlgItemInt(IDC_COLOR_RED);
1030 if (r < 0) {
1031 r = 0;
1032 SetDlgItemNum(IDC_COLOR_RED, r);
1033 }
1034 else if (r > 255) {
1035 r = 255;
1036 SetDlgItemNum(IDC_COLOR_RED, r);
1037 }
1038
1039 g = GetDlgItemInt(IDC_COLOR_GREEN);
1040 if (g < 0) {
1041 g = 0;
1042 SetDlgItemNum(IDC_COLOR_GREEN, g);
1043 }
1044 else if (g > 255) {
1045 g = 255;
1046 SetDlgItemNum(IDC_COLOR_GREEN, g);
1047 }
1048
1049 b = GetDlgItemInt(IDC_COLOR_BLUE);
1050 if (b < 0) {
1051 b = 0;
1052 SetDlgItemNum(IDC_COLOR_BLUE, b);
1053 }
1054 else if (b > 255) {
1055 b = 255;
1056 SetDlgItemNum(IDC_COLOR_BLUE, b);
1057 }
1058
1059 ANSIColor[sel] = RGB(r, g, b);
1060
1061 ::InvalidateRect(GetDlgItem(IDC_SAMPLE_COLOR), NULL, TRUE);
1062 }
1063 return TRUE;
1064 case IDC_ALPHA_BLEND_ACTIVE | (EN_CHANGE << 16):
1065 {
1066 int pos;
1067 pos = GetDlgItemInt(IDC_ALPHA_BLEND_ACTIVE);
1068 if(pos < 0) {
1069 pos = 0;
1070 SetDlgItemNum(IDC_ALPHA_BLEND_ACTIVE, pos);
1071 }
1072 else if(pos > 255) {
1073 pos = 255;
1074 SetDlgItemNum(IDC_ALPHA_BLEND_ACTIVE, pos);
1075 }
1076 SendDlgItemMessage(IDC_ALPHA_BLEND_ACTIVE_TRACKBAR, TBM_SETPOS, TRUE, pos);
1077 OpacityTooltip(TipWin, m_hWnd, IDC_ALPHA_BLEND_ACTIVE, pos, ts.UILanguageFileW);
1078 return TRUE;
1079 }
1080 case IDC_ALPHA_BLEND_INACTIVE | (EN_CHANGE << 16):
1081 {
1082 int pos;
1083 pos = GetDlgItemInt(IDC_ALPHA_BLEND_INACTIVE);
1084 if(pos < 0) {
1085 pos = 0;
1086 SetDlgItemNum(IDC_ALPHA_BLEND_INACTIVE, pos);
1087 }
1088 else if(pos > 255) {
1089 pos = 255;
1090 SetDlgItemNum(IDC_ALPHA_BLEND_INACTIVE, pos);
1091 }
1092 SendDlgItemMessage(IDC_ALPHA_BLEND_INACTIVE_TRACKBAR, TBM_SETPOS, TRUE, pos);
1093 OpacityTooltip(TipWin, m_hWnd, IDC_ALPHA_BLEND_INACTIVE, pos, ts.UILanguageFileW);
1094 return TRUE;
1095 }
1096 case IDC_SPIPATH_BUTTON | (BN_CLICKED << 16): {
1097 wchar_t *def;
1098 hGetDlgItemTextW(m_hWnd, IDC_SPIPATH_EDIT, &def);
1099 if (GetFileAttributesW(def) == INVALID_FILE_ATTRIBUTES) {
1100 // �t�H���_������������(�����r��?,TT4�������s?)
1101 static const TTMessageBoxInfoW info = {
1102 "Tera Term",
1103 "MSG_TT_NOTICE", L"Tera Term: Notice",
1104 NULL, L"'%s' not exist\nUse home folder",
1105 MB_OK };
1106 TTMessageBoxW(m_hWnd, &info, ts.UILanguageFileW, def);
1107 free(def);
1108 def = _wcsdup(ts.HomeDirW);
1109 }
1110
1111 TTBROWSEINFOW bi = {};
1112 bi.hwndOwner = m_hWnd;
1113 bi.lpszTitle = L"Select Susie Plugin path";
1114 bi.ulFlags = BIF_RETURNONLYFSDIRS | BIF_EDITBOX | BIF_NEWDIALOGSTYLE;
1115
1116 wchar_t *folder;
1117 if (TTSHBrowseForFolderW(&bi, def, &folder)) {
1118 SetDlgItemTextW(IDC_SPIPATH_EDIT, folder);
1119 free(folder);
1120 }
1121 free(def);
1122 break;
1123 }
1124 }
1125
1126 return TTCPropertyPage::OnCommand(wParam, lParam);
1127 }
1128
1129 HBRUSH CVisualPropPageDlg::OnCtlColor(HDC hDC, HWND hWnd)
1130 {
1131 if ( hWnd == GetDlgItem(IDC_SAMPLE_COLOR) ) {
1132 BYTE r = (BYTE)GetDlgItemInt(IDC_COLOR_RED);
1133 BYTE g = (BYTE)GetDlgItemInt(IDC_COLOR_GREEN);
1134 BYTE b = (BYTE)GetDlgItemInt(IDC_COLOR_BLUE);
1135 SetBkMode(hDC, TRANSPARENT);
1136 SetTextColor(hDC, RGB(r, g, b) );
1137
1138 return (HBRUSH)GetStockObject(NULL_BRUSH);
1139 }
1140 return TTCPropertyPage::OnCtlColor(hDC, hWnd);
1141 }
1142
1143 /**
1144 * �F�����������X�������`�F�b�N����
1145 * @retval TRUE ���X����
1146 * @retval FALSE ���X����������
1147 */
1148 BOOL CVisualPropPageDlg::CheckColorChanged()
1149 {
1150 for (int i = 0; i < 16; i++) {
1151 if (ts.ANSIColor[i] != ANSIColor[i]) {
1152 return TRUE;
1153 }
1154 }
1155 return FALSE;
1156 }
1157
1158 /**
1159 * �e�[�}�J���[�����������������`�F�b�N����
1160 * @retval TRUE ��������������
1161 * @retval FALSE ����������������
1162 */
1163 BOOL CVisualPropPageDlg::CheckThemeColor()
1164 {
1165 TColorTheme def; // default color (=ts.ANSIColor[])
1166 ThemeGetColorDefault(&def);
1167 TColorTheme disp; // ���\�������������F
1168 ThemeGetColor(&disp);
1169 for (int i = 0; i < 16; i++) {
1170 if (disp.ansicolor.color[i] != def.ansicolor.color[i]) {
1171 return TRUE;
1172 }
1173 }
1174 return FALSE;
1175 }
1176
1177 void CVisualPropPageDlg::OnOK()
1178 {
1179 int sel;
1180 int i;
1181
1182 // (1)
1183 i = GetDlgItemInt(IDC_ALPHA_BLEND_ACTIVE);
1184 ts.AlphaBlendActive =
1185 (i < 0) ? 0 :
1186 (BYTE)((i > 255) ? 255 : i);
1187 i = GetDlgItemInt(IDC_ALPHA_BLEND_INACTIVE);
1188 ts.AlphaBlendInactive =
1189 (i < 0) ? 0 :
1190 (BYTE)((i > 255) ? 255 : i);
1191
1192 // (2) �e�[�}�t�@�C���I��
1193 {
1194 int r = GetCurSel(IDC_THEME_FILE);
1195 switch (r) {
1196 default:
1197 assert(FALSE);
1198 // fall through
1199 case 0:
1200 ts.EtermLookfeel.BGEnable = 0;
1201 break;
1202 case 1: {
1203 // �e�[�}�t�@�C���w��
1204 ts.EtermLookfeel.BGEnable = 1;
1205
1206 wchar_t* theme_file;
1207 hGetDlgItemTextW(m_hWnd, IDC_THEME_EDIT, &theme_file);
1208
1209 if (ts.EtermLookfeel.BGThemeFileW != NULL) {
1210 free(ts.EtermLookfeel.BGThemeFileW);
1211 }
1212 ts.EtermLookfeel.BGThemeFileW = theme_file;
1213 break;
1214 }
1215 case 2: {
1216 // �����_���e�[�}
1217 ts.EtermLookfeel.BGEnable = 2;
1218 if (ts.EtermLookfeel.BGThemeFileW != NULL) {
1219 free(ts.EtermLookfeel.BGThemeFileW);
1220 }
1221 ts.EtermLookfeel.BGThemeFileW = NULL;
1222 break;
1223 }
1224 }
1225 }
1226
1227
1228 // (3)
1229 sel = GetCurSel(IDC_MOUSE_CURSOR);
1230 if (sel >= 0 && sel < MOUSE_CURSOR_MAX) {
1231 strncpy_s(ts.MouseCursorName, sizeof(ts.MouseCursorName), MouseCursor[sel].name, _TRUNCATE);
1232 }
1233
1234 // (4)Font quality
1235 switch (GetCurSel(IDC_FONT_QUALITY)) {
1236 case 0:
1237 ts.FontQuality = DEFAULT_QUALITY;
1238 break;
1239 case 1:
1240 ts.FontQuality = NONANTIALIASED_QUALITY;
1241 break;
1242 case 2:
1243 ts.FontQuality = ANTIALIASED_QUALITY;
1244 break;
1245 case 3:
1246 ts.FontQuality = CLEARTYPE_QUALITY;
1247 break;
1248 default: // Invalid value.
1249 break;
1250 }
1251
1252 // (6) Attr Bold Color
1253 if (((ts.ColorFlag & CF_BOLDCOLOR) != 0) != GetCheck(IDC_ENABLE_ATTR_COLOR_BOLD)) {
1254 ts.ColorFlag ^= CF_BOLDCOLOR;
1255 }
1256 if (((ts.FontFlag & FF_BOLD) != 0) != GetCheck(IDC_ENABLE_ATTR_FONT_BOLD)) {
1257 ts.FontFlag ^= FF_BOLD;
1258 }
1259
1260 // (7) Attr Blink Color
1261 if (((ts.ColorFlag & CF_BLINKCOLOR) != 0) != GetCheck(IDC_ENABLE_ATTR_COLOR_BLINK)) {
1262 ts.ColorFlag ^= CF_BLINKCOLOR;
1263 }
1264
1265 // (8) Attr Reverse Color
1266 if (((ts.ColorFlag & CF_REVERSECOLOR) != 0) != GetCheck(IDC_ENABLE_ATTR_COLOR_REVERSE)) {
1267 ts.ColorFlag ^= CF_REVERSECOLOR;
1268 }
1269
1270 // Underline Attr
1271 if (((ts.FontFlag & FF_UNDERLINE) != 0) != GetCheck(IDC_ENABLE_ATTR_FONT_UNDERLINE)) {
1272 ts.FontFlag ^= FF_UNDERLINE;
1273 }
1274 if (((ts.ColorFlag & CF_UNDERLINE) != 0) != GetCheck(IDC_ENABLE_ATTR_COLOR_UNDERLINE)) {
1275 ts.ColorFlag ^= CF_UNDERLINE;
1276 }
1277
1278 // URL Underline Attr
1279 if (((ts.FontFlag & FF_URLUNDERLINE) != 0) != GetCheck(IDC_ENABLE_ATTR_FONT_URL)) {
1280 ts.FontFlag ^= FF_URLUNDERLINE;
1281 }
1282 if (((ts.ColorFlag & CF_URLCOLOR) != 0) != GetCheck(IDC_ENABLE_ATTR_COLOR_URL)) {
1283 ts.ColorFlag ^= CF_URLCOLOR;
1284 }
1285
1286 // Color
1287 if (((ts.ColorFlag & CF_ANSICOLOR) != 0) != GetCheck(IDC_ENABLE_ANSI_COLOR)) {
1288 ts.ColorFlag ^= CF_ANSICOLOR;
1289 }
1290
1291 ts.EtermLookfeel.BGFastSizeMove = GetCheck(IDC_CHECK_FAST_SIZE_MOVE);
1292 ts.EtermLookfeel.BGNoCopyBits = GetCheck(IDC_CHECK_FLICKER_LESS_MOVE);
1293
1294 // �E�B���h�E���p������������
1295 if (ts.WindowCornerDontround != GetCheck(IDC_CHECK_CORNERDONTROUND)) {
1296 ts.WindowCornerDontround = GetCheck(IDC_CHECK_CORNERDONTROUND);
1297 if (pDwmSetWindowAttribute != NULL) {
1298 DWM_WINDOW_CORNER_PREFERENCE preference = ts.WindowCornerDontround ? DWMWCP_DONOTROUND : DWMWCP_DEFAULT;
1299 pDwmSetWindowAttribute(HVTWin, DWMWA_WINDOW_CORNER_PREFERENCE, &preference, sizeof(preference));
1300 }
1301 }
1302
1303 // ANSI Color
1304 if (CheckColorChanged()) {
1305 // �F�����X���s������
1306 bool set_color = TRUE;
1307
1308 // �J���[�e�[�}���g�����F�����X����������?
1309 if (CheckThemeColor()) {
1310 static const TTMessageBoxInfoW info = {
1311 "Tera Term",
1312 "MSG_TT_NOTICE", L"Tera Term: Notice",
1313 NULL, L"Color settings have been changed.\nDo you want to display this?",
1314 MB_ICONQUESTION | MB_YESNO };
1315 int r = TTMessageBoxW(m_hWnd, &info, ts.UILanguageFileW);
1316 if (r == IDNO) {
1317 set_color = FALSE;
1318 }
1319 }
1320
1321 // �F������(�f�t�H���g�F)�����f
1322 for (i = 0; i < 16; i++) {
1323 ts.ANSIColor[i] = ANSIColor[i];
1324 }
1325
1326 // �����������F���\�������f
1327 if (set_color) {
1328 TColorTheme color;
1329 // �f�t�H���g�F����������
1330 ThemeGetColorDefault(&color);
1331 ThemeSetColor(&color);
1332 }
1333 }
1334
1335 if ((GetCheck(IDC_THEME_ENABLE) == BST_CHECKED) && ThemeGetEnable() == FALSE) {
1336 // �e�[�}��enable������
1337 ThemeSetEnable(TRUE);
1338 }
1339 else if ((GetCheck(IDC_THEME_ENABLE) == BST_UNCHECKED) && ThemeGetEnable() == TRUE) {
1340 // �e�[�}��disable������
1341 ThemeSetEnable(FALSE);
1342 }
1343
1344 wchar_t *spi_path;
1345 hGetDlgItemTextW(m_hWnd, IDC_SPIPATH_EDIT, &spi_path);
1346 free(ts.EtermLookfeel.BGSPIPathW);
1347 ts.EtermLookfeel.BGSPIPathW = spi_path;
1348 }
1349
1350 void CVisualPropPageDlg::OnHelp()
1351 {
1352 PostMessage(HVTWin, WM_USER_DLGHELP2, HlpMenuSetupAdditionalVisual, 0);
1353 }
1354
1355 // CLogPropPageDlg �_�C�A���O
1356
1357 CLogPropPageDlg::CLogPropPageDlg(HINSTANCE inst)
1358 : TTCPropertyPage(inst, CLogPropPageDlg::IDD)
1359 {
1360 wchar_t *UIMsg;
1361 GetI18nStrWW("Tera Term", "DLG_TABSHEET_TITLE_Log",
1362 L"Log", ts.UILanguageFileW, &UIMsg);
1363 m_psp.pszTitle = UIMsg;
1364 m_psp.dwFlags |= (PSP_USETITLE | PSP_HASHELP);
1365 }
1366
1367 CLogPropPageDlg::~CLogPropPageDlg()
1368 {
1369 free((void *)m_psp.pszTitle);
1370 }
1371
1372 // CLogPropPageDlg ���b�Z�[�W �n���h��
1373
1374 #define LOG_ROTATE_SIZETYPE_NUM 3
1375 static const char *LogRotateSizeType[] = {
1376 "Byte", "KB", "MB"
1377 };
1378
1379 static const char *GetLogRotateSizeType(int val)
1380 {
1381 if (val >= LOG_ROTATE_SIZETYPE_NUM)
1382 val = 0;
1383
1384 return LogRotateSizeType[val];
1385 }
1386
1387 void CLogPropPageDlg::OnInitDialog()
1388 {
1389 TTCPropertyPage::OnInitDialog();
1390
1391 static const DlgTextInfo TextInfos[] = {
1392 { IDC_VIEWLOG_LABEL, "DLG_TAB_LOG_EDITOR" },
1393 { IDC_DEFAULTNAME_LABEL, "DLG_TAB_LOG_FILENAME" },
1394 { IDC_DEFAULTPATH_LABEL, "DLG_TAB_LOG_FILEPATH" },
1395 { IDC_AUTOSTART, "DLG_TAB_LOG_AUTOSTART" },
1396 // Log rotate
1397 { IDC_LOG_ROTATE, "DLG_TAB_LOG_ROTATE" },
1398 { IDC_ROTATE_SIZE_TEXT, "DLG_TAB_LOG_ROTATE_SIZE_TEXT" },
1399 { IDC_ROTATE_STEP_TEXT, "DLG_TAB_LOG_ROTATESTEP" },
1400 // Log options
1401 // FIXME: ���b�Z�[�W�J�^���O�����������O�I�v�V���������������p�������A�A�N�Z�����[�^�L�[���d�������������������B
1402 { IDC_LOG_OPTION_GROUP, "DLG_FOPT" },
1403 { IDC_OPT_BINARY, "DLG_FOPT_BINARY" },
1404 { IDC_OPT_APPEND, "DLG_FOPT_APPEND" },
1405 { IDC_OPT_PLAINTEXT, "DLG_FOPT_PLAIN" },
1406 { IDC_OPT_HIDEDLG, "DLG_FOPT_HIDEDIALOG" },
1407 { IDC_OPT_INCBUF, "DLG_FOPT_ALLBUFFINFIRST" },
1408 { IDC_OPT_TIMESTAMP, "DLG_FOPT_TIMESTAMP" },
1409 };
1410 SetDlgTextsW(m_hWnd, TextInfos, _countof(TextInfos), ts.UILanguageFileW);
1411
1412 const static I18nTextInfo fopt_timestamp[] = {
1413 { "DLG_FOPT_TIMESTAMP_LOCAL", L"Local Time" },
1414 { "DLG_FOPT_TIMESTAMP_UTC", L"UTC" },
1415 { "DLG_FOPT_TIMESTAMP_ELAPSED_LOGGING", L"Elapsed Time (Logging)" },
1416 { "DLG_FOPT_TIMESTAMP_ELAPSED_CONNECTION", L"Elapsed Time (Connection)" },
1417 };
1418 SetI18nListW("Tera Term", m_hWnd, IDC_OPT_TIMESTAMP_TYPE, fopt_timestamp, _countof(fopt_timestamp),
1419 ts.UILanguageFileW, 0);
1420
1421 // Viewlog Editor path (2005.1.29 yutaka)
1422 SetDlgItemTextA(IDC_VIEWLOG_EDITOR, ts.ViewlogEditor);
1423
1424 // Log Default File Name (2006.8.28 maya)
1425 SetDlgItemTextA(IDC_DEFAULTNAME_EDITOR, ts.LogDefaultName);
1426
1427 // Log Default File Path (2007.5.30 maya)
1428 SetDlgItemTextW(IDC_DEFAULTPATH_EDITOR, ts.LogDefaultPathW);
1429
1430 /* Auto start logging (2007.5.31 maya) */
1431 SetCheck(IDC_AUTOSTART, ts.LogAutoStart);
1432
1433 // Log rotate
1434 SetCheck(IDC_LOG_ROTATE, ts.LogRotate != ROTATE_NONE);
1435
1436 for (int i = 0 ; i < LOG_ROTATE_SIZETYPE_NUM ; i++) {
1437 SendDlgItemMessageA(IDC_ROTATE_SIZE_TYPE, CB_ADDSTRING, 0, (LPARAM)LogRotateSizeType[i]);
1438 }
1439 int TmpLogRotateSize = ts.LogRotateSize;
1440 for (int i = 0 ; i < ts.LogRotateSizeType ; i++)
1441 TmpLogRotateSize /= 1024;
1442 SetDlgItemInt(IDC_ROTATE_SIZE, TmpLogRotateSize, FALSE);
1443 SendDlgItemMessageA(IDC_ROTATE_SIZE_TYPE, CB_SELECTSTRING, -1, (LPARAM)GetLogRotateSizeType(ts.LogRotateSizeType));
1444 SetDlgItemInt(IDC_ROTATE_STEP, ts.LogRotateStep, FALSE);
1445 if (ts.LogRotate == ROTATE_NONE) {
1446 EnableDlgItem(IDC_ROTATE_SIZE_TEXT, FALSE);
1447 EnableDlgItem(IDC_ROTATE_SIZE, FALSE);
1448 EnableDlgItem(IDC_ROTATE_SIZE_TYPE, FALSE);
1449 EnableDlgItem(IDC_ROTATE_STEP_TEXT, FALSE);
1450 EnableDlgItem(IDC_ROTATE_STEP, FALSE);
1451 } else {
1452 EnableDlgItem(IDC_ROTATE_SIZE_TEXT, TRUE);
1453 EnableDlgItem(IDC_ROTATE_SIZE, TRUE);
1454 EnableDlgItem(IDC_ROTATE_SIZE_TYPE, TRUE);
1455 EnableDlgItem(IDC_ROTATE_STEP_TEXT, TRUE);
1456 EnableDlgItem(IDC_ROTATE_STEP, TRUE);
1457 }
1458
1459 // Log options
1460 SetCheck(IDC_OPT_BINARY, ts.LogBinary != 0);
1461 if (ts.LogBinary) {
1462 EnableDlgItem(IDC_OPT_PLAINTEXT, FALSE);
1463 EnableDlgItem(IDC_OPT_TIMESTAMP, FALSE);
1464 } else {
1465 EnableDlgItem(IDC_OPT_PLAINTEXT, TRUE);
1466 EnableDlgItem(IDC_OPT_TIMESTAMP, TRUE);
1467 }
1468 SetCheck(IDC_OPT_APPEND, ts.Append != 0);
1469 SetCheck(IDC_OPT_PLAINTEXT, ts.LogTypePlainText != 0);
1470 SetCheck(IDC_OPT_HIDEDLG, ts.LogHideDialog != 0);
1471 SetCheck(IDC_OPT_INCBUF, ts.LogAllBuffIncludedInFirst != 0);
1472 SetCheck(IDC_OPT_TIMESTAMP, ts.LogTimestamp != 0);
1473
1474 SetCurSel(IDC_OPT_TIMESTAMP_TYPE, ts.LogTimestampType);
1475 if (ts.LogBinary || !ts.LogTimestamp) {
1476 EnableDlgItem(IDC_OPT_TIMESTAMP_TYPE, FALSE);
1477 }
1478 else {
1479 EnableDlgItem(IDC_OPT_TIMESTAMP_TYPE, TRUE);
1480 }
1481 /*
1482 switch (ts.LogTimestampType) {
1483 case CSF_CBRW:
1484 cmb->SetCurSel(3);
1485 break;
1486 case CSF_CBREAD:
1487 cmb->SetCurSel(2);
1488 break;
1489 case CSF_CBWRITE:
1490 cmb->SetCurSel(1);
1491 break;
1492 default: // off
1493 cmb->SetCurSel(0);
1494 break;
1495 }
1496 */
1497
1498 // �_�C�A���O���t�H�[�J�X��������
1499 ::SetFocus(::GetDlgItem(GetSafeHwnd(), IDC_VIEWLOG_EDITOR));
1500 }
1501
1502 BOOL CLogPropPageDlg::OnCommand(WPARAM wParam, LPARAM lParam)
1503 {
1504 switch (wParam) {
1505 case IDC_VIEWLOG_PATH | (BN_CLICKED << 16):
1506 {
1507 wchar_t *editor;
1508 hGetDlgItemTextW(m_hWnd, IDC_VIEWLOG_EDITOR, &editor);
1509
1510 TTOPENFILENAMEW ofn = {};
1511 ofn.hwndOwner = m_hWnd;
1512 ofn.lpstrFilter = TTGetLangStrW("Tera Term", "FILEDLG_SELECT_LOGVIEW_APP_FILTER", L"exe(*.exe)\\0*.exe\\0all(*.*)\\0*.*\\0\\0", ts.UILanguageFile);
1513 ofn.lpstrFile = editor;
1514 ofn.lpstrTitle = TTGetLangStrW("Tera Term", "FILEDLG_SELECT_LOGVIEW_APP_TITLE", L"Choose a executing file with launching logging file", ts.UILanguageFile);
1515 ofn.Flags = OFN_FILEMUSTEXIST | OFN_HIDEREADONLY;
1516 wchar_t *filew;
1517 BOOL ok = TTGetOpenFileNameW(&ofn, &filew);
1518 if (ok) {
1519 SetDlgItemTextW(IDC_VIEWLOG_EDITOR, filew);
1520 free(filew);
1521 }
1522 free((void *)ofn.lpstrFilter);
1523 free((void *)ofn.lpstrTitle);
1524 free(editor);
1525 }
1526 return TRUE;
1527
1528 case IDC_DEFAULTPATH_PUSH | (BN_CLICKED << 16):
1529 // ���O�f�B���N�g�����I���_�C�A���O
1530 {
1531 wchar_t *title = TTGetLangStrW("Tera Term", "FILEDLG_SELECT_LOGDIR_TITLE", L"Select log folder", ts.UILanguageFile);
1532 wchar_t *default_path;
1533 hGetDlgItemTextW(m_hWnd, IDC_DEFAULTPATH_EDITOR, &default_path);
1534 if (default_path[0] == 0) {
1535 free(default_path);
1536 default_path = _wcsdup(ts.LogDirW);
1537 }
1538 wchar_t *new_path;
1539 if (doSelectFolderW(GetSafeHwnd(), default_path, title, &new_path)) {
1540 SetDlgItemTextW(IDC_DEFAULTPATH_EDITOR, new_path);
1541 free(new_path);
1542 }
1543 free(default_path);
1544 free(title);
1545 }
1546
1547 return TRUE;
1548
1549 case IDC_LOG_ROTATE | (BN_CLICKED << 16):
1550 {
1551 if (GetCheck(IDC_LOG_ROTATE)) {
1552 EnableDlgItem(IDC_ROTATE_SIZE_TEXT, TRUE);
1553 EnableDlgItem(IDC_ROTATE_SIZE, TRUE);
1554 EnableDlgItem(IDC_ROTATE_SIZE_TYPE, TRUE);
1555 EnableDlgItem(IDC_ROTATE_STEP_TEXT, TRUE);
1556 EnableDlgItem(IDC_ROTATE_STEP, TRUE);
1557 } else {
1558 EnableDlgItem(IDC_ROTATE_SIZE_TEXT, FALSE);
1559 EnableDlgItem(IDC_ROTATE_SIZE, FALSE);
1560 EnableDlgItem(IDC_ROTATE_SIZE_TYPE, FALSE);
1561 EnableDlgItem(IDC_ROTATE_STEP_TEXT, FALSE);
1562 EnableDlgItem(IDC_ROTATE_STEP, FALSE);
1563 }
1564
1565 }
1566 return TRUE;
1567
1568 case IDC_OPT_BINARY | (BN_CLICKED << 16):
1569 {
1570 if (GetCheck(IDC_OPT_BINARY)) {
1571 EnableDlgItem(IDC_OPT_PLAINTEXT, FALSE);
1572 EnableDlgItem(IDC_OPT_TIMESTAMP, FALSE);
1573 EnableDlgItem(IDC_OPT_TIMESTAMP_TYPE, FALSE);
1574 } else {
1575 EnableDlgItem(IDC_OPT_PLAINTEXT, TRUE);
1576 EnableDlgItem(IDC_OPT_TIMESTAMP, TRUE);
1577
1578 if (GetCheck(IDC_OPT_TIMESTAMP)) {
1579 EnableDlgItem(IDC_OPT_TIMESTAMP_TYPE, TRUE);
1580 }
1581 }
1582 }
1583 return TRUE;
1584
1585 case IDC_OPT_TIMESTAMP | (BN_CLICKED << 16):
1586 {
1587 if (GetCheck(IDC_OPT_TIMESTAMP)) {
1588 EnableDlgItem(IDC_OPT_TIMESTAMP_TYPE, TRUE);
1589 } else {
1590 EnableDlgItem(IDC_OPT_TIMESTAMP_TYPE, FALSE);
1591 }
1592 }
1593 return TRUE;
1594 }
1595
1596 return TTCPropertyPage::OnCommand(wParam, lParam);
1597 }
1598
1599 void CLogPropPageDlg::OnOK()
1600 {
1601 char buf[80], buf2[80];
1602 time_t time_local;
1603 struct tm tm_local;
1604
1605 // Viewlog Editor path (2005.1.29 yutaka)
1606 GetDlgItemTextA(IDC_VIEWLOG_EDITOR, ts.ViewlogEditor, _countof(ts.ViewlogEditor));
1607
1608 // Log Default File Name (2006.8.28 maya)
1609 GetDlgItemTextA(IDC_DEFAULTNAME_EDITOR, buf, sizeof(buf));
1610 if (isInvalidStrftimeChar(buf)) {
1611 static const TTMessageBoxInfoW info = {
1612 "Tera Term",
1613 "MSG_ERROR", L"ERROR",
1614 "MSG_LOGFILE_INVALID_CHAR_ERROR", L"Invalid character is included in log file name.",
1615 MB_ICONEXCLAMATION };
1616 TTMessageBoxA(m_hWnd, &info, ts.UILanguageFile);
1617 return;
1618 }
1619
1620 // ��������������
1621 time(&time_local);
1622 localtime_s(&tm_local, & time_local);
1623 // ����������������
1624 if (strlen(buf) != 0 && strftime(buf2, sizeof(buf2), buf, &tm_local) == 0) {
1625 static const TTMessageBoxInfoW info = {
1626 "Tera Term",
1627 "MSG_ERROR", L"ERROR",
1628 "MSG_LOGFILE_TOOLONG_ERROR", L"The log file name is too long.",
1629 MB_ICONEXCLAMATION };
1630 TTMessageBoxA(m_hWnd, &info, ts.UILanguageFile);
1631 return;
1632 }
1633 if (isInvalidFileNameChar(buf2)) {
1634 static const TTMessageBoxInfoW info = {
1635 "Tera Term",
1636 "MSG_ERROR", L"ERROR",
1637 "MSG_LOGFILE_INVALID_CHAR_ERROR", L"Invalid character is included in log file name.",
1638 MB_ICONEXCLAMATION };
1639 TTMessageBoxA(m_hWnd, &info, ts.UILanguageFile);
1640 return;
1641 }
1642 strncpy_s(ts.LogDefaultName, sizeof(ts.LogDefaultName), buf, _TRUNCATE);
1643
1644 // Log Default File Path (2007.5.30 maya)
1645 free(ts.LogDefaultPathW);
1646 hGetDlgItemTextW(m_hWnd, IDC_DEFAULTPATH_EDITOR, &ts.LogDefaultPathW);
1647
1648 /* Auto start logging (2007.5.31 maya) */
1649 ts.LogAutoStart = GetCheck(IDC_AUTOSTART);
1650
1651 /* Log Rotate */
1652 if (GetCheck(IDC_LOG_ROTATE)) { /* on */
1653 ts.LogRotate = ROTATE_SIZE;
1654 GetDlgItemTextA(IDC_ROTATE_SIZE_TYPE, buf, _countof(buf));
1655 ts.LogRotateSizeType = 0;
1656 for (int i = 0 ; i < LOG_ROTATE_SIZETYPE_NUM ; i++) {
1657 if (strcmp(buf, LogRotateSizeType[i]) == 0) {
1658 ts.LogRotateSizeType = i;
1659 break;
1660 }
1661 }
1662 ts.LogRotateSize = GetDlgItemInt(IDC_ROTATE_SIZE);
1663 for (int i = 0 ; i < ts.LogRotateSizeType ; i++)
1664 ts.LogRotateSize *= 1024;
1665
1666 ts.LogRotateStep = GetDlgItemInt(IDC_ROTATE_STEP);
1667
1668 } else { /* off */
1669 ts.LogRotate = ROTATE_NONE;
1670 /* �c���������o�[�����}�I���������c���B*/
1671 }
1672
1673 // Log Options
1674 if (GetCheck(IDC_OPT_BINARY)) {
1675 ts.LogBinary = 1;
1676 }
1677 else {
1678 ts.LogBinary = 0;
1679 }
1680
1681 if (GetCheck(IDC_OPT_APPEND)) {
1682 ts.Append = 1;
1683 }
1684 else {
1685 ts.Append = 0;
1686 }
1687
1688 if (GetCheck(IDC_OPT_PLAINTEXT)) {
1689 ts.LogTypePlainText = 1;
1690 }
1691 else {
1692 ts.LogTypePlainText = 0;
1693 }
1694
1695 if (GetCheck(IDC_OPT_HIDEDLG)) {
1696 ts.LogHideDialog = 1;
1697 }
1698 else {
1699 ts.LogHideDialog = 0;
1700 }
1701
1702 if (GetCheck(IDC_OPT_INCBUF)) {
1703 ts.LogAllBuffIncludedInFirst = 1;
1704 }
1705 else {
1706 ts.LogAllBuffIncludedInFirst = 0;
1707 }
1708
1709 if (GetCheck(IDC_OPT_TIMESTAMP)) {
1710 ts.LogTimestamp = 1;
1711 }
1712 else {
1713 ts.LogTimestamp = 0;
1714 }
1715
1716 ts.LogTimestampType = GetCurSel(IDC_OPT_TIMESTAMP_TYPE);
1717 }
1718
1719 void CLogPropPageDlg::OnHelp()
1720 {
1721 PostMessage(HVTWin, WM_USER_DLGHELP2, HlpMenuSetupAdditionalLog, 0);
1722 }
1723
1724 /////////////////////////////
1725 // cygterm.cfg ��������
1726
1727 #define CYGTERM_FILE "cygterm.cfg" // CygTerm configuration file
1728 #define CYGTERM_FILE_MAXLINE 100
1729
1730 void ReadCygtermConfFile(const char *homedir, cygterm_t *psettings)
1731 {
1732 const char *cfgfile = CYGTERM_FILE; // CygTerm configuration file
1733 char cfg[MAX_PATH];
1734 FILE *fp;
1735 char buf[256], *head, *body;
1736 cygterm_t settings;
1737
1738 // try to read CygTerm config file
1739 memset(&settings, 0, sizeof(settings));
1740 _snprintf_s(settings.term, sizeof(settings.term), _TRUNCATE, "ttermpro.exe %%s %%d /E /KR=SJIS /KT=SJIS /VTICON=CygTerm /nossh");
1741 _snprintf_s(settings.term_type, sizeof(settings.term_type), _TRUNCATE, "vt100");
1742 _snprintf_s(settings.port_start, sizeof(settings.port_start), _TRUNCATE, "20000");
1743 _snprintf_s(settings.port_range, sizeof(settings.port_range), _TRUNCATE, "40");
1744 _snprintf_s(settings.shell, sizeof(settings.shell), _TRUNCATE, "auto");
1745 _snprintf_s(settings.env1, sizeof(settings.env1), _TRUNCATE, "MAKE_MODE=unix");
1746 _snprintf_s(settings.env2, sizeof(settings.env2), _TRUNCATE, "");
1747 settings.login_shell = FALSE;
1748 settings.home_chdir = FALSE;
1749 settings.agent_proxy = FALSE;
1750
1751 strncpy_s(cfg, sizeof(cfg), homedir, _TRUNCATE);
1752 AppendSlash(cfg, sizeof(cfg));
1753 strncat_s(cfg, sizeof(cfg), cfgfile, _TRUNCATE);
1754
1755 fp = fopen(cfg, "r");
1756 if (fp != NULL) {
1757 while (fgets(buf, sizeof(buf), fp) != NULL) {
1758 size_t len = strlen(buf);
1759
1760 if (buf[len - 1] == '\n')
1761 buf[len - 1] = '\0';
1762
1763 split_buffer(buf, '=', &head, &body);
1764 if (head == NULL || body == NULL)
1765 continue;
1766
1767 if (_stricmp(head, "TERM") == 0) {
1768 _snprintf_s(settings.term, sizeof(settings.term), _TRUNCATE, "%s", body);
1769
1770 }
1771 else if (_stricmp(head, "TERM_TYPE") == 0) {
1772 _snprintf_s(settings.term_type, sizeof(settings.term_type), _TRUNCATE, "%s", body);
1773
1774 }
1775 else if (_stricmp(head, "PORT_START") == 0) {
1776 _snprintf_s(settings.port_start, sizeof(settings.port_start), _TRUNCATE, "%s", body);
1777
1778 }
1779 else if (_stricmp(head, "PORT_RANGE") == 0) {
1780 _snprintf_s(settings.port_range, sizeof(settings.port_range), _TRUNCATE, "%s", body);
1781
1782 }
1783 else if (_stricmp(head, "SHELL") == 0) {
1784 _snprintf_s(settings.shell, sizeof(settings.shell), _TRUNCATE, "%s", body);
1785
1786 }
1787 else if (_stricmp(head, "ENV_1") == 0) {
1788 _snprintf_s(settings.env1, sizeof(settings.env1), _TRUNCATE, "%s", body);
1789
1790 }
1791 else if (_stricmp(head, "ENV_2") == 0) {
1792 _snprintf_s(settings.env2, sizeof(settings.env2), _TRUNCATE, "%s", body);
1793
1794 }
1795 else if (_stricmp(head, "LOGIN_SHELL") == 0) {
1796 if (strchr("YyTt", *body)) {
1797 settings.login_shell = TRUE;
1798 }
1799
1800 }
1801 else if (_stricmp(head, "HOME_CHDIR") == 0) {
1802 if (strchr("YyTt", *body)) {
1803 settings.home_chdir = TRUE;
1804 }
1805
1806 }
1807 else if (_stricmp(head, "SSH_AGENT_PROXY") == 0) {
1808 if (strchr("YyTt", *body)) {
1809 settings.agent_proxy = TRUE;
1810 }
1811
1812 }
1813 else {
1814 // TODO: error check
1815
1816 }
1817 }
1818 fclose(fp);
1819 }
1820
1821 memcpy(psettings, &settings, sizeof(cygterm_t));
1822 }
1823
1824 BOOL WriteCygtermConfFile(const char *homedir, cygterm_t *psettings)
1825 {
1826 const char *cfgfile = CYGTERM_FILE; // CygTerm configuration file
1827 const char *tmpfile = "cygterm.tmp";
1828 char cfg[MAX_PATH];
1829 char tmp[MAX_PATH];
1830 FILE *fp;
1831 FILE *tmp_fp;
1832 char buf[256], *head, *body;
1833 cygterm_t settings;
1834 char *line[CYGTERM_FILE_MAXLINE];
1835 int i, linenum;
1836
1837 memcpy(&settings, psettings, sizeof(cygterm_t));
1838
1839 strncpy_s(cfg, sizeof(cfg), homedir, _TRUNCATE);
1840 AppendSlash(cfg, sizeof(cfg));
1841 strncat_s(cfg, sizeof(cfg), cfgfile, _TRUNCATE);
1842
1843 strncpy_s(tmp, sizeof(tmp), homedir, _TRUNCATE);
1844 AppendSlash(tmp, sizeof(tmp));
1845 strncat_s(tmp, sizeof(tmp), tmpfile, _TRUNCATE);
1846
1847 // cygterm.cfg �������������A�������������������������������B
1848 memset(line, 0, sizeof(line));
1849 linenum = 0;
1850 fp = fopen(cfg, "r");
1851 if (fp) {
1852 i = 0;
1853 while (fgets(buf, sizeof(buf), fp) != NULL) {
1854 size_t len = strlen(buf);
1855 if (buf[len - 1] == '\n')
1856 buf[len - 1] = '\0';
1857 if (i < CYGTERM_FILE_MAXLINE)
1858 line[i++] = _strdup(buf);
1859 else
1860 break;
1861 }
1862 linenum = i;
1863 fclose(fp);
1864 }
1865
1866 tmp_fp = fopen(cfg, "w");
1867 if (tmp_fp == NULL) {
1868 return FALSE;
1869 #if 0
1870 char uimsg[MAX_UIMSG];
1871 get_lang_msg("MSG_ERROR", uimsg, sizeof(uimsg), "ERROR", ts->UILanguageFile);
1872 get_lang_msg("MSG_CYGTERM_CONF_WRITEFILE_ERROR", ts->UIMsg, sizeof(ts->UIMsg),
1873 "Can't write CygTerm configuration file (%d).", ts->UILanguageFile);
1874 _snprintf_s(buf, sizeof(buf), _TRUNCATE, ts->UIMsg, GetLastError());
1875 MessageBox(NULL, buf, uimsg, MB_ICONEXCLAMATION);
1876 #endif
1877 }
1878 else {
1879 if (linenum > 0) {
1880 for (i = 0; i < linenum; i++) {
1881 split_buffer(line[i], '=', &head, &body);
1882 if (head == NULL || body == NULL) {
1883 fprintf(tmp_fp, "%s\n", line[i]);
1884 }
1885 else if (_stricmp(head, "TERM") == 0) {
1886 fprintf(tmp_fp, "TERM = %s\n", settings.term);
1887 settings.term[0] = '\0';
1888 }
1889 else if (_stricmp(head, "TERM_TYPE") == 0) {
1890 fprintf(tmp_fp, "TERM_TYPE = %s\n", settings.term_type);
1891 settings.term_type[0] = '\0';
1892 }
1893 else if (_stricmp(head, "PORT_START") == 0) {
1894 fprintf(tmp_fp, "PORT_START = %s\n", settings.port_start);
1895 settings.port_start[0] = '\0';
1896 }
1897 else if (_stricmp(head, "PORT_RANGE") == 0) {
1898 fprintf(tmp_fp, "PORT_RANGE = %s\n", settings.port_range);
1899 settings.port_range[0] = '\0';
1900 }
1901 else if (_stricmp(head, "SHELL") == 0) {
1902 fprintf(tmp_fp, "SHELL = %s\n", settings.shell);
1903 settings.shell[0] = '\0';
1904 }
1905 else if (_stricmp(head, "ENV_1") == 0) {
1906 fprintf(tmp_fp, "ENV_1 = %s\n", settings.env1);
1907 settings.env1[0] = '\0';
1908 }
1909 else if (_stricmp(head, "ENV_2") == 0) {
1910 fprintf(tmp_fp, "ENV_2 = %s\n", settings.env2);
1911 settings.env2[0] = '\0';
1912 }
1913 else if (_stricmp(head, "LOGIN_SHELL") == 0) {
1914 fprintf(tmp_fp, "LOGIN_SHELL = %s\n", (settings.login_shell == TRUE) ? "yes" : "no");
1915 settings.login_shell = FALSE;
1916 }
1917 else if (_stricmp(head, "HOME_CHDIR") == 0) {
1918 fprintf(tmp_fp, "HOME_CHDIR = %s\n", (settings.home_chdir == TRUE) ? "yes" : "no");
1919 settings.home_chdir = FALSE;
1920 }
1921 else if (_stricmp(head, "SSH_AGENT_PROXY") == 0) {
1922 fprintf(tmp_fp, "SSH_AGENT_PROXY = %s\n", (settings.agent_proxy == TRUE) ? "yes" : "no");
1923 settings.agent_proxy = FALSE;
1924 }
1925 else {
1926 fprintf(tmp_fp, "%s = %s\n", head, body);
1927 }
1928 }
1929 }
1930 else {
1931 fputs("# CygTerm setting\n", tmp_fp);
1932 fputs("\n", tmp_fp);
1933 }
1934 if (settings.term[0] != '\0') {
1935 fprintf(tmp_fp, "TERM = %s\n", settings.term);
1936 }
1937 if (settings.term_type[0] != '\0') {
1938 fprintf(tmp_fp, "TERM_TYPE = %s\n", settings.term_type);
1939 }
1940 if (settings.port_start[0] != '\0') {
1941 fprintf(tmp_fp, "PORT_START = %s\n", settings.port_start);
1942 }
1943 if (settings.port_range[0] != '\0') {
1944 fprintf(tmp_fp, "PORT_RANGE = %s\n", settings.port_range);
1945 }
1946 if (settings.shell[0] != '\0') {
1947 fprintf(tmp_fp, "SHELL = %s\n", settings.shell);
1948 }
1949 if (settings.env1[0] != '\0') {
1950 fprintf(tmp_fp, "ENV_1 = %s\n", settings.env1);
1951 }
1952 if (settings.env2[0] != '\0') {
1953 fprintf(tmp_fp, "ENV_2 = %s\n", settings.env2);
1954 }
1955 if (settings.login_shell) {
1956 fprintf(tmp_fp, "LOGIN_SHELL = yes\n");
1957 }
1958 if (settings.home_chdir) {
1959 fprintf(tmp_fp, "HOME_CHDIR = yes\n");
1960 }
1961 if (settings.agent_proxy) {
1962 fprintf(tmp_fp, "SSH_AGENT_PROXY = yes\n");
1963 }
1964 fclose(tmp_fp);
1965
1966 // �_�C���N�g���t�@�C���������������������������A���L�������s�v�B
1967 #if 0
1968 if (remove(cfg) != 0 && errno != ENOENT) {
1969 get_lang_msg("MSG_ERROR", uimsg, sizeof(uimsg), "ERROR", ts->UILanguageFile);
1970 get_lang_msg("MSG_CYGTERM_CONF_REMOVEFILE_ERROR", ts->UIMsg, sizeof(ts->UIMsg),
1971 "Can't remove old CygTerm configuration file (%d).", ts->UILanguageFile);
1972 _snprintf_s(buf, sizeof(buf), _TRUNCATE, ts->UIMsg, GetLastError());
1973 MessageBox(NULL, buf, uimsg, MB_ICONEXCLAMATION);
1974 }
1975 else if (rename(tmp, cfg) != 0) {
1976 get_lang_msg("MSG_ERROR", uimsg, sizeof(uimsg), "ERROR", ts->UILanguageFile);
1977 get_lang_msg("MSG_CYGTERM_CONF_RENAMEFILE_ERROR", ts->UIMsg, sizeof(ts->UIMsg),
1978 "Can't rename CygTerm configuration file (%d).", ts->UILanguageFile);
1979 _snprintf_s(buf, sizeof(buf), _TRUNCATE, ts->UIMsg, GetLastError());
1980 MessageBox(NULL, buf, uimsg, MB_ICONEXCLAMATION);
1981 }
1982 else {
1983 // cygterm.cfg �t�@�C�����������������������A���b�Z�[�W�_�C�A���O���\�������B
1984 // �������ASave setup�����s�����K�v�������������������N�����B
1985 // (2012.5.1 yutaka)
1986 // Save setup ���s�����ACygTerm�������������������������������������A
1987 // �_�C�A���O�\�����s�v�����������A���������B
1988 // (2015.11.12 yutaka)
1989 get_lang_msg("MSG_TT_NOTICE", uimsg, sizeof(uimsg), "MSG_TT_NOTICE", ts->UILanguageFile);
1990 get_lang_msg("MSG_CYGTERM_CONF_SAVED_NOTICE", ts->UIMsg, sizeof(ts->UIMsg),
1991 "%s has been saved. Do not do save setup.", ts->UILanguageFile);
1992 _snprintf_s(buf, sizeof(buf), _TRUNCATE, ts->UIMsg, CYGTERM_FILE);
1993 MessageBox(NULL, buf, uimsg, MB_OK | MB_ICONINFORMATION);
1994 }
1995 #endif
1996 }
1997
1998 // �Y�������������t���[���������B
1999 for (i = 0; i < linenum; i++) {
2000 free(line[i]);
2001 }
2002
2003 return TRUE;
2004 }
2005
2006 /////////////////////////////
2007
2008 // CCygwinPropPageDlg �_�C�A���O
2009
2010 CCygwinPropPageDlg::CCygwinPropPageDlg(HINSTANCE inst)
2011 : TTCPropertyPage(inst, CCygwinPropPageDlg::IDD)
2012 {
2013 wchar_t *UIMsg;
2014 GetI18nStrWW("Tera Term", "DLG_TABSHEET_TITLE_CYGWIN",
2015 L"Cygwin", ts.UILanguageFileW, &UIMsg);
2016 m_psp.pszTitle = UIMsg;
2017 m_psp.dwFlags |= (PSP_USETITLE | PSP_HASHELP);
2018 }
2019
2020 CCygwinPropPageDlg::~CCygwinPropPageDlg()
2021 {
2022 free((void *)m_psp.pszTitle);
2023 }
2024
2025 // CCygwinPropPageDlg ���b�Z�[�W �n���h��
2026
2027 void CCygwinPropPageDlg::OnInitDialog()
2028 {
2029 TTCPropertyPage::OnInitDialog();
2030
2031 static const DlgTextInfo TextInfos[] = {
2032 { IDC_CYGWIN_PATH_LABEL, "DLG_TAB_CYGWIN_PATH" }
2033 };
2034 SetDlgTextsW(m_hWnd, TextInfos, _countof(TextInfos), ts.UILanguageFileW);
2035
2036 ReadCygtermConfFile(ts.HomeDir, &settings);
2037
2038 SetDlgItemTextA(IDC_TERM_EDIT, settings.term);
2039 SetDlgItemTextA(IDC_TERM_TYPE, settings.term_type);
2040 SetDlgItemTextA(IDC_PORT_START, settings.port_start);
2041 SetDlgItemTextA(IDC_PORT_RANGE, settings.port_range);
2042 SetDlgItemTextA(IDC_SHELL, settings.shell);
2043 SetDlgItemTextA(IDC_ENV1, settings.env1);
2044 SetDlgItemTextA(IDC_ENV2, settings.env2);
2045
2046 SetCheck(IDC_LOGIN_SHELL, settings.login_shell);
2047 SetCheck(IDC_HOME_CHDIR, settings.home_chdir);
2048 SetCheck(IDC_AGENT_PROXY, settings.agent_proxy);
2049
2050 // Cygwin install path
2051 SetDlgItemTextA(IDC_CYGWIN_PATH, ts.CygwinDirectory);
2052
2053 // �_�C�A���O���t�H�[�J�X��������
2054 ::SetFocus(::GetDlgItem(GetSafeHwnd(), IDC_CYGWIN_PATH));
2055 }
2056
2057 BOOL CCygwinPropPageDlg::OnCommand(WPARAM wParam, LPARAM lParam)
2058 {
2059 switch (wParam) {
2060 case IDC_SELECT_FILE | (BN_CLICKED << 16):
2061 // Cygwin install �f�B���N�g�����I���_�C�A���O
2062 wchar_t *title = TTGetLangStrW("Tera Term", "DIRDLG_CYGTERM_DIR_TITLE", L"Select Cygwin directory", ts.UILanguageFile);
2063 wchar_t *buf;
2064 hGetDlgItemTextW(m_hWnd, IDC_CYGWIN_PATH, &buf);
2065 wchar_t *path;
2066 if (doSelectFolderW(GetSafeHwnd(), buf, title, &path)) {
2067 SetDlgItemTextW(IDC_CYGWIN_PATH, path);
2068 free(path);
2069 }
2070 free(buf);
2071 free(title);
2072 return TRUE;
2073 }
2074
2075 return TTCPropertyPage::OnCommand(wParam, lParam);
2076 }
2077
2078 /**
2079 * @brief cygterm_t�����r����
2080 * @param a cygterm_t
2081 * @param b cygterm_t
2082 * @retval TRUE ����
2083 * @retval FALSE ������
2084 */
2085 BOOL CmpCygtermConfFile(const cygterm_t *a, const cygterm_t *b)
2086 {
2087 if ((strcmp(a->term, b->term) != 0) ||
2088 (strcmp(a->term_type, b->term_type) != 0) ||
2089 (strcmp(a->port_start, b->port_start) != 0) ||
2090 (strcmp(a->port_range, b->port_range) != 0) ||
2091 (strcmp(a->shell, b->shell) != 0) ||
2092 (strcmp(a->env1, b->env1) != 0) ||
2093 (strcmp(a->env2, b->env2) != 0) ||
2094 (a->login_shell != b->login_shell) ||
2095 (a->home_chdir != b->home_chdir) ||
2096 (a->agent_proxy != b->agent_proxy)) {
2097 return FALSE;
2098 }
2099 return TRUE;
2100 }
2101
2102 void CCygwinPropPageDlg::OnOK()
2103 {
2104 cygterm_t settings_prop;
2105
2106 // �v���p�e�B�[�V�[�g�����l����������
2107 GetDlgItemTextA(IDC_TERM_EDIT, settings_prop.term, sizeof(settings_prop.term));
2108 GetDlgItemTextA(IDC_TERM_TYPE, settings_prop.term_type, sizeof(settings_prop.term_type));
2109 GetDlgItemTextA(IDC_PORT_START, settings_prop.port_start, sizeof(settings_prop.port_start));
2110 GetDlgItemTextA(IDC_PORT_RANGE, settings_prop.port_range, sizeof(settings_prop.port_range));
2111 GetDlgItemTextA(IDC_SHELL, settings_prop.shell, sizeof(settings_prop.shell));
2112 GetDlgItemTextA(IDC_ENV1, settings_prop.env1, sizeof(settings_prop.env1));
2113 GetDlgItemTextA(IDC_ENV2, settings_prop.env2, sizeof(settings_prop.env2));
2114
2115 settings_prop.login_shell = GetCheck(IDC_LOGIN_SHELL);
2116 settings_prop.home_chdir = GetCheck(IDC_HOME_CHDIR);
2117 settings_prop.agent_proxy = GetCheck(IDC_AGENT_PROXY);
2118
2119 // ���X�������������� cygterm.cfg ����������
2120 if (CmpCygtermConfFile(&settings_prop, &settings) == FALSE) {
2121 if (WriteCygtermConfFile(ts.HomeDir, &settings_prop) == FALSE) {
2122 char uimsg[MAX_UIMSG];
2123 char buf[256];
2124 get_lang_msg("MSG_ERROR", uimsg, sizeof(uimsg), "ERROR", ts.UILanguageFile);
2125 get_lang_msg("MSG_CYGTERM_CONF_WRITEFILE_ERROR", ts.UIMsg, sizeof(ts.UIMsg),
2126 "Can't write CygTerm configuration file (%d).", ts.UILanguageFile);
2127 _snprintf_s(buf, sizeof(buf), _TRUNCATE, ts.UIMsg, GetLastError());
2128 MessageBoxA(buf, uimsg, MB_ICONEXCLAMATION);
2129 }
2130 }
2131
2132 // Cygwin install path
2133 GetDlgItemTextA(IDC_CYGWIN_PATH, ts.CygwinDirectory, sizeof(ts.CygwinDirectory));
2134 }
2135
2136 void CCygwinPropPageDlg::OnHelp()
2137 {
2138 PostMessage(HVTWin, WM_USER_DLGHELP2, HlpMenuSetupAdditional, 0);
2139 }
2140
2141 //////////////////////////////////////////////////////////////////////////////
2142
2143 // CAddSettingPropSheetDlg
2144 CAddSettingPropSheetDlg::CAddSettingPropSheetDlg(HINSTANCE hInstance, HWND hParentWnd):
2145 TTCPropSheetDlg(hInstance, hParentWnd, ts.UILanguageFileW)
2146 {
2147 // CPP,tmfc��TTCPropertyPage�h���N���X��������
2148 int i = 0;
2149 m_Page[i++] = new CGeneralPropPageDlg(hInstance);
2150 m_Page[i++] = new CSequencePropPageDlg(hInstance);
2151 m_Page[i++] = new CCopypastePropPageDlg(hInstance);
2152 m_Page[i++] = new CVisualPropPageDlg(hInstance);
2153 m_Page[i++] = new CLogPropPageDlg(hInstance);
2154 m_Page[i++] = new CCygwinPropPageDlg(hInstance);
2155 if ((GetKeyState(VK_CONTROL) & 0x8000) != 0 ||
2156 (GetKeyState(VK_SHIFT) & 0x8000) != 0 ) {
2157 m_Page[i++] = new CDebugPropPage(hInstance);
2158 }
2159 m_PageCountCPP = i;
2160
2161 HPROPSHEETPAGE page;
2162 for (i = 0; i < m_PageCountCPP; i++) {
2163 page = m_Page[i]->CreatePropertySheetPage();
2164 AddPage(page);
2165 }
2166
2167 // TTCPropertyPage ���g�p������ PropertyPage
2168 page = CodingPageCreate(hInstance, &ts);
2169 AddPage(page);
2170 page = FontPageCreate(hInstance, &ts);
2171 AddPage(page);
2172
2173 wchar_t *title = TTGetLangStrW("Tera Term", "DLG_TABSHEET_TITLE", L"Tera Term: Additional settings", ts.UILanguageFile);
2174 SetCaption(title);
2175 free(title);
2176 }
2177
2178 CAddSettingPropSheetDlg::~CAddSettingPropSheetDlg()
2179 {
2180 for (int i = 0; i < m_PageCountCPP; i++) {
2181 delete m_Page[i];
2182 }
2183 }
2184
2185 void CAddSettingPropSheetDlg::SetStartPage(Page page)
2186 {
2187 int start_page = page == DefaultPage ? 0: 7;
2188 TTCPropSheetDlg::SetStartPage(start_page);
2189 }

Back to OSDN">Back to OSDN
ViewVC Help
Powered by ViewVC 1.1.26