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 10373 - (show annotations) (download) (as text)
Sun Nov 20 14:18:21 2022 UTC (16 months, 2 weeks ago) by zmatsuo
File MIME type: text/x-c++src
File size: 68376 byte(s)
通知サウンド設定追加

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

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