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 10338 - (show annotations) (download) (as text)
Fri Oct 28 13:25:45 2022 UTC (17 months, 1 week ago) by zmatsuo
File MIME type: text/x-c++src
File size: 66300 byte(s)
テーマの文字背景の透過設定の種類を増やした

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

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