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 10179 - (show annotations) (download) (as text)
Wed Aug 24 14:03:59 2022 UTC (19 months, 2 weeks ago) by zmatsuo
File MIME type: text/x-c++src
File size: 64278 byte(s)
cygterm_t を tttypes.h から addsetting.h へ移動

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

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