Develop and Download Open Source Software

Browse Subversion Repository

Annotation of /trunk/teraterm/ttpset/ttset.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 9631 - (hide annotations) (download) (as text)
Sat Dec 25 10:35:59 2021 UTC (2 years, 3 months ago) by zmatsuo
File MIME type: text/x-csrc
File size: 136103 byte(s)
ディレクトリの変更ダイアログを Unicode に対応するよう修正

- ts.FileDir を FileDirW に置き換え
- FileDir(W) は環境変数への参照を含んでいてもよい
  - %APPDATA% など
  - 使用前に ExpandEnvironmentStringsW() で展開する
- iniファイル読み込み時に環境変数への参照を残すようにした
- r9618
1 doda 6806 /*
2     * Copyright (C) 1994-1998 T. Teranishi
3 nmaya 9048 * (C) 2004- TeraTerm Project
4 doda 6806 * All rights reserved.
5     *
6 doda 6841 * Redistribution and use in source and binary forms, with or without
7     * modification, are permitted provided that the following conditions
8     * are met:
9 doda 6806 *
10 doda 6841 * 1. Redistributions of source code must retain the above copyright
11     * notice, this list of conditions and the following disclaimer.
12     * 2. Redistributions in binary form must reproduce the above copyright
13     * notice, this list of conditions and the following disclaimer in the
14     * documentation and/or other materials provided with the distribution.
15     * 3. The name of the author may not be used to endorse or promote products
16     * derived from this software without specific prior written permission.
17 doda 6806 *
18 doda 6841 * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR
19     * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20     * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21     * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT,
22     * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23     * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24     * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25     * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26     * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27     * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 doda 6806 */
29 maya 3227 /* IPv6 modification is Copyright(C) 2000 Jun-ya kato <kato@win6.jp> */
30    
31     /* TTSET.DLL, setup file routines*/
32     #include <winsock2.h>
33     #include <ws2tcpip.h>
34     #include "teraterm.h"
35     #include "tttypes.h"
36     #include <stdio.h>
37     #include <string.h>
38     #include <direct.h>
39 doda 4217 #include <ctype.h>
40 maya 6121 #include <errno.h>
41 zmatsuo 9301 #define _CRTDBG_MAP_ALLOC
42     #include <stdlib.h>
43     #include <crtdbg.h>
44    
45 maya 3227 #include "ttlib.h"
46     #include "tt_res.h"
47 doda 7091 #include "servicenames.h"
48 zmatsuo 9242 #include "codeconv.h"
49 zmatsuo 9306 #include "win32helper.h"
50 zmatsuo 9429 #include "inifile_com.h"
51 zmatsuo 9499 #include "ttlib_charset.h"
52 maya 3227
53 zmatsuo 8279 #define DllExport __declspec(dllexport)
54     #include "ttset.h"
55    
56 maya 4874 #ifndef CLEARTYPE_QUALITY
57     #define CLEARTYPE_QUALITY 5
58     #endif
59    
60 maya 3227 #define Section "Tera Term"
61 zmatsuo 9306 #define SectionW L"Tera Term"
62 maya 3227
63 atsue 5126 #define MaxStrLen (LONG)512
64    
65 maya 3227 static PCHAR far TermList[] =
66     { "VT100", "VT100J", "VT101", "VT102", "VT102J", "VT220J", "VT282",
67 doda 4084 "VT320", "VT382", "VT420", "VT520", "VT525", NULL };
68 maya 3227
69     static PCHAR far RussList2[] = { "Windows", "KOI8-R", NULL };
70    
71 yutakapon 8205
72     /*
73     * �V���A���|�[�g���A���������`
74     */
75     #define IDENDMARK 0xFFFF
76    
77     typedef struct id_str_pair {
78     WORD id;
79     char *str;
80     } id_str_pair_t;
81    
82     static id_str_pair_t serial_conf_databit[] = {
83     {IdDataBit7, "7"},
84     {IdDataBit8, "8"},
85     {IDENDMARK, NULL},
86     };
87    
88     static id_str_pair_t serial_conf_parity[] = {
89     {IdParityNone, "none"},
90     {IdParityOdd, "odd"},
91     {IdParityEven, "even"},
92     {IdParityMark, "mark"},
93     {IdParitySpace, "space"},
94     {IDENDMARK, NULL},
95     };
96    
97     static id_str_pair_t serial_conf_stopbit[] = {
98     {IdStopBit1, "1"},
99     {IdStopBit2, "2"},
100     {IDENDMARK, NULL},
101     };
102    
103     static id_str_pair_t serial_conf_flowctrl[] = {
104     {IdFlowX, "x"},
105     {IdFlowHard, "hard"},
106     {IdFlowHard, "rtscts"},
107     {IdFlowNone, "none"},
108     {IdFlowHardDsrDtr, "dsrdtr"},
109     {IDENDMARK, NULL},
110     };
111    
112    
113     /*
114     * �V���A���|�[�g���A������
115     * Id���������������������B
116     *
117     * return
118     * TRUE: ��������
119     * FALSE: �������s
120     */
121 zmatsuo 8279 int WINAPI SerialPortConfconvertId2Str(enum serial_port_conf type, WORD id, PCHAR str, int strlen)
122 yutakapon 8205 {
123     id_str_pair_t *conf;
124     int ret = FALSE;
125     int i;
126    
127     switch (type) {
128     case COM_DATABIT:
129     conf = serial_conf_databit;
130     break;
131     case COM_PARITY:
132     conf = serial_conf_parity;
133     break;
134     case COM_STOPBIT:
135     conf = serial_conf_stopbit;
136     break;
137     case COM_FLOWCTRL:
138     conf = serial_conf_flowctrl;
139     break;
140     default:
141     conf = NULL;
142     break;
143     }
144     if (conf == NULL)
145     goto error;
146    
147     for (i = 0 ; ; i++) {
148     if (conf[i].id == IDENDMARK)
149     goto error;
150     if (conf[i].id == id) {
151     strncpy_s(str, strlen, conf[i].str, _TRUNCATE);
152     break;
153     }
154     }
155    
156     ret = TRUE;
157    
158     error:
159     return (ret);
160     }
161    
162 zmatsuo 9242 #undef GetPrivateProfileInt
163     #undef GetPrivateProfileString
164 zmatsuo 9429 #define GetPrivateProfileInt(p1, p2, p3, p4) GetPrivateProfileIntAFileW(p1, p2, p3, p4)
165 zmatsuo 9242 #define GetPrivateProfileString(p1, p2, p3, p4, p5, p6) GetPrivateProfileStringAFileW(p1, p2, p3, p4, p5, p6)
166     #define GetPrivateProfileStringA(p1, p2, p3, p4, p5, p6) GetPrivateProfileStringAFileW(p1, p2, p3, p4, p5, p6)
167     #define WritePrivateProfileStringA(p1, p2, p3, p4) WritePrivateProfileStringAFileW(p1, p2, p3, p4)
168    
169 yutakapon 8205 /*
170     * �V���A���|�[�g���A������
171     * ����������Id�����������B
172     *
173     * return
174     * TRUE: ��������
175     * FALSE: �������s
176     */
177 zmatsuo 9436 static int SerialPortConfconvertStr2Id(enum serial_port_conf type, const wchar_t *str, WORD *id)
178 yutakapon 8205 {
179     id_str_pair_t *conf;
180     int ret = FALSE;
181     int i;
182 zmatsuo 9436 char *strA;
183 yutakapon 8205
184     switch (type) {
185     case COM_DATABIT:
186     conf = serial_conf_databit;
187     break;
188     case COM_PARITY:
189     conf = serial_conf_parity;
190     break;
191     case COM_STOPBIT:
192     conf = serial_conf_stopbit;
193     break;
194     case COM_FLOWCTRL:
195     conf = serial_conf_flowctrl;
196     break;
197     default:
198     conf = NULL;
199     break;
200     }
201 zmatsuo 9436 if (conf == NULL) {
202     return FALSE;
203     }
204 yutakapon 8205
205 zmatsuo 9436 strA = ToCharW(str);
206 yutakapon 8205 for (i = 0 ; ; i++) {
207 zmatsuo 9436 if (conf[i].id == IDENDMARK) {
208     ret = FALSE;
209     break;
210     }
211     if (_stricmp(conf[i].str, strA) == 0) {
212 yutakapon 8205 *id = conf[i].id;
213 zmatsuo 9436 ret = TRUE;
214 yutakapon 8205 break;
215     }
216     }
217 zmatsuo 9436 free(strA);
218     return ret;
219 yutakapon 8205 }
220    
221 maya 3227 WORD str2id(PCHAR far * List, PCHAR str, WORD DefId)
222     {
223     WORD i;
224     i = 0;
225     while ((List[i] != NULL) && (_stricmp(List[i], str) != 0))
226     i++;
227     if (List[i] == NULL)
228     i = DefId;
229     else
230     i++;
231    
232     return i;
233     }
234    
235     void id2str(PCHAR far * List, WORD Id, WORD DefId, PCHAR str, int destlen)
236     {
237     int i;
238    
239     if (Id == 0)
240     i = DefId - 1;
241     else {
242     i = 0;
243     while ((List[i] != NULL) && (i < Id - 1))
244     i++;
245     if (List[i] == NULL)
246     i = DefId - 1;
247     }
248     strncpy_s(str, destlen, List[i], _TRUNCATE);
249     }
250    
251 zmatsuo 9436 static int IconName2IconId(const wchar_t *name)
252     {
253 maya 3227 int id;
254    
255 zmatsuo 9436 if (_wcsicmp(name, L"tterm") == 0) {
256 maya 3227 id = IDI_TTERM;
257     }
258 zmatsuo 9436 else if (_wcsicmp(name, L"vt") == 0) {
259 maya 3227 id = IDI_VT;
260     }
261 zmatsuo 9436 else if (_wcsicmp(name, L"tek") == 0) {
262 maya 3227 id = IDI_TEK;
263     }
264 zmatsuo 9436 else if (_wcsicmp(name, L"tterm_classic") == 0) {
265 maya 3227 id = IDI_TTERM_CLASSIC;
266     }
267 zmatsuo 9436 else if (_wcsicmp(name, L"vt_classic") == 0) {
268 maya 3227 id = IDI_VT_CLASSIC;
269     }
270 zmatsuo 9436 else if (_wcsicmp(name, L"tterm_3d") == 0) {
271 maya 6386 id = IDI_TTERM_3D;
272     }
273 zmatsuo 9436 else if (_wcsicmp(name, L"vt_3d") == 0) {
274 maya 6386 id = IDI_VT_3D;
275     }
276 zmatsuo 9436 else if (_wcsicmp(name, L"cygterm") == 0) {
277 maya 3227 id = IDI_CYGTERM;
278     }
279     else {
280     id = IdIconDefault;
281     }
282     return id;
283     }
284    
285 zmatsuo 9436 static int IconName2IconIdA(const char *name)
286     {
287     wchar_t *nameW = ToWcharA(name);
288     int id = IconName2IconId(nameW);
289     free(nameW);
290     return id;
291     }
292    
293    
294 maya 3227 void IconId2IconName(char *name, int len, int id) {
295     char *icon;
296     switch (id) {
297     case IDI_TTERM:
298     icon = "tterm";
299     break;
300     case IDI_VT:
301     icon = "vt";
302     break;
303     case IDI_TEK:
304     icon = "tek";
305     break;
306     case IDI_TTERM_CLASSIC:
307     icon = "tterm_classic";
308     break;
309     case IDI_VT_CLASSIC:
310     icon = "vt_classic";
311     break;
312 maya 6386 case IDI_TTERM_3D:
313     icon = "tterm_3d";
314     break;
315     case IDI_VT_3D:
316     icon = "vt_3d";
317     break;
318 maya 3227 case IDI_CYGTERM:
319     icon = "cygterm";
320     break;
321     default:
322     icon = "Default";
323     }
324     strncpy_s(name, len, icon, _TRUNCATE);
325     }
326    
327 zmatsuo 9242 static WORD GetOnOff(PCHAR Sect, PCHAR Key, const wchar_t *FName, BOOL Default)
328 maya 3227 {
329     char Temp[4];
330     GetPrivateProfileString(Sect, Key, "", Temp, sizeof(Temp), FName);
331     if (Default) {
332     if (_stricmp(Temp, "off") == 0)
333     return 0;
334     else
335     return 1;
336     }
337     else {
338     if (_stricmp(Temp, "on") == 0)
339     return 1;
340     else
341     return 0;
342     }
343     }
344    
345 zmatsuo 9242 void WriteOnOff(PCHAR Sect, PCHAR Key, const wchar_t *FName, WORD Flag)
346 maya 3227 {
347 zmatsuo 9242 const char *on_off = (Flag != 0) ? "on" : "off";
348     WritePrivateProfileStringA(Sect, Key, on_off, FName);
349 maya 3227 }
350    
351 zmatsuo 9242 void WriteInt(PCHAR Sect, PCHAR Key, const wchar_t *FName, int i)
352 maya 3227 {
353     char Temp[15];
354     _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d", i);
355 zmatsuo 9242 WritePrivateProfileStringA(Sect, Key, Temp, FName);
356 maya 3227 }
357    
358 zmatsuo 9242 void WriteUint(PCHAR Sect, PCHAR Key, const wchar_t *FName, UINT i)
359 maya 3227 {
360     char Temp[15];
361     _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%u", i);
362 zmatsuo 9242 WritePrivateProfileStringA(Sect, Key, Temp, FName);
363 maya 3227 }
364    
365 zmatsuo 9242 void WriteInt2(PCHAR Sect, PCHAR Key, const wchar_t *FName, int i1, int i2)
366 maya 3227 {
367     char Temp[32];
368     _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d,%d", i1, i2);
369 zmatsuo 9242 WritePrivateProfileStringA(Sect, Key, Temp, FName);
370 maya 3227 }
371    
372 zmatsuo 9242 void WriteInt4(PCHAR Sect, PCHAR Key, const wchar_t *FName,
373 maya 3227 int i1, int i2, int i3, int i4)
374     {
375     char Temp[64];
376     _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d,%d,%d,%d",
377     i1, i2, i3, i4);
378 zmatsuo 9242 WritePrivateProfileStringA(Sect, Key, Temp, FName);
379 maya 3227 }
380    
381 zmatsuo 9242 void WriteInt6(PCHAR Sect, PCHAR Key, const wchar_t *FName,
382 maya 3227 int i1, int i2, int i3, int i4, int i5, int i6)
383     {
384     char Temp[96];
385     _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d,%d,%d,%d,%d,%d",
386     i1, i2,i3, i4, i5, i6);
387 zmatsuo 9242 WritePrivateProfileStringA(Sect, Key, Temp, FName);
388 maya 3227 }
389    
390 zmatsuo 7705 // �t�H���g�������������A4�p�����[�^��
391 zmatsuo 9242 static void WriteFont(PCHAR Sect, PCHAR Key, const wchar_t *FName,
392 zmatsuo 7705 PCHAR Name, int x, int y, int charset)
393 maya 3227 {
394     char Temp[80];
395     if (Name[0] != 0)
396     _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%s,%d,%d,%d",
397     Name, x, y, charset);
398     else
399     Temp[0] = 0;
400 zmatsuo 9242 WritePrivateProfileStringA(Sect, Key, Temp, FName);
401 maya 3227 }
402    
403 zmatsuo 7705 // �t�H���g�������������A4�p�����[�^��
404     static void ReadFont(
405 zmatsuo 9242 const char *Sect, const char *Key, const char *Default, const wchar_t *FName,
406     char *FontName, size_t FontNameLen, POINT *FontSize, int *FontCharSet)
407 zmatsuo 7705 {
408     char Temp[MAX_PATH];
409     GetPrivateProfileString(Sect, Key, Default,
410     Temp, _countof(Temp), FName);
411     if (Temp[0] == 0) {
412     // �f�t�H���g���Z�b�g������������ & ini���G���g���[����������
413     FontName[0] = 0;
414     FontSize->x = 0;
415     FontSize->y = 0;
416 zmatsuo 7706 *FontCharSet = 0;
417 zmatsuo 7705 } else {
418     GetNthString(Temp, 1, FontNameLen, FontName);
419     GetNthNum(Temp, 2, &(FontSize->x));
420     GetNthNum(Temp, 3, &(FontSize->y));
421     GetNthNum(Temp, 4, FontCharSet);
422 zmatsuo 7706 // TODO ���������p�[�X����
423 zmatsuo 7705 }
424     }
425 yutakapon 6119
426 zmatsuo 7706 // �t�H���g�������������A3�p�����[�^��
427     static void ReadFont3(
428 zmatsuo 9242 const char *Sect, const char *Key, const char *Default, const wchar_t *FName,
429     char *FontName, size_t FontNameLen, int *FontPoint, int *FontCharSet)
430 zmatsuo 7706 {
431     char Temp[MAX_PATH];
432     GetPrivateProfileString(Sect, Key, Default,
433     Temp, _countof(Temp), FName);
434     if (Temp[0] == 0) {
435     // �f�t�H���g���Z�b�g������������ & ini���G���g���[����������
436     FontName[0] = 0;
437     *FontPoint = 0;
438     *FontCharSet = 0;
439     } else {
440     GetNthString(Temp, 1, FontNameLen, FontName);
441     GetNthNum(Temp, 2, FontPoint);
442     GetNthNum(Temp, 3, FontCharSet);
443     // TODO ���������p�[�X����
444     }
445     }
446    
447 yutakapon 6119 #define CYGTERM_FILE "cygterm.cfg" // CygTerm configuration file
448 yutakapon 6126 #define CYGTERM_FILE_MAXLINE 100
449 yutakapon 6119
450     static void ReadCygtermConfFile(PTTSet ts)
451     {
452     char *cfgfile = CYGTERM_FILE; // CygTerm configuration file
453     char cfg[MAX_PATH];
454     FILE *fp;
455     char buf[256], *head, *body;
456     cygterm_t settings;
457    
458     // try to read CygTerm config file
459     memset(&settings, 0, sizeof(settings));
460     _snprintf_s(settings.term, sizeof(settings.term), _TRUNCATE, "ttermpro.exe %%s %%d /E /KR=SJIS /KT=SJIS /VTICON=CygTerm /nossh");
461     _snprintf_s(settings.term_type, sizeof(settings.term_type), _TRUNCATE, "vt100");
462     _snprintf_s(settings.port_start, sizeof(settings.port_start), _TRUNCATE, "20000");
463     _snprintf_s(settings.port_range, sizeof(settings.port_range), _TRUNCATE, "40");
464     _snprintf_s(settings.shell, sizeof(settings.shell), _TRUNCATE, "auto");
465     _snprintf_s(settings.env1, sizeof(settings.env1), _TRUNCATE, "MAKE_MODE=unix");
466     _snprintf_s(settings.env2, sizeof(settings.env2), _TRUNCATE, "");
467     settings.login_shell = FALSE;
468     settings.home_chdir = FALSE;
469     settings.agent_proxy = FALSE;
470    
471     strncpy_s(cfg, sizeof(cfg), ts->HomeDir, _TRUNCATE);
472     AppendSlash(cfg, sizeof(cfg));
473     strncat_s(cfg, sizeof(cfg), cfgfile, _TRUNCATE);
474    
475     fp = fopen(cfg, "r");
476     if (fp != NULL) {
477     while (fgets(buf, sizeof(buf), fp) != NULL) {
478 zmatsuo 9242 size_t len = strlen(buf);
479 yutakapon 6119
480     if (buf[len - 1] == '\n')
481     buf[len - 1] = '\0';
482    
483     split_buffer(buf, '=', &head, &body);
484     if (head == NULL || body == NULL)
485     continue;
486    
487     if (_stricmp(head, "TERM") == 0) {
488     _snprintf_s(settings.term, sizeof(settings.term), _TRUNCATE, "%s", body);
489    
490     }
491     else if (_stricmp(head, "TERM_TYPE") == 0) {
492     _snprintf_s(settings.term_type, sizeof(settings.term_type), _TRUNCATE, "%s", body);
493    
494     }
495     else if (_stricmp(head, "PORT_START") == 0) {
496     _snprintf_s(settings.port_start, sizeof(settings.port_start), _TRUNCATE, "%s", body);
497    
498     }
499     else if (_stricmp(head, "PORT_RANGE") == 0) {
500     _snprintf_s(settings.port_range, sizeof(settings.port_range), _TRUNCATE, "%s", body);
501    
502     }
503     else if (_stricmp(head, "SHELL") == 0) {
504     _snprintf_s(settings.shell, sizeof(settings.shell), _TRUNCATE, "%s", body);
505    
506     }
507     else if (_stricmp(head, "ENV_1") == 0) {
508     _snprintf_s(settings.env1, sizeof(settings.env1), _TRUNCATE, "%s", body);
509    
510     }
511     else if (_stricmp(head, "ENV_2") == 0) {
512     _snprintf_s(settings.env2, sizeof(settings.env2), _TRUNCATE, "%s", body);
513    
514     }
515     else if (_stricmp(head, "LOGIN_SHELL") == 0) {
516     if (strchr("YyTt", *body)) {
517     settings.login_shell = TRUE;
518     }
519    
520     }
521     else if (_stricmp(head, "HOME_CHDIR") == 0) {
522     if (strchr("YyTt", *body)) {
523     settings.home_chdir = TRUE;
524     }
525    
526     }
527     else if (_stricmp(head, "SSH_AGENT_PROXY") == 0) {
528     if (strchr("YyTt", *body)) {
529     settings.agent_proxy = TRUE;
530     }
531    
532     }
533     else {
534     // TODO: error check
535    
536     }
537     }
538     fclose(fp);
539     }
540    
541     memcpy(&ts->CygtermSettings, &settings, sizeof(cygterm_t));
542     }
543    
544     static void WriteCygtermConfFile(PTTSet ts)
545     {
546     char *cfgfile = CYGTERM_FILE; // CygTerm configuration file
547     char *tmpfile = "cygterm.tmp";
548     char cfg[MAX_PATH];
549     char tmp[MAX_PATH];
550     FILE *fp;
551     FILE *tmp_fp;
552     char buf[256], *head, *body;
553     char uimsg[MAX_UIMSG];
554     cygterm_t settings;
555 yutakapon 6126 char *line[CYGTERM_FILE_MAXLINE];
556 zmatsuo 9242 int i, linenum;
557 yutakapon 6119
558     // Cygwin���������X�������������������A�t�@�C�����������������B
559     if (ts->CygtermSettings.update_flag == FALSE)
560     return;
561     // �t���O���������ASave setup�����x�����x�������������������������B
562     ts->CygtermSettings.update_flag = FALSE;
563    
564     memcpy(&settings, &ts->CygtermSettings, sizeof(cygterm_t));
565    
566     strncpy_s(cfg, sizeof(cfg), ts->HomeDir, _TRUNCATE);
567     AppendSlash(cfg, sizeof(cfg));
568     strncat_s(cfg, sizeof(cfg), cfgfile, _TRUNCATE);
569    
570     strncpy_s(tmp, sizeof(tmp), ts->HomeDir, _TRUNCATE);
571     AppendSlash(tmp, sizeof(tmp));
572     strncat_s(tmp, sizeof(tmp), tmpfile, _TRUNCATE);
573    
574 yutakapon 6126 // cygterm.cfg �������������A�������������������������������B
575     memset(line, 0, sizeof(line));
576     linenum = 0;
577 yutakapon 6119 fp = fopen(cfg, "r");
578 yutakapon 6126 if (fp) {
579     i = 0;
580     while (fgets(buf, sizeof(buf), fp) != NULL) {
581 zmatsuo 9242 size_t len = strlen(buf);
582 yutakapon 6126 if (buf[len - 1] == '\n')
583     buf[len - 1] = '\0';
584     if (i < CYGTERM_FILE_MAXLINE)
585 yutakapon 6127 line[i++] = _strdup(buf);
586 yutakapon 6126 else
587     break;
588     }
589     linenum = i;
590     fclose(fp);
591     }
592    
593     tmp_fp = fopen(cfg, "w");
594 yutakapon 6119 if (tmp_fp == NULL) {
595     get_lang_msg("MSG_ERROR", uimsg, sizeof(uimsg), "ERROR", ts->UILanguageFile);
596     get_lang_msg("MSG_CYGTERM_CONF_WRITEFILE_ERROR", ts->UIMsg, sizeof(ts->UIMsg),
597     "Can't write CygTerm configuration file (%d).", ts->UILanguageFile);
598     _snprintf_s(buf, sizeof(buf), _TRUNCATE, ts->UIMsg, GetLastError());
599     MessageBox(NULL, buf, uimsg, MB_ICONEXCLAMATION);
600     }
601     else {
602 yutakapon 6126 if (linenum > 0) {
603     for (i = 0; i < linenum; i++) {
604     split_buffer(line[i], '=', &head, &body);
605 yutakapon 6119 if (head == NULL || body == NULL) {
606 yutakapon 6126 fprintf(tmp_fp, "%s\n", line[i]);
607 yutakapon 6119 }
608     else if (_stricmp(head, "TERM") == 0) {
609     fprintf(tmp_fp, "TERM = %s\n", settings.term);
610     settings.term[0] = '\0';
611     }
612     else if (_stricmp(head, "TERM_TYPE") == 0) {
613     fprintf(tmp_fp, "TERM_TYPE = %s\n", settings.term_type);
614     settings.term_type[0] = '\0';
615     }
616     else if (_stricmp(head, "PORT_START") == 0) {
617     fprintf(tmp_fp, "PORT_START = %s\n", settings.port_start);
618     settings.port_start[0] = '\0';
619     }
620     else if (_stricmp(head, "PORT_RANGE") == 0) {
621     fprintf(tmp_fp, "PORT_RANGE = %s\n", settings.port_range);
622     settings.port_range[0] = '\0';
623     }
624     else if (_stricmp(head, "SHELL") == 0) {
625     fprintf(tmp_fp, "SHELL = %s\n", settings.shell);
626     settings.shell[0] = '\0';
627     }
628     else if (_stricmp(head, "ENV_1") == 0) {
629     fprintf(tmp_fp, "ENV_1 = %s\n", settings.env1);
630     settings.env1[0] = '\0';
631     }
632     else if (_stricmp(head, "ENV_2") == 0) {
633     fprintf(tmp_fp, "ENV_2 = %s\n", settings.env2);
634     settings.env2[0] = '\0';
635     }
636     else if (_stricmp(head, "LOGIN_SHELL") == 0) {
637     fprintf(tmp_fp, "LOGIN_SHELL = %s\n", (settings.login_shell == TRUE) ? "yes" : "no");
638     settings.login_shell = FALSE;
639     }
640     else if (_stricmp(head, "HOME_CHDIR") == 0) {
641     fprintf(tmp_fp, "HOME_CHDIR = %s\n", (settings.home_chdir == TRUE) ? "yes" : "no");
642     settings.home_chdir = FALSE;
643     }
644     else if (_stricmp(head, "SSH_AGENT_PROXY") == 0) {
645     fprintf(tmp_fp, "SSH_AGENT_PROXY = %s\n", (settings.agent_proxy == TRUE) ? "yes" : "no");
646     settings.agent_proxy = FALSE;
647     }
648     else {
649     fprintf(tmp_fp, "%s = %s\n", head, body);
650     }
651     }
652     }
653     else {
654     fputs("# CygTerm setting\n", tmp_fp);
655     fputs("\n", tmp_fp);
656     }
657     if (settings.term[0] != '\0') {
658     fprintf(tmp_fp, "TERM = %s\n", settings.term);
659     }
660     if (settings.term_type[0] != '\0') {
661     fprintf(tmp_fp, "TERM_TYPE = %s\n", settings.term_type);
662     }
663     if (settings.port_start[0] != '\0') {
664     fprintf(tmp_fp, "PORT_START = %s\n", settings.port_start);
665     }
666     if (settings.port_range[0] != '\0') {
667     fprintf(tmp_fp, "PORT_RANGE = %s\n", settings.port_range);
668     }
669     if (settings.shell[0] != '\0') {
670     fprintf(tmp_fp, "SHELL = %s\n", settings.shell);
671     }
672     if (settings.env1[0] != '\0') {
673     fprintf(tmp_fp, "ENV_1 = %s\n", settings.env1);
674     }
675     if (settings.env2[0] != '\0') {
676     fprintf(tmp_fp, "ENV_2 = %s\n", settings.env2);
677     }
678     if (settings.login_shell) {
679     fprintf(tmp_fp, "LOGIN_SHELL = yes\n");
680     }
681     if (settings.home_chdir) {
682     fprintf(tmp_fp, "HOME_CHDIR = yes\n");
683     }
684     if (settings.agent_proxy) {
685     fprintf(tmp_fp, "SSH_AGENT_PROXY = yes\n");
686     }
687     fclose(tmp_fp);
688    
689 yutakapon 6126 // �_�C���N�g���t�@�C���������������������������A���L�������s�v�B
690     #if 0
691 yutakapon 6119 if (remove(cfg) != 0 && errno != ENOENT) {
692     get_lang_msg("MSG_ERROR", uimsg, sizeof(uimsg), "ERROR", ts->UILanguageFile);
693     get_lang_msg("MSG_CYGTERM_CONF_REMOVEFILE_ERROR", ts->UIMsg, sizeof(ts->UIMsg),
694     "Can't remove old CygTerm configuration file (%d).", ts->UILanguageFile);
695     _snprintf_s(buf, sizeof(buf), _TRUNCATE, ts->UIMsg, GetLastError());
696     MessageBox(NULL, buf, uimsg, MB_ICONEXCLAMATION);
697     }
698     else if (rename(tmp, cfg) != 0) {
699     get_lang_msg("MSG_ERROR", uimsg, sizeof(uimsg), "ERROR", ts->UILanguageFile);
700     get_lang_msg("MSG_CYGTERM_CONF_RENAMEFILE_ERROR", ts->UIMsg, sizeof(ts->UIMsg),
701     "Can't rename CygTerm configuration file (%d).", ts->UILanguageFile);
702     _snprintf_s(buf, sizeof(buf), _TRUNCATE, ts->UIMsg, GetLastError());
703     MessageBox(NULL, buf, uimsg, MB_ICONEXCLAMATION);
704     }
705     else {
706     // cygterm.cfg �t�@�C�����������������������A���b�Z�[�W�_�C�A���O���\�������B
707     // �������ASave setup�����s�����K�v�������������������N�����B
708     // (2012.5.1 yutaka)
709     // Save setup ���s�����ACygTerm�������������������������������������A
710     // �_�C�A���O�\�����s�v�����������A���������B
711     // (2015.11.12 yutaka)
712     get_lang_msg("MSG_TT_NOTICE", uimsg, sizeof(uimsg), "MSG_TT_NOTICE", ts->UILanguageFile);
713     get_lang_msg("MSG_CYGTERM_CONF_SAVED_NOTICE", ts->UIMsg, sizeof(ts->UIMsg),
714     "%s has been saved. Do not do save setup.", ts->UILanguageFile);
715     _snprintf_s(buf, sizeof(buf), _TRUNCATE, ts->UIMsg, CYGTERM_FILE);
716     MessageBox(NULL, buf, uimsg, MB_OK | MB_ICONINFORMATION);
717 yutakapon 6126 }
718 yutakapon 6119 #endif
719     }
720 yutakapon 6126
721     // �Y�������������t���[���������B
722     for (i = 0; i < linenum; i++) {
723     free(line[i]);
724     }
725    
726 yutakapon 6119 }
727    
728 zmatsuo 9429 void PASCAL ReadIniFile(const wchar_t *FName, PTTSet ts)
729 maya 3227 {
730     int i;
731     HDC TmpDC;
732 doda 8386 char Temp[MAX_PATH], Temp2[MAX_PATH], *p;
733 zmatsuo 9436 wchar_t TempW[MAX_PATH];
734 maya 3227
735     ts->Minimize = 0;
736     ts->HideWindow = 0;
737     ts->LogFlag = 0; // Log flags
738     ts->FTFlag = 0; // File transfer flags
739     ts->MenuFlag = 0; // Menu flags
740     ts->TermFlag = 0; // Terminal flag
741     ts->ColorFlag = 0; // ANSI/Attribute color flags
742 doda 3666 ts->FontFlag = 0; // Font flag
743 maya 3227 ts->PortFlag = 0; // Port flags
744 doda 3485 ts->WindowFlag = 0; // Window flags
745 doda 4700 ts->CtrlFlag = 0; // Control sequence flags
746 doda 6594 ts->PasteFlag = 0; // Clipboard Paste flags
747 maya 3227 ts->TelPort = 23;
748    
749 doda 3388 ts->DisableTCPEchoCR = FALSE;
750    
751 doda 8386 /*
752     * Version number
753     * �����t�@�C���������o�[�W������ Tera Term �����������������\��
754     * �����t�@�C�����������������l���������A������ Tera Term ���o�[�W�������g������
755     */
756     GetPrivateProfileString(Section, "Version", TT_VERSION_STR("."), Temp, sizeof(Temp), FName);
757     p = strchr(Temp, '.');
758     if (p) {
759     *p++ = 0;
760     ts->ConfigVersion = atoi(Temp) * 10000 + atoi(p);
761     }
762     else {
763     ts->ConfigVersion = 0;
764     }
765 maya 3227
766 doda 8387 // TTX �� �m�F�����������ATera Term ���o�[�W�������i�[��������
767     ts->RunningVersion = TT_VERSION_MAJOR * 10000 + TT_VERSION_MINOR;
768    
769 maya 3227 /* Language */
770     GetPrivateProfileString(Section, "Language", "",
771     Temp, sizeof(Temp), FName);
772 zmatsuo 9499 if (Temp[0] != 0) {
773     ts->Language = GetLanguageFromStr(Temp);
774     }
775 maya 3227 else {
776     switch (PRIMARYLANGID(GetSystemDefaultLangID())) {
777     case LANG_JAPANESE:
778     ts->Language = IdJapanese;
779     break;
780     case LANG_RUSSIAN:
781     ts->Language = IdRussian;
782     break;
783 doda 3354 case LANG_KOREAN: // HKS
784 doda 6435 ts->Language = IdKorean;
785     break;
786 maya 3227 default:
787     ts->Language = IdEnglish;
788     }
789     }
790    
791     /* Port type */
792     GetPrivateProfileString(Section, "Port", "",
793     Temp, sizeof(Temp), FName);
794 doda 6696 if (_stricmp(Temp, "serial") == 0)
795 maya 3227 ts->PortType = IdSerial;
796     else {
797     ts->PortType = IdTCPIP;
798     }
799    
800     /* VT win position */
801     GetPrivateProfileString(Section, "VTPos", "-2147483648,-2147483648", Temp, sizeof(Temp), FName); /* default: random position */
802     GetNthNum(Temp, 1, (int far *) (&ts->VTPos.x));
803     GetNthNum(Temp, 2, (int far *) (&ts->VTPos.y));
804    
805     /* TEK win position */
806     GetPrivateProfileString(Section, "TEKPos", "-2147483648,-2147483648", Temp, sizeof(Temp), FName); /* default: random position */
807     GetNthNum(Temp, 1, (int far *) &(ts->TEKPos.x));
808     GetNthNum(Temp, 2, (int far *) &(ts->TEKPos.y));
809    
810     /* Save VT Window position */
811     ts->SaveVTWinPos = GetOnOff(Section, "SaveVTWinPos", FName, FALSE);
812    
813     /* VT terminal size */
814     GetPrivateProfileString(Section, "TerminalSize", "80,24",
815     Temp, sizeof(Temp), FName);
816     GetNthNum(Temp, 1, &ts->TerminalWidth);
817     GetNthNum(Temp, 2, &ts->TerminalHeight);
818 doda 6784 if (ts->TerminalWidth <= 0)
819     ts->TerminalWidth = 80;
820     else if (ts->TerminalWidth > TermWidthMax)
821     ts->TerminalWidth = TermWidthMax;
822     if (ts->TerminalHeight <= 0)
823     ts->TerminalHeight = 24;
824     else if (ts->TerminalHeight > TermHeightMax)
825     ts->TerminalHeight = TermHeightMax;
826 maya 3227
827     /* Terminal size = Window size */
828     ts->TermIsWin = GetOnOff(Section, "TermIsWin", FName, FALSE);
829    
830     /* Auto window resize flag */
831     ts->AutoWinResize = GetOnOff(Section, "AutoWinResize", FName, FALSE);
832    
833     /* CR Receive */
834     GetPrivateProfileString(Section, "CRReceive", "",
835     Temp, sizeof(Temp), FName);
836     if (_stricmp(Temp, "CRLF") == 0) {
837     ts->CRReceive = IdCRLF;
838     }
839     else if (_stricmp(Temp, "LF") == 0) {
840     ts->CRReceive = IdLF;
841     }
842 maya 4893 else if (_stricmp(Temp, "AUTO") == 0) {
843     ts->CRReceive = IdAUTO;
844     }
845 maya 3227 else {
846     ts->CRReceive = IdCR;
847     }
848     /* CR Send */
849     GetPrivateProfileString(Section, "CRSend", "",
850     Temp, sizeof(Temp), FName);
851 maya 6369 if (_stricmp(Temp, "CRLF") == 0) {
852 maya 3227 ts->CRSend = IdCRLF;
853 maya 6369 }
854     else if (_stricmp(Temp, "LF") == 0) {
855     ts->CRSend = IdLF;
856     }
857     else {
858 maya 3227 ts->CRSend = IdCR;
859 maya 6369 }
860 maya 3227 ts->CRSend_ini = ts->CRSend;
861    
862     /* Local echo */
863     ts->LocalEcho = GetOnOff(Section, "LocalEcho", FName, FALSE);
864     ts->LocalEcho_ini = ts->LocalEcho;
865    
866     /* Answerback */
867     GetPrivateProfileString(Section, "Answerback", "", Temp,
868     sizeof(Temp), FName);
869     ts->AnswerbackLen =
870     Hex2Str(Temp, ts->Answerback, sizeof(ts->Answerback));
871    
872     /* Kanji Code (receive) */
873     GetPrivateProfileString(Section, "KanjiReceive", "",
874     Temp, sizeof(Temp), FName);
875 zmatsuo 9499 ts->KanjiCode = GetKanjiCodeFromStr(ts->Language, Temp);
876 maya 3227
877     /* Katakana (receive) */
878     GetPrivateProfileString(Section, "KatakanaReceive", "",
879     Temp, sizeof(Temp), FName);
880     if (_stricmp(Temp, "7") == 0)
881     ts->JIS7Katakana = 1;
882     else
883     ts->JIS7Katakana = 0;
884    
885     /* Kanji Code (transmit) */
886     GetPrivateProfileString(Section, "KanjiSend", "",
887     Temp, sizeof(Temp), FName);
888 zmatsuo 9499 ts->KanjiCodeSend = GetKanjiCodeFromStr(ts->Language, Temp);
889 maya 3227
890     /* Katakana (receive) */
891     GetPrivateProfileString(Section, "KatakanaSend", "",
892     Temp, sizeof(Temp), FName);
893     if (_stricmp(Temp, "7") == 0)
894     ts->JIS7KatakanaSend = 1;
895     else
896     ts->JIS7KatakanaSend = 0;
897    
898     /* KanjiIn */
899     GetPrivateProfileString(Section, "KanjiIn", "",
900     Temp, sizeof(Temp), FName);
901     if (_stricmp(Temp, "@") == 0)
902     ts->KanjiIn = IdKanjiInA;
903     else
904     ts->KanjiIn = IdKanjiInB;
905    
906     /* KanjiOut */
907     GetPrivateProfileString(Section, "KanjiOut", "",
908     Temp, sizeof(Temp), FName);
909     if (_stricmp(Temp, "B") == 0)
910     ts->KanjiOut = IdKanjiOutB;
911     else if (_stricmp(Temp, "H") == 0)
912     ts->KanjiOut = IdKanjiOutH;
913     else
914     ts->KanjiOut = IdKanjiOutJ;
915    
916     /* Auto Win Switch VT<->TEK */
917     ts->AutoWinSwitch = GetOnOff(Section, "AutoWinSwitch", FName, FALSE);
918    
919     /* Terminal ID */
920     GetPrivateProfileString(Section, "TerminalID", "",
921     Temp, sizeof(Temp), FName);
922     ts->TerminalID = str2id(TermList, Temp, IdVT100);
923    
924     /* Title String */
925     GetPrivateProfileString(Section, "Title", "Tera Term",
926     ts->Title, sizeof(ts->Title), FName);
927    
928     /* Cursor shape */
929     GetPrivateProfileString(Section, "CursorShape", "",
930     Temp, sizeof(Temp), FName);
931     if (_stricmp(Temp, "vertical") == 0)
932     ts->CursorShape = IdVCur;
933     else if (_stricmp(Temp, "horizontal") == 0)
934     ts->CursorShape = IdHCur;
935     else
936     ts->CursorShape = IdBlkCur;
937    
938     /* Hide title */
939     ts->HideTitle = GetOnOff(Section, "HideTitle", FName, FALSE);
940    
941     /* Popup menu */
942     ts->PopupMenu = GetOnOff(Section, "PopupMenu", FName, FALSE);
943    
944     /* PC-Style bold color mapping */
945     if (GetOnOff(Section, "PcBoldColor", FName, FALSE))
946     ts->ColorFlag |= CF_PCBOLD16;
947    
948     /* aixterm style 16 colors mode */
949     if (GetOnOff(Section, "Aixterm16Color", FName, FALSE))
950     ts->ColorFlag |= CF_AIXTERM16;
951    
952     /* xterm style 256 colors mode */
953     if (GetOnOff(Section, "Xterm256Color", FName, TRUE))
954     ts->ColorFlag |= CF_XTERM256;
955    
956     /* Enable scroll buffer */
957     ts->EnableScrollBuff =
958     GetOnOff(Section, "EnableScrollBuff", FName, TRUE);
959    
960     /* Scroll buffer size */
961     ts->ScrollBuffSize =
962     GetPrivateProfileInt(Section, "ScrollBuffSize", 100, FName);
963    
964     /* VT Color */
965     GetPrivateProfileString(Section, "VTColor", "0,0,0,255,255,255",
966     Temp, sizeof(Temp), FName);
967     for (i = 0; i <= 5; i++)
968     GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
969     for (i = 0; i <= 1; i++)
970     ts->VTColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
971     (BYTE) ts->TmpColor[0][i * 3 + 1],
972     (BYTE) ts->TmpColor[0][i * 3 + 2]);
973    
974     /* VT Bold Color */
975     GetPrivateProfileString(Section, "VTBoldColor", "0,0,255,255,255,255",
976     Temp, sizeof(Temp), FName);
977     for (i = 0; i <= 5; i++)
978     GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
979     for (i = 0; i <= 1; i++)
980     ts->VTBoldColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
981     (BYTE) ts->TmpColor[0][i * 3 + 1],
982     (BYTE) ts->TmpColor[0][i * 3 + 2]);
983     if (GetOnOff(Section, "EnableBoldAttrColor", FName, TRUE))
984     ts->ColorFlag |= CF_BOLDCOLOR;
985    
986     /* VT Blink Color */
987     GetPrivateProfileString(Section, "VTBlinkColor", "255,0,0,255,255,255",
988     Temp, sizeof(Temp), FName);
989     for (i = 0; i <= 5; i++)
990     GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
991     for (i = 0; i <= 1; i++)
992     ts->VTBlinkColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
993     (BYTE) ts->TmpColor[0][i * 3 + 1],
994     (BYTE) ts->TmpColor[0][i * 3 + 2]);
995     if (GetOnOff(Section, "EnableBlinkAttrColor", FName, TRUE))
996     ts->ColorFlag |= CF_BLINKCOLOR;
997    
998     /* VT Reverse Color */
999     GetPrivateProfileString(Section, "VTReverseColor", "255,255,255,0,0,0",
1000     Temp, sizeof(Temp), FName);
1001     for (i = 0; i <= 5; i++)
1002     GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
1003     for (i = 0; i <= 1; i++)
1004     ts->VTReverseColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
1005     (BYTE) ts->TmpColor[0][i * 3 + 1],
1006     (BYTE) ts->TmpColor[0][i * 3 + 2]);
1007     if (GetOnOff(Section, "EnableReverseAttrColor", FName, FALSE))
1008     ts->ColorFlag |= CF_REVERSECOLOR;
1009    
1010     ts->EnableClickableUrl =
1011     GetOnOff(Section, "EnableClickableUrl", FName, FALSE);
1012    
1013     /* URL Color */
1014     GetPrivateProfileString(Section, "URLColor", "0,255,0,255,255,255",
1015     Temp, sizeof(Temp), FName);
1016     for (i = 0; i <= 5; i++)
1017     GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
1018     for (i = 0; i <= 1; i++)
1019     ts->URLColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
1020     (BYTE) ts->TmpColor[0][i * 3 + 1],
1021     (BYTE) ts->TmpColor[0][i * 3 + 2]);
1022     if (GetOnOff(Section, "EnableURLColor", FName, TRUE))
1023     ts->ColorFlag |= CF_URLCOLOR;
1024    
1025 doda 3660 if (GetOnOff(Section, "URLUnderline", FName, TRUE))
1026 doda 3666 ts->FontFlag |= FF_URLUNDERLINE;
1027 doda 3660
1028 maya 3227 /* TEK Color */
1029     GetPrivateProfileString(Section, "TEKColor", "0,0,0,255,255,255",
1030     Temp, sizeof(Temp), FName);
1031     for (i = 0; i <= 5; i++)
1032     GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
1033     for (i = 0; i <= 1; i++)
1034     ts->TEKColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
1035     (BYTE) ts->TmpColor[0][i * 3 + 1],
1036     (BYTE) ts->TmpColor[0][i * 3 + 2]);
1037    
1038     /* ANSI color definition (in the case FullColor=on) -- special option
1039     o UseTextColor should be off, or the background and foreground color of
1040     VTColor are assigned to color-number 0 and 7 respectively, even if
1041     they are specified in ANSIColor.
1042     o ANSIColor is a set of 4 values that are color-number(0--15),
1043     red-value(0--255), green-value(0--255) and blue-value(0--255). */
1044     GetPrivateProfileString(Section, "ANSIColor",
1045     " 0, 0, 0, 0,"
1046     " 1,255, 0, 0,"
1047     " 2, 0,255, 0,"
1048     " 3,255,255, 0,"
1049     " 4, 0, 0,255,"
1050     " 5,255, 0,255,"
1051     " 6, 0,255,255,"
1052     " 7,255,255,255,"
1053     " 8,128,128,128,"
1054     " 9,128, 0, 0,"
1055     "10, 0,128, 0,"
1056     "11,128,128, 0,"
1057     "12, 0, 0,128,"
1058     "13,128, 0,128,"
1059     "14, 0,128,128,"
1060     "15,192,192,192", Temp, sizeof(Temp), FName);
1061     {
1062     char *t;
1063     int n = 1;
1064     for (t = Temp; *t; t++)
1065     if (*t == ',')
1066     n++;
1067     n /= 4;
1068 doda 4640 for (i = 0; i < n; i++) {
1069 maya 3227 int colorid, r, g, b;
1070     GetNthNum(Temp, i * 4 + 1, (int far *) &colorid);
1071     GetNthNum(Temp, i * 4 + 2, (int far *) &r);
1072     GetNthNum(Temp, i * 4 + 3, (int far *) &g);
1073     GetNthNum(Temp, i * 4 + 4, (int far *) &b);
1074     ts->ANSIColor[colorid & 15] =
1075     RGB((BYTE) r, (BYTE) g, (BYTE) b);
1076     }
1077     }
1078    
1079     TmpDC = GetDC(0); /* Get screen device context */
1080     for (i = 0; i <= 1; i++)
1081     ts->VTColor[i] = GetNearestColor(TmpDC, ts->VTColor[i]);
1082     for (i = 0; i <= 1; i++)
1083     ts->VTBoldColor[i] = GetNearestColor(TmpDC, ts->VTBoldColor[i]);
1084     for (i = 0; i <= 1; i++)
1085     ts->VTBlinkColor[i] = GetNearestColor(TmpDC, ts->VTBlinkColor[i]);
1086     for (i = 0; i <= 1; i++)
1087     ts->TEKColor[i] = GetNearestColor(TmpDC, ts->TEKColor[i]);
1088     /* begin - ishizaki */
1089     for (i = 0; i <= 1; i++)
1090     ts->URLColor[i] = GetNearestColor(TmpDC, ts->URLColor[i]);
1091     /* end - ishizaki */
1092     for (i = 0; i < 16; i++)
1093     ts->ANSIColor[i] = GetNearestColor(TmpDC, ts->ANSIColor[i]);
1094     ReleaseDC(0, TmpDC);
1095     if (GetOnOff(Section, "EnableANSIColor", FName, TRUE))
1096     ts->ColorFlag |= CF_ANSICOLOR;
1097    
1098     /* TEK color emulation */
1099     ts->TEKColorEmu = GetOnOff(Section, "TEKColorEmulation", FName, FALSE);
1100    
1101     /* VT Font */
1102 zmatsuo 7705 ReadFont(Section, "VTFont", "Terminal,0,-13,1", FName,
1103     ts->VTFont, _countof(ts->VTFont),
1104     &ts->VTFontSize, &(ts->VTFontCharSet));
1105 maya 3227
1106     /* Bold font flag */
1107 doda 3666 if (GetOnOff(Section, "EnableBold", FName, TRUE))
1108     ts->FontFlag |= FF_BOLD;
1109 maya 3227
1110     /* TEK Font */
1111 zmatsuo 7705 ReadFont(Section, "TEKFont", "Courier,0,-13,0", FName,
1112     ts->TEKFont, _countof(ts->TEKFont),
1113     &ts->TEKFontSize, &(ts->TEKFontCharSet));
1114 maya 3227
1115     /* BS key */
1116     GetPrivateProfileString(Section, "BSKey", "",
1117     Temp, sizeof(Temp), FName);
1118     if (_stricmp(Temp, "DEL") == 0)
1119     ts->BSKey = IdDEL;
1120     else
1121     ts->BSKey = IdBS;
1122     /* Delete key */
1123     ts->DelKey = GetOnOff(Section, "DeleteKey", FName, FALSE);
1124    
1125     /* Meta Key */
1126 doda 4414 GetPrivateProfileString(Section, "MetaKey", "off", Temp, sizeof(Temp), FName);
1127     if (_stricmp(Temp, "on") == 0)
1128     ts->MetaKey = IdMetaOn;
1129     else if (_stricmp(Temp, "left") == 0)
1130     ts->MetaKey = IdMetaLeft;
1131     else if (_stricmp(Temp, "right") == 0)
1132     ts->MetaKey = IdMetaRight;
1133     else
1134     ts->MetaKey = IdMetaOff;
1135 maya 3227
1136 doda 4414 // Windows95 �n�����E�� Alt ��������������
1137 yutakapon 6286 if (!IsWindowsNTKernel() && ts->MetaKey != IdMetaOff) {
1138 doda 4414 ts->MetaKey = IdMetaOn;
1139     }
1140    
1141 maya 3227 /* Application Keypad */
1142     ts->DisableAppKeypad =
1143     GetOnOff(Section, "DisableAppKeypad", FName, FALSE);
1144    
1145     /* Application Cursor */
1146     ts->DisableAppCursor =
1147     GetOnOff(Section, "DisableAppCursor", FName, FALSE);
1148    
1149     /* Russian keyboard type */
1150     GetPrivateProfileString(Section, "RussKeyb", "",
1151     Temp, sizeof(Temp), FName);
1152     ts->RussKeyb = str2id(RussList2, Temp, IdWindows);
1153    
1154     /* Serial port ID */
1155     ts->ComPort = GetPrivateProfileInt(Section, "ComPort", 1, FName);
1156    
1157     /* Baud rate */
1158 maya 3874 ts->Baud = GetPrivateProfileInt(Section, "BaudRate", 9600, FName);
1159 maya 3227
1160     /* Parity */
1161 zmatsuo 9436 GetPrivateProfileStringW(SectionW, L"Parity", L"",
1162     TempW, _countof(TempW), FName);
1163     if (!SerialPortConfconvertStr2Id(COM_PARITY, TempW, &ts->Parity)) {
1164 maya 3227 ts->Parity = IdParityNone;
1165 yutakapon 8205 }
1166 maya 3227
1167     /* Data bit */
1168 zmatsuo 9436 GetPrivateProfileStringW(SectionW, L"DataBit", L"",
1169     TempW, _countof(TempW), FName);
1170     if (!SerialPortConfconvertStr2Id(COM_DATABIT, TempW, &ts->DataBit)) {
1171 maya 3227 ts->DataBit = IdDataBit8;
1172 yutakapon 8205 }
1173 maya 3227
1174     /* Stop bit */
1175 zmatsuo 9436 GetPrivateProfileStringW(SectionW, L"StopBit", L"",
1176     TempW, _countof(TempW), FName);
1177     if (!SerialPortConfconvertStr2Id(COM_STOPBIT, TempW, &ts->StopBit)) {
1178 maya 3227 ts->StopBit = IdStopBit1;
1179 yutakapon 8205 }
1180 maya 3227
1181     /* Flow control */
1182 zmatsuo 9436 GetPrivateProfileStringW(SectionW, L"FlowCtrl", L"",
1183     TempW, _countof(TempW), FName);
1184     if (!SerialPortConfconvertStr2Id(COM_FLOWCTRL, TempW, &ts->Flow)) {
1185 maya 3227 ts->Flow = IdFlowNone;
1186 yutakapon 8205 }
1187 maya 3227
1188     /* Delay per character */
1189     ts->DelayPerChar =
1190     GetPrivateProfileInt(Section, "DelayPerChar", 0, FName);
1191    
1192     /* Delay per line */
1193     ts->DelayPerLine =
1194     GetPrivateProfileInt(Section, "DelayPerLine", 0, FName);
1195    
1196     /* Telnet flag */
1197     ts->Telnet = GetOnOff(Section, "Telnet", FName, TRUE);
1198    
1199     /* Telnet terminal type */
1200     GetPrivateProfileString(Section, "TermType", "xterm", ts->TermType,
1201     sizeof(ts->TermType), FName);
1202    
1203     /* TCP port num */
1204     ts->TCPPort =
1205     GetPrivateProfileInt(Section, "TCPPort", ts->TelPort, FName);
1206    
1207     /* Auto window close flag */
1208     ts->AutoWinClose = GetOnOff(Section, "AutoWinClose", FName, TRUE);
1209    
1210     /* History list */
1211     ts->HistoryList = GetOnOff(Section, "HistoryList", FName, FALSE);
1212    
1213     /* File transfer binary flag */
1214     ts->TransBin = GetOnOff(Section, "TransBin", FName, FALSE);
1215    
1216 doda 3887 /* Log binary flag */
1217     ts->LogBinary = GetOnOff(Section, "LogBinary", FName, FALSE);
1218    
1219 maya 3227 /* Log append */
1220     ts->Append = GetOnOff(Section, "LogAppend", FName, FALSE);
1221    
1222     /* Log plain text (2005.5.7 yutaka) */
1223     ts->LogTypePlainText =
1224     GetOnOff(Section, "LogTypePlainText", FName, FALSE);
1225    
1226     /* Log with timestamp (2006.7.23 maya) */
1227     ts->LogTimestamp = GetOnOff(Section, "LogTimestamp", FName, FALSE);
1228    
1229     /* Log without transfer dialog */
1230     ts->LogHideDialog = GetOnOff(Section, "LogHideDialog", FName, FALSE);
1231    
1232 yutakapon 5444 ts->LogAllBuffIncludedInFirst = GetOnOff(Section, "LogIncludeScreenBuffer", FName, FALSE);
1233 yutakapon 5392
1234 maya 6767 /* Timestamp format of Log each line */
1235 maya 6795 GetPrivateProfileString(Section, "LogTimestampFormat", "%Y-%m-%d %H:%M:%S.%N",
1236 maya 6767 ts->LogTimestampFormat, sizeof(ts->LogTimestampFormat),
1237     FName);
1238    
1239 doda 6947 /* Timestamp type */
1240     GetPrivateProfileString(Section, "LogTimestampType", "", Temp, sizeof(Temp), FName);
1241     if (_stricmp(Temp, "UTC") == 0)
1242     ts->LogTimestampType = TIMESTAMP_UTC;
1243     else if (_stricmp(Temp, "LoggingElapsed") == 0)
1244     ts->LogTimestampType = TIMESTAMP_ELAPSED_LOGSTART;
1245     else if (_stricmp(Temp, "ConnectionElapsed") == 0)
1246     ts->LogTimestampType = TIMESTAMP_ELAPSED_CONNECTED;
1247     else if (_stricmp(Temp, "") == 0 && GetOnOff(Section, "LogTimestampUTC", FName, FALSE))
1248     // LogTimestampType ���������������� LogTimestampUTC ���l���Q������
1249     ts->LogTimestampType = TIMESTAMP_UTC;
1250     else
1251     ts->LogTimestampType = TIMESTAMP_LOCAL;
1252 maya 6768
1253 doda 5312 /* File Transfer dialog visibility */
1254     ts->FTHideDialog = GetOnOff(Section, "FTHideDialog", FName, FALSE);
1255    
1256 maya 3227 /* Default Log file name (2006.8.28 maya) */
1257     GetPrivateProfileString(Section, "LogDefaultName", "teraterm.log",
1258     ts->LogDefaultName, sizeof(ts->LogDefaultName),
1259     FName);
1260    
1261     /* Default Log file path (2007.5.30 maya) */
1262     GetPrivateProfileString(Section, "LogDefaultPath", "",
1263     ts->LogDefaultPath, sizeof(ts->LogDefaultPath),
1264     FName);
1265    
1266     /* Auto start logging (2007.5.31 maya) */
1267     ts->LogAutoStart = GetOnOff(Section, "LogAutoStart", FName, FALSE);
1268    
1269 yutakapon 5171 /* Log Rotate (2013.3.24 yutaka) */
1270     ts->LogRotate = GetPrivateProfileInt(Section, "LogRotate", 0, FName);
1271     ts->LogRotateSize = GetPrivateProfileInt(Section, "LogRotateSize", 0, FName);
1272     ts->LogRotateSizeType = GetPrivateProfileInt(Section, "LogRotateSizeType", 0, FName);
1273     ts->LogRotateStep = GetPrivateProfileInt(Section, "LogRotateStep", 0, FName);
1274    
1275 yutakapon 5206 /* Deferred Log Write Mode (2013.4.20 yutaka) */
1276     ts->DeferredLogWriteMode = GetOnOff(Section, "DeferredLogWriteMode", FName, TRUE);
1277 yutakapon 5171
1278 yutakapon 5206
1279 maya 3227 /* XMODEM option */
1280     GetPrivateProfileString(Section, "XmodemOpt", "",
1281     Temp, sizeof(Temp), FName);
1282     if (_stricmp(Temp, "crc") == 0)
1283     ts->XmodemOpt = XoptCRC;
1284     else if (_stricmp(Temp, "1k") == 0)
1285 doda 6219 ts->XmodemOpt = Xopt1kCRC;
1286 doda 6328 else if (_stricmp(Temp, "1ksum") == 0)
1287     ts->XmodemOpt = Xopt1kCksum;
1288 maya 3227 else
1289     ts->XmodemOpt = XoptCheck;
1290    
1291     /* XMODEM binary file */
1292     ts->XmodemBin = GetOnOff(Section, "XmodemBin", FName, TRUE);
1293    
1294     /* XMODEM ���M�R�}���h (2007.12.21 yutaka) */
1295     GetPrivateProfileString(Section, "XModemRcvCommand", "",
1296     ts->XModemRcvCommand,
1297     sizeof(ts->XModemRcvCommand), FName);
1298    
1299     /* Default directory for file transfer */
1300 zmatsuo 9618 hGetPrivateProfileStringW(SectionW, L"FileDir", L"", FName, &ts->FileDirW);
1301     if (ts->FileDirW != NULL && ts->FileDirW[0] != 0) {
1302     wchar_t *FileDirExpanded;
1303     hExpandEnvironmentStringsW(ts->FileDirW, &FileDirExpanded);
1304 zmatsuo 9631 if (!DoesFolderExistW(FileDirExpanded)) {
1305     free(ts->FileDirW);
1306     ts->FileDirW = NULL;
1307 zmatsuo 9618 }
1308 zmatsuo 9631 free(FileDirExpanded);
1309 maya 3227 }
1310 zmatsuo 9618 if (ts->FileDirW == NULL || ts->FileDirW[0] == 0) {
1311 zmatsuo 9631 // �f�t�H���g�t�H���_���Z�b�g����
1312 zmatsuo 9618 free(ts->FileDirW);
1313     ts->FileDirW = GetDownloadFolderW();
1314     }
1315     WideCharToACP_t(ts->FileDirW, ts->FileDir, sizeof(ts->FileDir));
1316 maya 3227
1317     /* filter on file send (2007.6.5 maya) */
1318     GetPrivateProfileString(Section, "FileSendFilter", "",
1319     ts->FileSendFilter, sizeof(ts->FileSendFilter),
1320     FName);
1321    
1322 yutakapon 4880 /* SCP���M���p�X (2012.4.6 yutaka) */
1323 doda 6457 GetPrivateProfileString(Section, "ScpSendDir", "",
1324 yutakapon 4880 ts->ScpSendDir, sizeof(ts->ScpSendDir), FName);
1325    
1326    
1327 maya 3227 /*--------------------------------------------------*/
1328     /* 8 bit control code flag -- special option */
1329     if (GetOnOff(Section, "Accept8BitCtrl", FName, TRUE))
1330     ts->TermFlag |= TF_ACCEPT8BITCTRL;
1331    
1332     /* Wrong sequence flag -- special option */
1333     if (GetOnOff(Section, "AllowWrongSequence", FName, FALSE))
1334     ts->TermFlag |= TF_ALLOWWRONGSEQUENCE;
1335    
1336     if (((ts->TermFlag & TF_ALLOWWRONGSEQUENCE) == 0) &&
1337     (ts->KanjiOut == IdKanjiOutH))
1338     ts->KanjiOut = IdKanjiOutJ;
1339    
1340 maya 6083 // Detect disconnect/reconnect of serial port --- special option
1341 maya 6115 ts->AutoComPortReconnect = GetOnOff(Section, "AutoComPortReconnect", FName, TRUE);
1342 maya 6083
1343 maya 3227 // Auto file renaming --- special option
1344     if (GetOnOff(Section, "AutoFileRename", FName, FALSE))
1345     ts->FTFlag |= FT_RENAME;
1346    
1347     // Auto invoking (character set->G0->GL) --- special option
1348     if (GetOnOff(Section, "AutoInvoke", FName, FALSE))
1349     ts->TermFlag |= TF_AUTOINVOKE;
1350    
1351     // Auto text copy --- special option
1352     ts->AutoTextCopy = GetOnOff(Section, "AutoTextCopy", FName, TRUE);
1353    
1354     /* Back wrap -- special option */
1355     if (GetOnOff(Section, "BackWrap", FName, FALSE))
1356     ts->TermFlag |= TF_BACKWRAP;
1357    
1358     /* Beep type -- special option */
1359 doda 4082 GetPrivateProfileString(Section, "Beep", "", Temp, sizeof(Temp), FName);
1360 maya 3227 if (_stricmp(Temp, "off") == 0)
1361     ts->Beep = IdBeepOff;
1362     else if (_stricmp(Temp, "visual") == 0)
1363     ts->Beep = IdBeepVisual;
1364     else
1365     ts->Beep = IdBeepOn;
1366    
1367     /* Beep on connection & disconnection -- special option */
1368     if (GetOnOff(Section, "BeepOnConnect", FName, FALSE))
1369     ts->PortFlag |= PF_BEEPONCONNECT;
1370    
1371     /* Auto B-Plus activation -- special option */
1372     if (GetOnOff(Section, "BPAuto", FName, FALSE))
1373     ts->FTFlag |= FT_BPAUTO;
1374     if ((ts->FTFlag & FT_BPAUTO) != 0) { /* Answerback */
1375     strncpy_s(ts->Answerback, sizeof(ts->Answerback), "\020++\0200",
1376     _TRUNCATE);
1377     ts->AnswerbackLen = 5;
1378     }
1379    
1380     /* B-Plus ESCCTL flag -- special option */
1381     if (GetOnOff(Section, "BPEscCtl", FName, FALSE))
1382     ts->FTFlag |= FT_BPESCCTL;
1383    
1384     /* B-Plus log -- special option */
1385     if (GetOnOff(Section, "BPLog", FName, FALSE))
1386     ts->LogFlag |= LOG_BP;
1387    
1388     /* Clear serial port buffer when port opening -- special option */
1389     ts->ClearComBuffOnOpen =
1390     GetOnOff(Section, "ClearComBuffOnOpen", FName, TRUE);
1391    
1392 salarm 6349 /* When serial port is specified with with /C= option and the port does not exist, Tera Term will wait for port connection. */
1393     ts->WaitCom = GetOnOff(Section, "WaitCom", FName, FALSE);
1394    
1395 maya 3227 /* Confirm disconnection -- special option */
1396     if (GetOnOff(Section, "ConfirmDisconnect", FName, TRUE))
1397     ts->PortFlag |= PF_CONFIRMDISCONN;
1398    
1399     /* Ctrl code in Kanji -- special option */
1400     if (GetOnOff(Section, "CtrlInKanji", FName, TRUE))
1401     ts->TermFlag |= TF_CTRLINKANJI;
1402    
1403     /* Debug flag -- special option */
1404     ts->Debug = GetOnOff(Section, "Debug", FName, FALSE);
1405    
1406     /* Delimiter list -- special option */
1407     GetPrivateProfileString(Section, "DelimList",
1408     "$20!\"#$24%&\'()*+,-./:;<=>?@[\\]^`{|}~",
1409     Temp, sizeof(Temp), FName);
1410     Hex2Str(Temp, ts->DelimList, sizeof(ts->DelimList));
1411    
1412     /* regard DBCS characters as delimiters -- special option */
1413     ts->DelimDBCS = GetOnOff(Section, "DelimDBCS", FName, TRUE);
1414    
1415     // Enable popup menu -- special option
1416     if (!GetOnOff(Section, "EnablePopupMenu", FName, TRUE))
1417     ts->MenuFlag |= MF_NOPOPUP;
1418    
1419     // Enable "Show menu" -- special option
1420     if (!GetOnOff(Section, "EnableShowMenu", FName, TRUE))
1421     ts->MenuFlag |= MF_NOSHOWMENU;
1422    
1423     // Enable the status line -- special option
1424     if (GetOnOff(Section, "EnableStatusLine", FName, TRUE))
1425     ts->TermFlag |= TF_ENABLESLINE;
1426    
1427 maya 6079 // Enable multiple bytes send -- special option
1428 maya 6115 ts->FileSendHighSpeedMode = GetOnOff(Section, "FileSendHighSpeedMode", FName, TRUE);
1429 maya 6079
1430 maya 3227 // fixed JIS --- special
1431     if (GetOnOff(Section, "FixedJIS", FName, FALSE))
1432     ts->TermFlag |= TF_FIXEDJIS;
1433    
1434     /* IME Flag -- special option */
1435     ts->UseIME = GetOnOff(Section, "IME", FName, TRUE);
1436    
1437     /* IME-inline Flag -- special option */
1438     ts->IMEInline = GetOnOff(Section, "IMEInline", FName, TRUE);
1439    
1440     /* Kermit log -- special option */
1441     if (GetOnOff(Section, "KmtLog", FName, FALSE))
1442     ts->LogFlag |= LOG_KMT;
1443 yutakapon 4810 if (GetOnOff(Section, "KmtLongPacket", FName, FALSE))
1444     ts->KermitOpt |= KmtOptLongPacket;
1445     if (GetOnOff(Section, "KmtFileAttr", FName, FALSE))
1446     ts->KermitOpt |= KmtOptFileAttr;
1447 maya 3227
1448     // Enable language selection -- special option
1449     if (!GetOnOff(Section, "LanguageSelection", FName, TRUE))
1450     ts->MenuFlag |= MF_NOLANGUAGE;
1451    
1452     /* Maximum scroll buffer size -- special option */
1453     ts->ScrollBuffMax =
1454     GetPrivateProfileInt(Section, "MaxBuffSize", 10000, FName);
1455     if (ts->ScrollBuffMax < 24)
1456     ts->ScrollBuffMax = 10000;
1457    
1458     /* Max com port number -- special option */
1459 doda 6467 ts->MaxComPort = GetPrivateProfileInt(Section, "MaxComPort", 256, FName);
1460 maya 3227 if (ts->MaxComPort < 4)
1461     ts->MaxComPort = 4;
1462     if (ts->MaxComPort > MAXCOMPORT)
1463     ts->MaxComPort = MAXCOMPORT;
1464     if ((ts->ComPort < 1) || (ts->ComPort > ts->MaxComPort))
1465     ts->ComPort = 1;
1466    
1467     /* Non-blinking cursor -- special option */
1468     ts->NonblinkingCursor =
1469     GetOnOff(Section, "NonblinkingCursor", FName, FALSE);
1470    
1471     // �t�H�[�J�X���������|���S���J�[�\�� (2008.1.24 yutaka)
1472     ts->KillFocusCursor =
1473     GetOnOff(Section, "KillFocusCursor", FName, TRUE);
1474    
1475     /* Delay for pass-thru printing activation */
1476     /* -- special option */
1477     ts->PassThruDelay =
1478     GetPrivateProfileInt(Section, "PassThruDelay", 3, FName);
1479    
1480     /* Printer port for pass-thru printing */
1481     /* -- special option */
1482     GetPrivateProfileString(Section, "PassThruPort", "",
1483     ts->PrnDev, sizeof(ts->PrnDev), FName);
1484    
1485 doda 4397 /* �v�����^�p�����R�[�h�������t������ */
1486     if (GetOnOff(Section, "PrinterCtrlSequence", FName, TRUE))
1487     ts->TermFlag |= TF_PRINTERCTRL;
1488 yutakapon 4393
1489 maya 3227 /* Printer Font --- special option */
1490 zmatsuo 7705 ReadFont(Section, "PrnFont", NULL, FName,
1491     ts->PrnFont, _countof(ts->PrnFont),
1492     &ts->PrnFontSize, &(ts->PrnFontCharSet));
1493 maya 3227
1494     // Page margins (left, right, top, bottom) for printing
1495     // -- special option
1496     GetPrivateProfileString(Section, "PrnMargin", "50,50,50,50",
1497     Temp, sizeof(Temp), FName);
1498     for (i = 0; i <= 3; i++)
1499     GetNthNum(Temp, 1 + i, &ts->PrnMargin[i]);
1500    
1501 maya 6921 /* Disable (convert to NL) Form Feed when printing */
1502     /* --- special option */
1503     ts->PrnConvFF =
1504     GetOnOff(Section, "PrnConvFF", FName, FALSE);
1505    
1506 maya 3227 /* Quick-VAN log -- special option */
1507     if (GetOnOff(Section, "QVLog", FName, FALSE))
1508     ts->LogFlag |= LOG_QV;
1509    
1510     /* Quick-VAN window size -- special */
1511     ts->QVWinSize = GetPrivateProfileInt(Section, "QVWinSize", 8, FName);
1512    
1513     /* Scroll threshold -- special option */
1514     ts->ScrollThreshold =
1515     GetPrivateProfileInt(Section, "ScrollThreshold", 12, FName);
1516    
1517     ts->MouseWheelScrollLine =
1518     GetPrivateProfileInt(Section, "MouseWheelScrollLine", 3, FName);
1519    
1520     // Select on activate -- special option
1521     ts->SelOnActive = GetOnOff(Section, "SelectOnActivate", FName, TRUE);
1522    
1523     /* Send 8bit control sequence -- special option */
1524     ts->Send8BitCtrl = GetOnOff(Section, "Send8BitCtrl", FName, FALSE);
1525    
1526 maya 5694 /* SendBreak time (in msec) -- special option */
1527     ts->SendBreakTime =
1528     GetPrivateProfileInt(Section, "SendBreakTime", 1000, FName);
1529    
1530 maya 3227 /* Startup macro -- special option */
1531 zmatsuo 9306 hGetPrivateProfileStringW(SectionW, L"StartupMacro", L"", FName, &ts->MacroFNW);
1532     WideCharToACP_t(ts->MacroFNW, ts->MacroFN, sizeof(ts->MacroFN));
1533 maya 3227
1534     /* TEK GIN Mouse keycode -- special option */
1535     ts->GINMouseCode =
1536     GetPrivateProfileInt(Section, "TEKGINMouseCode", 32, FName);
1537    
1538     /* Telnet Auto Detect -- special option */
1539     ts->TelAutoDetect = GetOnOff(Section, "TelAutoDetect", FName, TRUE);
1540    
1541     /* Telnet binary flag -- special option */
1542     ts->TelBin = GetOnOff(Section, "TelBin", FName, FALSE);
1543    
1544     /* Telnet Echo flag -- special option */
1545     ts->TelEcho = GetOnOff(Section, "TelEcho", FName, FALSE);
1546    
1547     /* Telnet log -- special option */
1548     if (GetOnOff(Section, "TelLog", FName, FALSE))
1549     ts->LogFlag |= LOG_TEL;
1550    
1551     /* TCP port num for telnet -- special option */
1552     ts->TelPort = GetPrivateProfileInt(Section, "TelPort", 23, FName);
1553    
1554     /* Telnet keep-alive packet(NOP command) interval -- special option */
1555     ts->TelKeepAliveInterval =
1556     GetPrivateProfileInt(Section, "TelKeepAliveInterval", 300, FName);
1557    
1558     /* Max number of broadcast commad history */
1559     ts->MaxBroadcatHistory =
1560     GetPrivateProfileInt(Section, "MaxBroadcatHistory", 99, FName);
1561    
1562     /* Local echo for non-telnet */
1563     ts->TCPLocalEcho = GetOnOff(Section, "TCPLocalEcho", FName, FALSE);
1564    
1565     /* "new-line (transmit)" option for non-telnet -- special option */
1566     GetPrivateProfileString(Section, "TCPCRSend", "",
1567     Temp, sizeof(Temp), FName);
1568     if (_stricmp(Temp, "CR") == 0)
1569     ts->TCPCRSend = IdCR;
1570     else if (_stricmp(Temp, "CRLF") == 0)
1571     ts->TCPCRSend = IdCRLF;
1572     else
1573     ts->TCPCRSend = 0; // disabled
1574    
1575     /* Use text (background) color for "white (black)" --- special option */
1576     if (GetOnOff(Section, "UseTextColor", FName, FALSE))
1577     ts->ColorFlag |= CF_USETEXTCOLOR;
1578    
1579     /* Title format -- special option */
1580     ts->TitleFormat =
1581 maya 6170 GetPrivateProfileInt(Section, "TitleFormat", 13, FName);
1582 maya 3227
1583     /* VT Compatible Tab -- special option */
1584     ts->VTCompatTab = GetOnOff(Section, "VTCompatTab", FName, FALSE);
1585    
1586     /* VT Font space --- special option */
1587     GetPrivateProfileString(Section, "VTFontSpace", "0,0,0,0",
1588     Temp, sizeof(Temp), FName);
1589     GetNthNum(Temp, 1, &ts->FontDX);
1590     GetNthNum(Temp, 2, &ts->FontDW);
1591     GetNthNum(Temp, 3, &ts->FontDY);
1592     GetNthNum(Temp, 4, &ts->FontDH);
1593     if (ts->FontDX < 0)
1594     ts->FontDX = 0;
1595     if (ts->FontDW < 0)
1596     ts->FontDW = 0;
1597     ts->FontDW = ts->FontDW + ts->FontDX;
1598     if (ts->FontDY < 0)
1599     ts->FontDY = 0;
1600     if (ts->FontDH < 0)
1601     ts->FontDH = 0;
1602     ts->FontDH = ts->FontDH + ts->FontDY;
1603    
1604     // VT-print scaling factors (pixels per inch) --- special option
1605     GetPrivateProfileString(Section, "VTPPI", "0,0",
1606     Temp, sizeof(Temp), FName);
1607     GetNthNum(Temp, 1, (int far *) &ts->VTPPI.x);
1608     GetNthNum(Temp, 2, (int far *) &ts->VTPPI.y);
1609    
1610     // TEK-print scaling factors (pixels per inch) --- special option
1611     GetPrivateProfileString(Section, "TEKPPI", "0,0",
1612     Temp, sizeof(Temp), FName);
1613     GetNthNum(Temp, 1, (int far *) &ts->TEKPPI.x);
1614     GetNthNum(Temp, 2, (int far *) &ts->TEKPPI.y);
1615    
1616     // Show "Window" menu -- special option
1617     if (GetOnOff(Section, "WindowMenu", FName, TRUE))
1618     ts->MenuFlag |= MF_SHOWWINMENU;
1619    
1620     /* XMODEM log -- special option */
1621     if (GetOnOff(Section, "XmodemLog", FName, FALSE))
1622     ts->LogFlag |= LOG_X;
1623    
1624     /* YMODEM log -- special option */
1625     if (GetOnOff(Section, "YmodemLog", FName, FALSE))
1626     ts->LogFlag |= LOG_Y;
1627    
1628 yutakapon 3815 /* YMODEM ���M�R�}���h (2010.3.23 yutaka) */
1629     GetPrivateProfileString(Section, "YModemRcvCommand", "rb",
1630     ts->YModemRcvCommand, sizeof(ts->YModemRcvCommand), FName);
1631    
1632 maya 3227 /* Auto ZMODEM activation -- special option */
1633     if (GetOnOff(Section, "ZmodemAuto", FName, FALSE))
1634     ts->FTFlag |= FT_ZAUTO;
1635    
1636     /* ZMODEM data subpacket length for sending -- special */
1637     ts->ZmodemDataLen =
1638     GetPrivateProfileInt(Section, "ZmodemDataLen", 1024, FName);
1639     /* ZMODEM window size for sending -- special */
1640     ts->ZmodemWinSize =
1641     GetPrivateProfileInt(Section, "ZmodemWinSize", 32767, FName);
1642    
1643     /* ZMODEM ESCCTL flag -- special option */
1644     if (GetOnOff(Section, "ZmodemEscCtl", FName, FALSE))
1645     ts->FTFlag |= FT_ZESCCTL;
1646    
1647     /* ZMODEM log -- special option */
1648     if (GetOnOff(Section, "ZmodemLog", FName, FALSE))
1649     ts->LogFlag |= LOG_Z;
1650    
1651     /* ZMODEM ���M�R�}���h (2007.12.21 yutaka) */
1652     GetPrivateProfileString(Section, "ZModemRcvCommand", "rz",
1653     ts->ZModemRcvCommand, sizeof(ts->ZModemRcvCommand), FName);
1654    
1655     /* Enable continued-line copy -- special option */
1656     ts->EnableContinuedLineCopy =
1657     GetOnOff(Section, "EnableContinuedLineCopy", FName, FALSE);
1658    
1659 doda 6594 if (GetOnOff(Section, "DisablePasteMouseRButton", FName, FALSE))
1660     ts->PasteFlag |= CPF_DISABLE_RBUTTON;
1661 maya 3227
1662 doda 6594 if (GetOnOff(Section, "DisablePasteMouseMButton", FName, TRUE))
1663     ts->PasteFlag |= CPF_DISABLE_MBUTTON;
1664 maya 3227
1665 doda 6594 if (GetOnOff(Section, "ConfirmPasteMouseRButton", FName, FALSE))
1666     ts->PasteFlag |= CPF_CONFIRM_RBUTTON;
1667 maya 3227
1668 doda 6594 if (GetOnOff(Section, "ConfirmChangePaste", FName, TRUE))
1669     ts->PasteFlag |= CPF_CONFIRM_CHANGEPASTE;
1670    
1671     if (GetOnOff(Section, "ConfirmChangePasteCR", FName, TRUE))
1672     ts->PasteFlag |= CPF_CONFIRM_CHANGEPASTE_CR;
1673    
1674 yutakapon 3535 GetPrivateProfileString(Section, "ConfirmChangePasteStringFile", "",
1675     Temp, sizeof(Temp), FName);
1676 doda 6594
1677 yutakapon 3535 strncpy_s(ts->ConfirmChangePasteStringFile, sizeof(ts->ConfirmChangePasteStringFile), Temp,
1678     _TRUNCATE);
1679 maya 3227
1680     // added ScrollWindowClearScreen (2008.5.3 yutaka)
1681     ts->ScrollWindowClearScreen =
1682     GetOnOff(Section, "ScrollWindowClearScreen", FName, TRUE);
1683    
1684     // added SelectOnlyByLButton (2007.11.20 maya)
1685     ts->SelectOnlyByLButton =
1686     GetOnOff(Section, "SelectOnlyByLButton", FName, TRUE);
1687    
1688     // added DisableAcceleratorSendBreak (2007.3.17 maya)
1689     ts->DisableAcceleratorSendBreak =
1690     GetOnOff(Section, "DisableAcceleratorSendBreak", FName, FALSE);
1691    
1692     // WinSock connecting timeout value (2007.1.11 yutaka)
1693     ts->ConnectingTimeout =
1694     GetPrivateProfileInt(Section, "ConnectingTimeout", 0, FName);
1695    
1696 doda 6435 // mouse cursor
1697 maya 3227 GetPrivateProfileString(Section, "MouseCursor", "IBEAM",
1698     Temp, sizeof(Temp), FName);
1699     strncpy_s(ts->MouseCursorName, sizeof(ts->MouseCursorName), Temp,
1700     _TRUNCATE);
1701    
1702     // Translucent window
1703 zmatsuo 7390 ts->AlphaBlendInactive =
1704     GetPrivateProfileInt(Section, "AlphaBlend", 255, FName);
1705     ts->AlphaBlendInactive = max(0, ts->AlphaBlendInactive);
1706     ts->AlphaBlendInactive = min(255, ts->AlphaBlendInactive);
1707     ts->AlphaBlendActive =
1708 doda 7447 GetPrivateProfileInt(Section, "AlphaBlendActive", ts->AlphaBlendInactive, FName);
1709 zmatsuo 7390 ts->AlphaBlendActive = max(0, ts->AlphaBlendActive);
1710     ts->AlphaBlendActive = min(255, ts->AlphaBlendActive);
1711 maya 3227
1712     // Cygwin install path
1713     GetPrivateProfileString(Section, "CygwinDirectory ", "c:\\cygwin",
1714     Temp, sizeof(Temp), FName);
1715     strncpy_s(ts->CygwinDirectory, sizeof(ts->CygwinDirectory), Temp,
1716     _TRUNCATE);
1717    
1718     // Viewlog Editor path
1719 doda 4198 if (GetWindowsDirectory(Temp, sizeof(Temp)) + 13 < sizeof(Temp)) { // "\\notepad.exe"(12) + NUL(1)
1720     strncat_s(Temp, sizeof(Temp), "\\notepad.exe", _TRUNCATE);
1721     }
1722     else {
1723     Temp[0] = '\0';
1724     }
1725     GetPrivateProfileString(Section, "ViewlogEditor ", Temp,
1726     ts->ViewlogEditor, sizeof(ts->ViewlogEditor), FName);
1727 maya 3227
1728 zmatsuo 7674 // UI language message file (�����p�X)
1729 zmatsuo 9306 hGetPrivateProfileStringW(SectionW, L"UILanguageFile", NULL, FName, &ts->UILanguageFileW_ini);
1730 zmatsuo 9381 if (ts->UILanguageFileW_ini[0] == 0) {
1731     free(ts->UILanguageFileW_ini);
1732 zmatsuo 9318 ts->UILanguageFileW_ini = _wcsdup(L"lang\\Default.lng");
1733 zmatsuo 9306 }
1734     WideCharToACP_t(ts->UILanguageFileW_ini, ts->UILanguageFile_ini, sizeof(ts->UILanguageFile_ini));
1735 maya 3227
1736 zmatsuo 7674 // UI language message file (full path)
1737 zmatsuo 9501 ts->UILanguageFileW = GetUILanguageFileFullW(ts->ExeDirW, ts->UILanguageFileW_ini);
1738 zmatsuo 9306 WideCharToACP_t(ts->UILanguageFileW, ts->UILanguageFile, sizeof(ts->UILanguageFile));
1739 maya 3227
1740 zmatsuo 9306
1741 maya 3227 // Broadcast Command History (2007.3.3 maya)
1742     ts->BroadcastCommandHistory =
1743     GetOnOff(Section, "BroadcastCommandHistory", FName, FALSE);
1744    
1745     // 337: 2007/03/20 Accept Broadcast
1746     ts->AcceptBroadcast =
1747     GetOnOff(Section, "AcceptBroadcast", FName, TRUE);
1748    
1749     // Confirm send a file when drag and drop (2007.12.28 maya)
1750     ts->ConfirmFileDragAndDrop =
1751     GetOnOff(Section, "ConfirmFileDragAndDrop", FName, TRUE);
1752    
1753     // Translate mouse wheel to cursor key when application cursor mode
1754     ts->TranslateWheelToCursor =
1755     GetOnOff(Section, "TranslateWheelToCursor", FName, TRUE);
1756    
1757     // Display "New Connection" dialog on startup (2008.1.18 maya)
1758     ts->HostDialogOnStartup =
1759     GetOnOff(Section, "HostDialogOnStartup", FName, TRUE);
1760    
1761     // Mouse event tracking
1762     ts->MouseEventTracking =
1763     GetOnOff(Section, "MouseEventTracking", FName, TRUE);
1764    
1765     // Maximized bug tweak
1766 doda 6730 GetPrivateProfileString(Section, "MaximizedBugTweak", "2", Temp,
1767 doda 6671 sizeof(Temp), FName);
1768     if (_stricmp(Temp, "on") == 0) {
1769 doda 6730 ts->MaximizedBugTweak = 2;
1770 doda 6671 }
1771     else {
1772     ts->MaximizedBugTweak = atoi(Temp);
1773     }
1774 maya 3227
1775     // Convert Unicode symbol characters to DEC Special characters
1776     ts->UnicodeDecSpMapping =
1777     GetPrivateProfileInt(Section, "UnicodeToDecSpMapping", 3, FName);
1778    
1779     // VT Window Icon
1780     GetPrivateProfileString(Section, "VTIcon", "Default",
1781     Temp, sizeof(Temp), FName);
1782 zmatsuo 9436 ts->VTIcon = IconName2IconIdA(Temp);
1783 maya 3227
1784     // Tek Window Icon
1785     GetPrivateProfileString(Section, "TEKIcon", "Default",
1786     Temp, sizeof(Temp), FName);
1787 zmatsuo 9436 ts->TEKIcon = IconName2IconIdA(Temp);
1788 maya 3227
1789     // Unknown Unicode Character
1790     ts->UnknownUnicodeCharaAsWide =
1791     GetOnOff(Section, "UnknownUnicodeCharacterAsWide", FName, FALSE);
1792    
1793     #ifdef USE_NORMAL_BGCOLOR
1794     // UseNormalBGColor
1795     ts->UseNormalBGColor =
1796     GetOnOff(Section, "UseNormalBGColor", FName, FALSE);
1797     // 2006/03/11 by 337
1798     if (ts->UseNormalBGColor) {
1799     ts->VTBoldColor[1] =
1800     ts->VTBlinkColor[1] = ts->URLColor[1] = ts->VTColor[1];
1801     }
1802     #endif
1803    
1804     // AutoScrollOnlyInBottomLine
1805     ts->AutoScrollOnlyInBottomLine =
1806     GetOnOff(Section, "AutoScrollOnlyInBottomLine", FName, FALSE);
1807    
1808     // Accept remote-controlled window title changing
1809     GetPrivateProfileString(Section, "AcceptTitleChangeRequest", "overwrite",
1810     Temp, sizeof(Temp), FName);
1811     if (_stricmp(Temp, "overwrite") == 0 || _stricmp(Temp, "on") == 0)
1812     ts->AcceptTitleChangeRequest = IdTitleChangeRequestOverwrite;
1813     else if (_stricmp(Temp, "ahead") == 0)
1814     ts->AcceptTitleChangeRequest = IdTitleChangeRequestAhead;
1815     else if (_stricmp(Temp, "last") == 0)
1816     ts->AcceptTitleChangeRequest = IdTitleChangeRequestLast;
1817     else
1818     ts->AcceptTitleChangeRequest = IdTitleChangeRequestOff;
1819    
1820     // Size of paste confirm dialog
1821     GetPrivateProfileString(Section, "PasteDialogSize", "330,220",
1822     Temp, sizeof(Temp), FName);
1823     GetNthNum(Temp, 1, &ts->PasteDialogSize.cx);
1824     GetNthNum(Temp, 2, &ts->PasteDialogSize.cy);
1825     if (ts->PasteDialogSize.cx < 0)
1826     ts->PasteDialogSize.cx = 330;
1827     if (ts->PasteDialogSize.cy < 0)
1828     ts->PasteDialogSize.cy = 220;
1829    
1830     // Disable mouse event tracking when Control-Key is pressed.
1831     ts->DisableMouseTrackingByCtrl =
1832     GetOnOff(Section, "DisableMouseTrackingByCtrl", FName, TRUE);
1833    
1834     // Disable TranslateWheelToCursor setting when Control-Key is pressed.
1835     ts->DisableWheelToCursorByCtrl =
1836     GetOnOff(Section, "DisableWheelToCursorByCtrl", FName, TRUE);
1837    
1838     // Strict Key Mapping.
1839     ts->StrictKeyMapping =
1840     GetOnOff(Section, "StrictKeyMapping", FName, FALSE);
1841    
1842     // added Wait4allMacroCommand (2009.3.23 yutaka)
1843     ts->Wait4allMacroCommand =
1844     GetOnOff(Section, "Wait4allMacroCommand", FName, FALSE);
1845 maya 3279
1846 maya 3283 // added DisableMenuSendBreak (2009.4.6 maya)
1847     ts->DisableMenuSendBreak =
1848     GetOnOff(Section, "DisableMenuSendBreak", FName, FALSE);
1849 maya 3282
1850 maya 3283 // added ClearScreenOnCloseConnection (2009.4.6 maya)
1851     ts->ClearScreenOnCloseConnection =
1852     GetOnOff(Section, "ClearScreenOnCloseConnection", FName, FALSE);
1853    
1854     // added DisableAcceleratorDuplicateSession (2009.4.6 maya)
1855 maya 3282 ts->DisableAcceleratorDuplicateSession =
1856     GetOnOff(Section, "DisableAcceleratorDuplicateSession", FName, FALSE);
1857 maya 3306
1858 maya 5684 ts->AcceleratorNewConnection =
1859     GetOnOff(Section, "AcceleratorNewConnection", FName, TRUE);
1860    
1861     ts->AcceleratorCygwinConnection =
1862     GetOnOff(Section, "AcceleratorCygwinConnection", FName, TRUE);
1863    
1864 maya 3964 // added DisableMenuDuplicateSession (2010.8.3 maya)
1865     ts->DisableMenuDuplicateSession =
1866     GetOnOff(Section, "DisableMenuDuplicateSession", FName, FALSE);
1867    
1868 maya 3965 // added DisableMenuNewConnection (2010.8.4 maya)
1869     ts->DisableMenuNewConnection =
1870     GetOnOff(Section, "DisableMenuNewConnection", FName, FALSE);
1871    
1872 maya 3306 // added PasteDelayPerLine (2009.4.12 maya)
1873     ts->PasteDelayPerLine =
1874     GetPrivateProfileInt(Section, "PasteDelayPerLine", 10, FName);
1875 maya 3315 {
1876     int tmp = min(max(0, ts->PasteDelayPerLine), 5000);
1877     ts->PasteDelayPerLine = tmp;
1878     }
1879 doda 3395
1880     // Font scaling -- test
1881     ts->FontScaling = GetOnOff(Section, "FontScaling", FName, FALSE);
1882 doda 3441
1883     // Meta sets MSB
1884 doda 3507 GetPrivateProfileString(Section, "Meta8Bit", "off", Temp, sizeof(Temp), FName);
1885     if (_stricmp(Temp, "raw") == 0 || _stricmp(Temp, "on") == 0)
1886     ts->Meta8Bit = IdMeta8BitRaw;
1887     else if (_stricmp(Temp, "text") == 0)
1888     ts->Meta8Bit = IdMeta8BitText;
1889     else
1890     ts->Meta8Bit = IdMeta8BitOff;
1891    
1892 maya 3479 // Window control sequence
1893 doda 3485 if (GetOnOff(Section, "WindowCtrlSequence", FName, TRUE))
1894     ts->WindowFlag |= WF_WINDOWCHANGE;
1895 maya 3479
1896     // Cursor control sequence
1897 doda 3485 if (GetOnOff(Section, "CursorCtrlSequence", FName, FALSE))
1898     ts->WindowFlag |= WF_CURSORCHANGE;
1899    
1900     // Window report sequence
1901     if (GetOnOff(Section, "WindowReportSequence", FName, TRUE))
1902     ts->WindowFlag |= WF_WINDOWREPORT;
1903    
1904 doda 3749 // Title report sequence
1905 doda 3747 GetPrivateProfileString(Section, "TitleReportSequence", "Empty", Temp, sizeof(Temp), FName);
1906 doda 3774 if (_stricmp(Temp, "accept") == 0)
1907     ts->WindowFlag |= IdTitleReportAccept;
1908     else if (_stricmp(Temp, "ignore") == 0 || _stricmp(Temp, "off") == 0)
1909 doda 3747 ts->WindowFlag &= ~WF_TITLEREPORT;
1910     else // empty
1911     ts->WindowFlag |= IdTitleReportEmpty;
1912 doda 3501
1913     // Line at a time mode
1914     ts->EnableLineMode = GetOnOff(Section, "EnableLineMode", FName, TRUE);
1915 doda 3721
1916     // Clear window on resize
1917     if (GetOnOff(Section, "ClearOnResize", FName, TRUE))
1918     ts->TermFlag |= TF_CLEARONRESIZE;
1919 doda 3743
1920     // Alternate Screen Buffer
1921     if (GetOnOff(Section, "AlternateScreenBuffer", FName, TRUE))
1922     ts->TermFlag |= TF_ALTSCR;
1923 doda 3969
1924     // IME status related cursor style
1925     if (GetOnOff(Section, "IMERelatedCursor", FName, FALSE))
1926     ts->WindowFlag |= WF_IMECURSORCHANGE;
1927 doda 4217
1928     // Terminal Unique ID
1929     GetPrivateProfileString(Section, "TerminalUID", "FFFFFFFF", Temp, sizeof(Temp), FName);
1930     if (strlen(Temp) == 8) {
1931 doda 4228 for (i=0; i<8 && isxdigit((unsigned char)Temp[i]); i++) {
1932 doda 4217 if (islower(Temp[i])) {
1933     ts->TerminalUID[i] = toupper(Temp[i]);
1934     }
1935     else {
1936     ts->TerminalUID[i] = Temp[i];
1937     }
1938     }
1939     if (i == 8) {
1940     ts->TerminalUID[i] = 0;
1941     }
1942     else {
1943     strncpy_s(ts->TerminalUID, sizeof(ts->TerminalUID), "FFFFFFFF", _TRUNCATE);
1944     }
1945     }
1946     else {
1947     strncpy_s(ts->TerminalUID, sizeof(ts->TerminalUID), "FFFFFFFF", _TRUNCATE);
1948     }
1949 doda 4225
1950     // Lock Terminal UID
1951     if (GetOnOff(Section, "LockTUID", FName, TRUE))
1952     ts->TermFlag |= TF_LOCKTUID;
1953 doda 6435
1954 doda 4480 // Jump List
1955     ts->JumpList = GetOnOff(Section, "JumpList", FName, TRUE);
1956    
1957 doda 4699 // TabStopModifySequence
1958 doda 4687 GetPrivateProfileString(Section, "TabStopModifySequence", "on", Temp, sizeof(Temp), FName);
1959     if (_stricmp(Temp, "on") == 0 || _stricmp(Temp, "all") == 0)
1960     ts->TabStopFlag = TABF_ALL;
1961     else if (_stricmp(Temp, "off") == 0 || _stricmp(Temp, "none") == 0)
1962     ts->TabStopFlag = TABF_NONE;
1963     else {
1964     ts->TabStopFlag = TABF_NONE;
1965     for (i=1; GetNthString(Temp, i, sizeof(Temp2), Temp2); i++) {
1966     if (_stricmp(Temp2, "HTS") == 0)
1967     ts->TabStopFlag |= TABF_HTS;
1968     else if (_stricmp(Temp2, "HTS7") == 0)
1969     ts->TabStopFlag |= TABF_HTS7;
1970     else if (_stricmp(Temp2, "HTS8") == 0)
1971     ts->TabStopFlag |= TABF_HTS8;
1972     else if (_stricmp(Temp2, "TBC") == 0)
1973     ts->TabStopFlag |= TABF_TBC;
1974     else if (_stricmp(Temp2, "TBC0") == 0)
1975     ts->TabStopFlag |= TABF_TBC0;
1976     else if (_stricmp(Temp2, "TBC3") == 0)
1977     ts->TabStopFlag |= TABF_TBC3;
1978     }
1979     }
1980    
1981 doda 4700 // Clipboard Access from Remote
1982 doda 8384 ts->CtrlFlag &= ~CSF_CBMASK;
1983 doda 4700 GetPrivateProfileString(Section, "ClipboardAccessFromRemote", "off", Temp, sizeof(Temp), FName);
1984     if (_stricmp(Temp, "on") == 0 || _stricmp(Temp, "readwrite") == 0)
1985     ts->CtrlFlag |= CSF_CBRW;
1986     else if (_stricmp(Temp, "read") == 0)
1987     ts->CtrlFlag |= CSF_CBREAD;
1988     else if (_stricmp(Temp, "write") == 0)
1989     ts->CtrlFlag |= CSF_CBWRITE;
1990 doda 8384 else
1991     ts->CtrlFlag |= CSF_CBNONE; // ��������������
1992 doda 4700
1993 doda 6666 // Notify Clipboard Access from Remote
1994     ts->NotifyClipboardAccess = GetOnOff(Section, "NotifyClipboardAccess", FName, TRUE);
1995    
1996 doda 4281 // Use invalid DECRPSS (for testing)
1997     if (GetOnOff(Section, "UseInvalidDECRQSSResponse", FName, FALSE))
1998     ts->TermFlag |= TF_INVALIDDECRPSS;
1999 maya 4704
2000     // ClickableUrlBrowser
2001     GetPrivateProfileString(Section, "ClickableUrlBrowser", "",
2002     ts->ClickableUrlBrowser, sizeof(ts->ClickableUrlBrowser), FName);
2003     GetPrivateProfileString(Section, "ClickableUrlBrowserArg", "",
2004     ts->ClickableUrlBrowserArg, sizeof(ts->ClickableUrlBrowserArg), FName);
2005 maya 4786
2006     // Exclusive Lock when open the log file
2007     ts->LogLockExclusive = GetOnOff(Section, "LogLockExclusive", FName, TRUE);
2008 maya 4874
2009     // Font quality
2010     GetPrivateProfileString(Section, "FontQuality", "default",
2011     Temp, sizeof(Temp), FName);
2012     if (_stricmp(Temp, "nonantialiased") == 0)
2013     ts->FontQuality = NONANTIALIASED_QUALITY;
2014     else if (_stricmp(Temp, "antialiased") == 0)
2015     ts->FontQuality = ANTIALIASED_QUALITY;
2016     else if (_stricmp(Temp, "cleartype") == 0)
2017     ts->FontQuality = CLEARTYPE_QUALITY;
2018     else
2019     ts->FontQuality = DEFAULT_QUALITY;
2020 doda 5316
2021     // Beep Over Used
2022     ts->BeepOverUsedCount =
2023     GetPrivateProfileInt(Section, "BeepOverUsedCount", 5, FName);
2024     ts->BeepOverUsedTime =
2025     GetPrivateProfileInt(Section, "BeepOverUsedTime", 2, FName);
2026     ts->BeepSuppressTime =
2027     GetPrivateProfileInt(Section, "BeepSuppressTime", 5, FName);
2028 doda 5410
2029     // Max OSC string buffer size
2030     ts->MaxOSCBufferSize =
2031     GetPrivateProfileInt(Section, "MaxOSCBufferSize", 4096, FName);
2032 doda 5428
2033 doda 5438 ts->JoinSplitURL = GetOnOff(Section, "JoinSplitURL", FName, FALSE);
2034 doda 5428
2035 doda 5438 GetPrivateProfileString(Section, "JoinSplitURLIgnoreEOLChar", "\\", Temp, sizeof(Temp), FName);
2036     ts->JoinSplitURLIgnoreEOLChar = Temp[0];
2037 doda 5590
2038     // Debug modes.
2039     GetPrivateProfileString(Section, "DebugModes", "all", Temp, sizeof(Temp), FName);
2040     if (_stricmp(Temp, "on") == 0 || _stricmp(Temp, "all") == 0)
2041     ts->DebugModes = DBGF_ALL;
2042     else if (_stricmp(Temp, "off") == 0 || _stricmp(Temp, "none") == 0) {
2043     ts->DebugModes = DBGF_NONE;
2044     ts->Debug = FALSE;
2045     }
2046     else {
2047     ts->DebugModes = DBGF_NONE;
2048     for (i=1; GetNthString(Temp, i, sizeof(Temp2), Temp2); i++) {
2049     if (_stricmp(Temp2, "normal") == 0)
2050     ts->DebugModes |= DBGF_NORM;
2051     else if (_stricmp(Temp2, "hex") == 0)
2052     ts->DebugModes |= DBGF_HEXD;
2053     else if (_stricmp(Temp2, "noout") == 0)
2054     ts->DebugModes |= DBGF_NOUT;
2055     }
2056     if (ts->DebugModes == DBGF_NONE)
2057     ts->Debug = FALSE;
2058     }
2059 yutakapon 6119
2060 doda 6318 // Xmodem Timeout
2061     GetPrivateProfileString(Section, "XmodemTimeouts", "10,3,10,20,60", Temp, sizeof(Temp), FName);
2062     ts->XmodemTimeOutInit = GetNthNum2(Temp, 1, 10);
2063     if (ts->XmodemTimeOutInit < 1)
2064     ts->XmodemTimeOutInit = 1;
2065     ts->XmodemTimeOutInitCRC = GetNthNum2(Temp, 2, 3);
2066     if (ts->XmodemTimeOutInitCRC < 1)
2067     ts->XmodemTimeOutInitCRC = 1;
2068     ts->XmodemTimeOutShort = GetNthNum2(Temp, 3, 10);
2069     if (ts->XmodemTimeOutShort < 1)
2070     ts->XmodemTimeOutShort = 1;
2071     ts->XmodemTimeOutLong = GetNthNum2(Temp, 4, 20);
2072     if (ts->XmodemTimeOutLong < 1)
2073     ts->XmodemTimeOutLong = 1;
2074     ts->XmodemTimeOutVLong = GetNthNum2(Temp, 5, 60);
2075     if (ts->XmodemTimeOutVLong < 1)
2076     ts->XmodemTimeOutVLong = 1;
2077    
2078 maya 6319 // Ymodem Timeout
2079     GetPrivateProfileString(Section, "YmodemTimeouts", "10,3,10,20,60", Temp, sizeof(Temp), FName);
2080     ts->YmodemTimeOutInit = GetNthNum2(Temp, 1, 10);
2081     if (ts->YmodemTimeOutInit < 1)
2082     ts->YmodemTimeOutInit = 1;
2083     ts->YmodemTimeOutInitCRC = GetNthNum2(Temp, 2, 3);
2084     if (ts->YmodemTimeOutInitCRC < 1)
2085     ts->YmodemTimeOutInitCRC = 1;
2086     ts->YmodemTimeOutShort = GetNthNum2(Temp, 3, 10);
2087     if (ts->YmodemTimeOutShort < 1)
2088     ts->YmodemTimeOutShort = 1;
2089     ts->YmodemTimeOutLong = GetNthNum2(Temp, 4, 20);
2090     if (ts->YmodemTimeOutLong < 1)
2091     ts->YmodemTimeOutLong = 1;
2092     ts->YmodemTimeOutVLong = GetNthNum2(Temp, 5, 60);
2093     if (ts->YmodemTimeOutVLong < 1)
2094     ts->YmodemTimeOutVLong = 1;
2095    
2096     // Zmodem Timeout
2097     GetPrivateProfileString(Section, "ZmodemTimeouts", "10,0,10,3", Temp, sizeof(Temp), FName);
2098     ts->ZmodemTimeOutNormal = GetNthNum2(Temp, 1, 10);
2099     if (ts->ZmodemTimeOutNormal < 1)
2100     ts->ZmodemTimeOutNormal = 1;
2101     ts->ZmodemTimeOutTCPIP = GetNthNum2(Temp, 2, 0);
2102     if (ts->ZmodemTimeOutTCPIP < 0)
2103     ts->ZmodemTimeOutTCPIP = 0;
2104     ts->ZmodemTimeOutInit = GetNthNum2(Temp, 3, 10);
2105     if (ts->ZmodemTimeOutInit < 1)
2106     ts->ZmodemTimeOutInit = 1;
2107     ts->ZmodemTimeOutFin = GetNthNum2(Temp, 4, 3);
2108     if (ts->ZmodemTimeOutFin < 1)
2109     ts->ZmodemTimeOutFin = 1;
2110    
2111 doda 6418 // Trim trailing new line character when pasting
2112 doda 6594 if (GetOnOff(Section, "TrimTrailingNLonPaste", FName, FALSE))
2113     ts->PasteFlag |= CPF_TRIM_TRAILING_NL;
2114 doda 6418
2115 doda 6856 // List Inactive Font
2116     ts->ListHiddenFonts = GetOnOff(Section, "ListHiddenFonts", FName, FALSE);
2117    
2118 doda 6916 // ISO2022ShiftFunction
2119     GetPrivateProfileString(Section, "ISO2022ShiftFunction", "on", Temp, sizeof(Temp), FName);
2120 doda 6915 ts->ISO2022Flag = ISO2022_SHIFT_NONE;
2121     for (i=1; GetNthString(Temp, i, sizeof(Temp2), Temp2); i++) {
2122     BOOL add=TRUE;
2123 doda 6918 char *p = Temp2, *p2;
2124 doda 6915 int mask = 0;
2125    
2126 doda 6918 while (*p == ' ' || *p == '\t') {
2127     p++;
2128     }
2129     p2 = p + strlen(p);
2130     while (p2 > p) {
2131     p2--;
2132     if (*p2 != ' ' && *p2 != '\t') {
2133     break;
2134     }
2135     }
2136     *++p2 = 0;
2137    
2138 doda 6915 if (*p == '-') {
2139     p++;
2140     add=FALSE;
2141 doda 6913 }
2142 doda 6918 else if (*p == '+') {
2143     p++;
2144     }
2145    
2146 doda 6915 if (_stricmp(p, "on") == 0 || _stricmp(p, "all") == 0)
2147     ts->ISO2022Flag = ISO2022_SHIFT_ALL;
2148     else if (_stricmp(p, "off") == 0 || _stricmp(p, "none") == 0)
2149     ts->ISO2022Flag = ISO2022_SHIFT_NONE;
2150     else if (_stricmp(p, "SI") == 0 || _stricmp(p, "LS0") == 0)
2151     mask = ISO2022_SI;
2152     else if (_stricmp(p, "SO") == 0 || _stricmp(p, "LS1") == 0)
2153     mask = ISO2022_SO;
2154     else if (_stricmp(p, "LS2") == 0)
2155     mask = ISO2022_LS2;
2156     else if (_stricmp(p, "LS3") == 0)
2157     mask = ISO2022_LS3;
2158     else if (_stricmp(p, "LS1R") == 0)
2159     mask = ISO2022_LS1R;
2160     else if (_stricmp(p, "LS2R") == 0)
2161     mask = ISO2022_LS2R;
2162     else if (_stricmp(p, "LS3R") == 0)
2163     mask = ISO2022_LS3R;
2164     else if (_stricmp(p, "SS2") == 0)
2165     mask = ISO2022_SS2;
2166     else if (_stricmp(p, "SS3") == 0)
2167     mask = ISO2022_SS3;
2168    
2169     if (mask) {
2170     if (add) {
2171     ts->ISO2022Flag |= mask;
2172     }
2173     else {
2174     ts->ISO2022Flag &= ~mask;
2175     }
2176     }
2177 doda 6913 }
2178    
2179 doda 6958 // Terminal Speed (Used by telnet and ssh)
2180     GetPrivateProfileString(Section, "TerminalSpeed", "38400", Temp, sizeof(Temp), FName);
2181     GetNthNum(Temp, 1, &<