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 10358 - (show annotations) (download) (as text)
Fri Nov 11 14:13:11 2022 UTC (16 months, 4 weeks ago) by zmatsuo
File MIME type: text/x-c++src
File size: 66999 byte(s)
印字開始シーケンスを無効化、ベルの動作設定をダイアログに追加

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

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