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 10394 - (show annotations) (download) (as text)
Sat Dec 3 06:40:18 2022 UTC (16 months, 1 week ago) by zmatsuo
File MIME type: text/x-c++src
File size: 68388 byte(s)
通知関連のAPIを整理した

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

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