Develop and Download Open Source Software

Browse Subversion Repository

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 3278 - (show annotations) (download) (as text)
Fri Apr 3 15:04:41 2009 UTC (15 years ago) by doda
File MIME type: text/x-csrc
File size: 95389 byte(s)
設定の保存時に書き込まれる値を、他の設定に合わせてすべて小文字に変更。
http://sourceforge.jp/ticket/browse.php?group_id=1412&tid=15906

1 /* Tera Term
2 Copyright(C) 1994-1998 T. Teranishi
3 All rights reserved. */
4 /* IPv6 modification is Copyright(C) 2000 Jun-ya kato <kato@win6.jp> */
5
6 /* TTSET.DLL, setup file routines*/
7 #ifndef NO_INET6
8 #include <winsock2.h>
9 #include <ws2tcpip.h>
10 #endif /* NO_INET6 */
11 #include "teraterm.h"
12 #include "tttypes.h"
13 #include <stdio.h>
14 #include <string.h>
15 #include <direct.h>
16 #include "ttlib.h"
17 #include "tt_res.h"
18
19 #include "compat_w95.h"
20
21 #define Section "Tera Term"
22
23 static PCHAR far TermList[] =
24 { "VT100", "VT100J", "VT101", "VT102", "VT102J", "VT220J", "VT282",
25 "VT320", "VT382", NULL };
26
27 static PCHAR far RussList[] =
28 { "Windows", "KOI8-R", "CP-866", "ISO-8859-5", NULL };
29 static PCHAR far RussList2[] = { "Windows", "KOI8-R", NULL };
30
31 WORD str2id(PCHAR far * List, PCHAR str, WORD DefId)
32 {
33 WORD i;
34 i = 0;
35 while ((List[i] != NULL) && (_stricmp(List[i], str) != 0))
36 i++;
37 if (List[i] == NULL)
38 i = DefId;
39 else
40 i++;
41
42 return i;
43 }
44
45 void id2str(PCHAR far * List, WORD Id, WORD DefId, PCHAR str, int destlen)
46 {
47 int i;
48
49 if (Id == 0)
50 i = DefId - 1;
51 else {
52 i = 0;
53 while ((List[i] != NULL) && (i < Id - 1))
54 i++;
55 if (List[i] == NULL)
56 i = DefId - 1;
57 }
58 strncpy_s(str, destlen, List[i], _TRUNCATE);
59 }
60
61 int IconName2IconId(const char *name) {
62 int id;
63
64 if (_stricmp(name, "tterm") == 0) {
65 id = IDI_TTERM;
66 }
67 else if (_stricmp(name, "vt") == 0) {
68 id = IDI_VT;
69 }
70 else if (_stricmp(name, "tek") == 0) {
71 id = IDI_TEK;
72 }
73 else if (_stricmp(name, "tterm_classic") == 0) {
74 id = IDI_TTERM_CLASSIC;
75 }
76 else if (_stricmp(name, "vt_classic") == 0) {
77 id = IDI_VT_CLASSIC;
78 }
79 else if (_stricmp(name, "cygterm") == 0) {
80 id = IDI_CYGTERM;
81 }
82 else {
83 id = IdIconDefault;
84 }
85 return id;
86 }
87
88 void IconId2IconName(char *name, int len, int id) {
89 char *icon;
90 switch (id) {
91 case IDI_TTERM:
92 icon = "tterm";
93 break;
94 case IDI_VT:
95 icon = "vt";
96 break;
97 case IDI_TEK:
98 icon = "tek";
99 break;
100 case IDI_TTERM_CLASSIC:
101 icon = "tterm_classic";
102 break;
103 case IDI_VT_CLASSIC:
104 icon = "vt_classic";
105 break;
106 case IDI_CYGTERM:
107 icon = "cygterm";
108 break;
109 default:
110 icon = "Default";
111 }
112 strncpy_s(name, len, icon, _TRUNCATE);
113 }
114
115 WORD GetOnOff(PCHAR Sect, PCHAR Key, PCHAR FName, BOOL Default)
116 {
117 char Temp[4];
118 GetPrivateProfileString(Sect, Key, "", Temp, sizeof(Temp), FName);
119 if (Default) {
120 if (_stricmp(Temp, "off") == 0)
121 return 0;
122 else
123 return 1;
124 }
125 else {
126 if (_stricmp(Temp, "on") == 0)
127 return 1;
128 else
129 return 0;
130 }
131 }
132
133 void WriteOnOff(PCHAR Sect, PCHAR Key, PCHAR FName, WORD Flag)
134 {
135 char Temp[4];
136
137 if (Flag != 0)
138 strncpy_s(Temp, sizeof(Temp), "on", _TRUNCATE);
139 else
140 strncpy_s(Temp, sizeof(Temp), "off", _TRUNCATE);
141 WritePrivateProfileString(Sect, Key, Temp, FName);
142 }
143
144 void WriteInt(PCHAR Sect, PCHAR Key, PCHAR FName, int i)
145 {
146 char Temp[15];
147 _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d", i);
148 WritePrivateProfileString(Sect, Key, Temp, FName);
149 }
150
151 void WriteUint(PCHAR Sect, PCHAR Key, PCHAR FName, UINT i)
152 {
153 char Temp[15];
154 _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%u", i);
155 WritePrivateProfileString(Sect, Key, Temp, FName);
156 }
157
158 void WriteInt2(PCHAR Sect, PCHAR Key, PCHAR FName, int i1, int i2)
159 {
160 char Temp[32];
161 _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d,%d", i1, i2);
162 WritePrivateProfileString(Sect, Key, Temp, FName);
163 }
164
165 void WriteInt4(PCHAR Sect, PCHAR Key, PCHAR FName,
166 int i1, int i2, int i3, int i4)
167 {
168 char Temp[64];
169 _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d,%d,%d,%d",
170 i1, i2, i3, i4);
171 WritePrivateProfileString(Sect, Key, Temp, FName);
172 }
173
174 void WriteInt6(PCHAR Sect, PCHAR Key, PCHAR FName,
175 int i1, int i2, int i3, int i4, int i5, int i6)
176 {
177 char Temp[96];
178 _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d,%d,%d,%d,%d,%d",
179 i1, i2,i3, i4, i5, i6);
180 WritePrivateProfileString(Sect, Key, Temp, FName);
181 }
182
183 void WriteFont(PCHAR Sect, PCHAR Key, PCHAR FName,
184 PCHAR Name, int x, int y, int charset)
185 {
186 char Temp[80];
187 if (Name[0] != 0)
188 _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%s,%d,%d,%d",
189 Name, x, y, charset);
190 else
191 Temp[0] = 0;
192 WritePrivateProfileString(Sect, Key, Temp, FName);
193 }
194
195 void FAR PASCAL ReadIniFile(PCHAR FName, PTTSet ts)
196 {
197 int i;
198 HDC TmpDC;
199 char Temp[MAXPATHLEN];
200
201 ts->Minimize = 0;
202 ts->HideWindow = 0;
203 ts->LogFlag = 0; // Log flags
204 ts->FTFlag = 0; // File transfer flags
205 ts->MenuFlag = 0; // Menu flags
206 ts->TermFlag = 0; // Terminal flag
207 ts->ColorFlag = 0; // ANSI/Attribute color flags
208 ts->PortFlag = 0; // Port flags
209 ts->TelPort = 23;
210
211 /* Version number */
212 /* GetPrivateProfileString(Section,"Version","",
213 Temp,sizeof(Temp),FName); */
214
215 /* Language */
216 GetPrivateProfileString(Section, "Language", "",
217 Temp, sizeof(Temp), FName);
218 if (_stricmp(Temp, "Japanese") == 0)
219 ts->Language = IdJapanese;
220 else if (_stricmp(Temp, "Russian") == 0)
221 ts->Language = IdRussian;
222 else if (_stricmp(Temp, "English") == 0)
223 ts->Language = IdEnglish;
224 else if (_stricmp(Temp,"Korean") == 0) // HKS
225 ts->Language = IdKorean;
226 else {
227 switch (PRIMARYLANGID(GetSystemDefaultLangID())) {
228 case LANG_JAPANESE:
229 ts->Language = IdJapanese;
230 break;
231 case LANG_RUSSIAN:
232 ts->Language = IdRussian;
233 break;
234 case LANG_KOREAN: // HKS
235 ts->Language = IdKorean;
236 break;
237 default:
238 ts->Language = IdEnglish;
239 }
240 }
241
242 /* Port type */
243 GetPrivateProfileString(Section, "Port", "",
244 Temp, sizeof(Temp), FName);
245 if (_stricmp(Temp, "tcpip") == 0)
246 ts->PortType = IdTCPIP;
247 else if (_stricmp(Temp, "serial") == 0)
248 ts->PortType = IdSerial;
249 else {
250 ts->PortType = IdTCPIP;
251 }
252
253 /* VT win position */
254 GetPrivateProfileString(Section, "VTPos", "-2147483648,-2147483648", Temp, sizeof(Temp), FName); /* default: random position */
255 GetNthNum(Temp, 1, (int far *) (&ts->VTPos.x));
256 GetNthNum(Temp, 2, (int far *) (&ts->VTPos.y));
257
258 /* TEK win position */
259 GetPrivateProfileString(Section, "TEKPos", "-2147483648,-2147483648", Temp, sizeof(Temp), FName); /* default: random position */
260 GetNthNum(Temp, 1, (int far *) &(ts->TEKPos.x));
261 GetNthNum(Temp, 2, (int far *) &(ts->TEKPos.y));
262
263 /* Save VT Window position */
264 ts->SaveVTWinPos = GetOnOff(Section, "SaveVTWinPos", FName, FALSE);
265
266 /* VT terminal size */
267 GetPrivateProfileString(Section, "TerminalSize", "80,24",
268 Temp, sizeof(Temp), FName);
269 GetNthNum(Temp, 1, &ts->TerminalWidth);
270 GetNthNum(Temp, 2, &ts->TerminalHeight);
271 if (ts->TerminalWidth < 0)
272 ts->TerminalWidth = 1;
273 if (ts->TerminalHeight < 0)
274 ts->TerminalHeight = 1;
275
276 /* Terminal size = Window size */
277 ts->TermIsWin = GetOnOff(Section, "TermIsWin", FName, FALSE);
278
279 /* Auto window resize flag */
280 ts->AutoWinResize = GetOnOff(Section, "AutoWinResize", FName, FALSE);
281
282 /* CR Receive */
283 GetPrivateProfileString(Section, "CRReceive", "",
284 Temp, sizeof(Temp), FName);
285 if (_stricmp(Temp, "CRLF") == 0) {
286 ts->CRReceive = IdCRLF;
287 }
288 else if (_stricmp(Temp, "LF") == 0) {
289 ts->CRReceive = IdLF;
290 }
291 else {
292 ts->CRReceive = IdCR;
293 }
294 /* CR Send */
295 GetPrivateProfileString(Section, "CRSend", "",
296 Temp, sizeof(Temp), FName);
297 if (_stricmp(Temp, "CRLF") == 0)
298 ts->CRSend = IdCRLF;
299 else
300 ts->CRSend = IdCR;
301 ts->CRSend_ini = ts->CRSend;
302
303 /* Local echo */
304 ts->LocalEcho = GetOnOff(Section, "LocalEcho", FName, FALSE);
305 ts->LocalEcho_ini = ts->LocalEcho;
306
307 /* Answerback */
308 GetPrivateProfileString(Section, "Answerback", "", Temp,
309 sizeof(Temp), FName);
310 ts->AnswerbackLen =
311 Hex2Str(Temp, ts->Answerback, sizeof(ts->Answerback));
312
313 /* Kanji Code (receive) */
314 GetPrivateProfileString(Section, "KanjiReceive", "",
315 Temp, sizeof(Temp), FName);
316 if (_stricmp(Temp, "EUC") == 0)
317 ts->KanjiCode = IdEUC;
318 else if (_stricmp(Temp, "JIS") == 0)
319 ts->KanjiCode = IdJIS;
320 else if (_stricmp(Temp, "UTF-8") == 0)
321 ts->KanjiCode = IdUTF8;
322 else if (_stricmp(Temp, "UTF-8m") == 0)
323 ts->KanjiCode = IdUTF8m;
324 else
325 ts->KanjiCode = IdSJIS;
326
327 /* Katakana (receive) */
328 GetPrivateProfileString(Section, "KatakanaReceive", "",
329 Temp, sizeof(Temp), FName);
330 if (_stricmp(Temp, "7") == 0)
331 ts->JIS7Katakana = 1;
332 else
333 ts->JIS7Katakana = 0;
334
335 /* Kanji Code (transmit) */
336 GetPrivateProfileString(Section, "KanjiSend", "",
337 Temp, sizeof(Temp), FName);
338 if (_stricmp(Temp, "EUC") == 0)
339 ts->KanjiCodeSend = IdEUC;
340 else if (_stricmp(Temp, "JIS") == 0)
341 ts->KanjiCodeSend = IdJIS;
342 else if (_stricmp(Temp, "UTF-8") == 0)
343 ts->KanjiCodeSend = IdUTF8;
344 else
345 ts->KanjiCodeSend = IdSJIS;
346
347 /* Katakana (receive) */
348 GetPrivateProfileString(Section, "KatakanaSend", "",
349 Temp, sizeof(Temp), FName);
350 if (_stricmp(Temp, "7") == 0)
351 ts->JIS7KatakanaSend = 1;
352 else
353 ts->JIS7KatakanaSend = 0;
354
355 /* KanjiIn */
356 GetPrivateProfileString(Section, "KanjiIn", "",
357 Temp, sizeof(Temp), FName);
358 if (_stricmp(Temp, "@") == 0)
359 ts->KanjiIn = IdKanjiInA;
360 else
361 ts->KanjiIn = IdKanjiInB;
362
363 /* KanjiOut */
364 GetPrivateProfileString(Section, "KanjiOut", "",
365 Temp, sizeof(Temp), FName);
366 if (_stricmp(Temp, "B") == 0)
367 ts->KanjiOut = IdKanjiOutB;
368 else if (_stricmp(Temp, "H") == 0)
369 ts->KanjiOut = IdKanjiOutH;
370 else
371 ts->KanjiOut = IdKanjiOutJ;
372
373 /* Auto Win Switch VT<->TEK */
374 ts->AutoWinSwitch = GetOnOff(Section, "AutoWinSwitch", FName, FALSE);
375
376 /* Terminal ID */
377 GetPrivateProfileString(Section, "TerminalID", "",
378 Temp, sizeof(Temp), FName);
379 ts->TerminalID = str2id(TermList, Temp, IdVT100);
380
381 /* Russian character set (host) */
382 GetPrivateProfileString(Section, "RussHost", "",
383 Temp, sizeof(Temp), FName);
384 ts->RussHost = str2id(RussList, Temp, IdKOI8);
385
386 /* Russian character set (client) */
387 GetPrivateProfileString(Section, "RussClient", "",
388 Temp, sizeof(Temp), FName);
389 ts->RussClient = str2id(RussList, Temp, IdWindows);
390
391 /* Title String */
392 GetPrivateProfileString(Section, "Title", "Tera Term",
393 ts->Title, sizeof(ts->Title), FName);
394
395 /* Cursor shape */
396 GetPrivateProfileString(Section, "CursorShape", "",
397 Temp, sizeof(Temp), FName);
398 if (_stricmp(Temp, "vertical") == 0)
399 ts->CursorShape = IdVCur;
400 else if (_stricmp(Temp, "horizontal") == 0)
401 ts->CursorShape = IdHCur;
402 else
403 ts->CursorShape = IdBlkCur;
404
405 /* Hide title */
406 ts->HideTitle = GetOnOff(Section, "HideTitle", FName, FALSE);
407
408 /* Popup menu */
409 ts->PopupMenu = GetOnOff(Section, "PopupMenu", FName, FALSE);
410
411 /* PC-Style bold color mapping */
412 if (GetOnOff(Section, "PcBoldColor", FName, FALSE))
413 ts->ColorFlag |= CF_PCBOLD16;
414
415 /* aixterm style 16 colors mode */
416 if (GetOnOff(Section, "Aixterm16Color", FName, FALSE))
417 ts->ColorFlag |= CF_AIXTERM16;
418
419 /* xterm style 256 colors mode */
420 if (GetOnOff(Section, "Xterm256Color", FName, TRUE))
421 ts->ColorFlag |= CF_XTERM256;
422
423 /* Enable scroll buffer */
424 ts->EnableScrollBuff =
425 GetOnOff(Section, "EnableScrollBuff", FName, TRUE);
426
427 /* Scroll buffer size */
428 ts->ScrollBuffSize =
429 GetPrivateProfileInt(Section, "ScrollBuffSize", 100, FName);
430
431 /* VT Color */
432 GetPrivateProfileString(Section, "VTColor", "0,0,0,255,255,255",
433 Temp, sizeof(Temp), FName);
434 for (i = 0; i <= 5; i++)
435 GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
436 for (i = 0; i <= 1; i++)
437 ts->VTColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
438 (BYTE) ts->TmpColor[0][i * 3 + 1],
439 (BYTE) ts->TmpColor[0][i * 3 + 2]);
440
441 /* VT Bold Color */
442 GetPrivateProfileString(Section, "VTBoldColor", "0,0,255,255,255,255",
443 Temp, sizeof(Temp), FName);
444 for (i = 0; i <= 5; i++)
445 GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
446 for (i = 0; i <= 1; i++)
447 ts->VTBoldColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
448 (BYTE) ts->TmpColor[0][i * 3 + 1],
449 (BYTE) ts->TmpColor[0][i * 3 + 2]);
450 if (GetOnOff(Section, "EnableBoldAttrColor", FName, TRUE))
451 ts->ColorFlag |= CF_BOLDCOLOR;
452
453 /* VT Blink Color */
454 GetPrivateProfileString(Section, "VTBlinkColor", "255,0,0,255,255,255",
455 Temp, sizeof(Temp), FName);
456 for (i = 0; i <= 5; i++)
457 GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
458 for (i = 0; i <= 1; i++)
459 ts->VTBlinkColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
460 (BYTE) ts->TmpColor[0][i * 3 + 1],
461 (BYTE) ts->TmpColor[0][i * 3 + 2]);
462 if (GetOnOff(Section, "EnableBlinkAttrColor", FName, TRUE))
463 ts->ColorFlag |= CF_BLINKCOLOR;
464
465 /* VT Reverse Color */
466 GetPrivateProfileString(Section, "VTReverseColor", "255,255,255,0,0,0",
467 Temp, sizeof(Temp), FName);
468 for (i = 0; i <= 5; i++)
469 GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
470 for (i = 0; i <= 1; i++)
471 ts->VTReverseColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
472 (BYTE) ts->TmpColor[0][i * 3 + 1],
473 (BYTE) ts->TmpColor[0][i * 3 + 2]);
474 if (GetOnOff(Section, "EnableReverseAttrColor", FName, FALSE))
475 ts->ColorFlag |= CF_REVERSECOLOR;
476
477 ts->EnableClickableUrl =
478 GetOnOff(Section, "EnableClickableUrl", FName, FALSE);
479
480 /* URL Color */
481 GetPrivateProfileString(Section, "URLColor", "0,255,0,255,255,255",
482 Temp, sizeof(Temp), FName);
483 for (i = 0; i <= 5; i++)
484 GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
485 for (i = 0; i <= 1; i++)
486 ts->URLColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
487 (BYTE) ts->TmpColor[0][i * 3 + 1],
488 (BYTE) ts->TmpColor[0][i * 3 + 2]);
489 if (GetOnOff(Section, "EnableURLColor", FName, TRUE))
490 ts->ColorFlag |= CF_URLCOLOR;
491
492 /* TEK Color */
493 GetPrivateProfileString(Section, "TEKColor", "0,0,0,255,255,255",
494 Temp, sizeof(Temp), FName);
495 for (i = 0; i <= 5; i++)
496 GetNthNum(Temp, i + 1, (int far *) &(ts->TmpColor[0][i]));
497 for (i = 0; i <= 1; i++)
498 ts->TEKColor[i] = RGB((BYTE) ts->TmpColor[0][i * 3],
499 (BYTE) ts->TmpColor[0][i * 3 + 1],
500 (BYTE) ts->TmpColor[0][i * 3 + 2]);
501
502 #ifndef NO_ANSI_COLOR_EXTENSION
503 /* ANSI color definition (in the case FullColor=on) -- special option
504 o UseTextColor should be off, or the background and foreground color of
505 VTColor are assigned to color-number 0 and 7 respectively, even if
506 they are specified in ANSIColor.
507 o ANSIColor is a set of 4 values that are color-number(0--15),
508 red-value(0--255), green-value(0--255) and blue-value(0--255). */
509 GetPrivateProfileString(Section, "ANSIColor",
510 " 0, 0, 0, 0,"
511 " 1,255, 0, 0,"
512 " 2, 0,255, 0,"
513 " 3,255,255, 0,"
514 " 4, 0, 0,255,"
515 " 5,255, 0,255,"
516 " 6, 0,255,255,"
517 " 7,255,255,255,"
518 " 8,128,128,128,"
519 " 9,128, 0, 0,"
520 "10, 0,128, 0,"
521 "11,128,128, 0,"
522 "12, 0, 0,128,"
523 "13,128, 0,128,"
524 "14, 0,128,128,"
525 "15,192,192,192", Temp, sizeof(Temp), FName);
526 {
527 char *t;
528 int n = 1;
529 for (t = Temp; *t; t++)
530 if (*t == ',')
531 n++;
532 n /= 4;
533 for (i = 0; i <= n; i++) {
534 int colorid, r, g, b;
535 GetNthNum(Temp, i * 4 + 1, (int far *) &colorid);
536 GetNthNum(Temp, i * 4 + 2, (int far *) &r);
537 GetNthNum(Temp, i * 4 + 3, (int far *) &g);
538 GetNthNum(Temp, i * 4 + 4, (int far *) &b);
539 ts->ANSIColor[colorid & 15] =
540 RGB((BYTE) r, (BYTE) g, (BYTE) b);
541 }
542 }
543 #endif /* NO_ANSI_COLOR_EXTENSION */
544
545 TmpDC = GetDC(0); /* Get screen device context */
546 for (i = 0; i <= 1; i++)
547 ts->VTColor[i] = GetNearestColor(TmpDC, ts->VTColor[i]);
548 for (i = 0; i <= 1; i++)
549 ts->VTBoldColor[i] = GetNearestColor(TmpDC, ts->VTBoldColor[i]);
550 for (i = 0; i <= 1; i++)
551 ts->VTBlinkColor[i] = GetNearestColor(TmpDC, ts->VTBlinkColor[i]);
552 for (i = 0; i <= 1; i++)
553 ts->TEKColor[i] = GetNearestColor(TmpDC, ts->TEKColor[i]);
554 /* begin - ishizaki */
555 for (i = 0; i <= 1; i++)
556 ts->URLColor[i] = GetNearestColor(TmpDC, ts->URLColor[i]);
557 /* end - ishizaki */
558 #ifndef NO_ANSI_COLOR_EXTENSION
559 for (i = 0; i < 16; i++)
560 ts->ANSIColor[i] = GetNearestColor(TmpDC, ts->ANSIColor[i]);
561 #endif /* NO_ANSI_COLOR_EXTENSION */
562 ReleaseDC(0, TmpDC);
563 if (GetOnOff(Section, "EnableANSIColor", FName, TRUE))
564 ts->ColorFlag |= CF_ANSICOLOR;
565
566 /* TEK color emulation */
567 ts->TEKColorEmu = GetOnOff(Section, "TEKColorEmulation", FName, FALSE);
568
569 /* VT Font */
570 GetPrivateProfileString(Section, "VTFont", "Terminal,0,-13,1",
571 Temp, sizeof(Temp), FName);
572 GetNthString(Temp, 1, sizeof(ts->VTFont), ts->VTFont);
573 GetNthNum(Temp, 2, (int far *) &(ts->VTFontSize.x));
574 GetNthNum(Temp, 3, (int far *) &(ts->VTFontSize.y));
575 GetNthNum(Temp, 4, &(ts->VTFontCharSet));
576
577 /* Bold font flag */
578 ts->EnableBold = GetOnOff(Section, "EnableBold", FName, TRUE);
579
580 /* Russian character set (font) */
581 GetPrivateProfileString(Section, "RussFont", "",
582 Temp, sizeof(Temp), FName);
583 ts->RussFont = str2id(RussList, Temp, IdWindows);
584
585 /* TEK Font */
586 GetPrivateProfileString(Section, "TEKFont", "Courier,0,-13,0",
587 Temp, sizeof(Temp), FName);
588 GetNthString(Temp, 1, sizeof(ts->TEKFont), ts->TEKFont);
589 GetNthNum(Temp, 2, (int far *) &(ts->TEKFontSize.x));
590 GetNthNum(Temp, 3, (int far *) &(ts->TEKFontSize.y));
591 GetNthNum(Temp, 4, &(ts->TEKFontCharSet));
592
593 /* BS key */
594 GetPrivateProfileString(Section, "BSKey", "",
595 Temp, sizeof(Temp), FName);
596 if (_stricmp(Temp, "DEL") == 0)
597 ts->BSKey = IdDEL;
598 else
599 ts->BSKey = IdBS;
600 /* Delete key */
601 ts->DelKey = GetOnOff(Section, "DeleteKey", FName, FALSE);
602
603 /* Meta Key */
604 ts->MetaKey = GetOnOff(Section, "MetaKey", FName, FALSE);
605
606 /* Application Keypad */
607 ts->DisableAppKeypad =
608 GetOnOff(Section, "DisableAppKeypad", FName, FALSE);
609
610 /* Application Cursor */
611 ts->DisableAppCursor =
612 GetOnOff(Section, "DisableAppCursor", FName, FALSE);
613
614 /* Russian keyboard type */
615 GetPrivateProfileString(Section, "RussKeyb", "",
616 Temp, sizeof(Temp), FName);
617 ts->RussKeyb = str2id(RussList2, Temp, IdWindows);
618
619 /* Serial port ID */
620 ts->ComPort = GetPrivateProfileInt(Section, "ComPort", 1, FName);
621
622 /* Baud rate */
623 GetPrivateProfileString(Section, "BaudRate", "9600",
624 Temp, sizeof(Temp), FName);
625 ts->Baud = str2id(BaudList, Temp, IdBaud9600);
626
627 /* Parity */
628 GetPrivateProfileString(Section, "Parity", "",
629 Temp, sizeof(Temp), FName);
630 if (_stricmp(Temp, "even") == 0)
631 ts->Parity = IdParityEven;
632 else if (_stricmp(Temp, "odd") == 0)
633 ts->Parity = IdParityOdd;
634 else
635 ts->Parity = IdParityNone;
636
637 /* Data bit */
638 GetPrivateProfileString(Section, "DataBit", "",
639 Temp, sizeof(Temp), FName);
640 if (_stricmp(Temp, "7") == 0)
641 ts->DataBit = IdDataBit7;
642 else
643 ts->DataBit = IdDataBit8;
644
645 /* Stop bit */
646 GetPrivateProfileString(Section, "StopBit", "",
647 Temp, sizeof(Temp), FName);
648 if (_stricmp(Temp, "2") == 0)
649 ts->StopBit = IdStopBit2;
650 else
651 ts->StopBit = IdStopBit1;
652
653 /* Flow control */
654 GetPrivateProfileString(Section, "FlowCtrl", "",
655 Temp, sizeof(Temp), FName);
656 if (_stricmp(Temp, "x") == 0)
657 ts->Flow = IdFlowX;
658 else if (_stricmp(Temp, "hard") == 0)
659 ts->Flow = IdFlowHard;
660 else
661 ts->Flow = IdFlowNone;
662
663 /* Delay per character */
664 ts->DelayPerChar =
665 GetPrivateProfileInt(Section, "DelayPerChar", 0, FName);
666
667 /* Delay per line */
668 ts->DelayPerLine =
669 GetPrivateProfileInt(Section, "DelayPerLine", 0, FName);
670
671 /* Telnet flag */
672 ts->Telnet = GetOnOff(Section, "Telnet", FName, TRUE);
673
674 /* Telnet terminal type */
675 GetPrivateProfileString(Section, "TermType", "xterm", ts->TermType,
676 sizeof(ts->TermType), FName);
677
678 /* TCP port num */
679 ts->TCPPort =
680 GetPrivateProfileInt(Section, "TCPPort", ts->TelPort, FName);
681
682 /* Auto window close flag */
683 ts->AutoWinClose = GetOnOff(Section, "AutoWinClose", FName, TRUE);
684
685 /* History list */
686 ts->HistoryList = GetOnOff(Section, "HistoryList", FName, FALSE);
687
688 /* File transfer binary flag */
689 ts->TransBin = GetOnOff(Section, "TransBin", FName, FALSE);
690
691 /* Log append */
692 ts->Append = GetOnOff(Section, "LogAppend", FName, FALSE);
693
694 /* Log plain text (2005.5.7 yutaka) */
695 ts->LogTypePlainText =
696 GetOnOff(Section, "LogTypePlainText", FName, FALSE);
697
698 /* Log with timestamp (2006.7.23 maya) */
699 ts->LogTimestamp = GetOnOff(Section, "LogTimestamp", FName, FALSE);
700
701 /* Log without transfer dialog */
702 ts->LogHideDialog = GetOnOff(Section, "LogHideDialog", FName, FALSE);
703
704 /* Default Log file name (2006.8.28 maya) */
705 GetPrivateProfileString(Section, "LogDefaultName", "teraterm.log",
706 ts->LogDefaultName, sizeof(ts->LogDefaultName),
707 FName);
708
709 /* Default Log file path (2007.5.30 maya) */
710 GetPrivateProfileString(Section, "LogDefaultPath", "",
711 ts->LogDefaultPath, sizeof(ts->LogDefaultPath),
712 FName);
713
714 /* Auto start logging (2007.5.31 maya) */
715 ts->LogAutoStart = GetOnOff(Section, "LogAutoStart", FName, FALSE);
716
717 /* XMODEM option */
718 GetPrivateProfileString(Section, "XmodemOpt", "",
719 Temp, sizeof(Temp), FName);
720 if (_stricmp(Temp, "crc") == 0)
721 ts->XmodemOpt = XoptCRC;
722 else if (_stricmp(Temp, "1k") == 0)
723 ts->XmodemOpt = Xopt1K;
724 else
725 ts->XmodemOpt = XoptCheck;
726
727 /* XMODEM binary file */
728 ts->XmodemBin = GetOnOff(Section, "XmodemBin", FName, TRUE);
729
730 /* XMODEM ���M�R�}���h (2007.12.21 yutaka) */
731 GetPrivateProfileString(Section, "XModemRcvCommand", "",
732 ts->XModemRcvCommand,
733 sizeof(ts->XModemRcvCommand), FName);
734
735 /* Default directory for file transfer */
736 GetPrivateProfileString(Section, "FileDir", "",
737 ts->FileDir, sizeof(ts->FileDir), FName);
738 if (strlen(ts->FileDir) == 0)
739 strncpy_s(ts->FileDir, sizeof(ts->FileDir), ts->HomeDir, _TRUNCATE);
740 else {
741 _getcwd(Temp, sizeof(Temp));
742 if (_chdir(ts->FileDir) != 0)
743 strncpy_s(ts->FileDir, sizeof(ts->FileDir), ts->HomeDir, _TRUNCATE);
744 _chdir(Temp);
745 }
746
747 /* filter on file send (2007.6.5 maya) */
748 GetPrivateProfileString(Section, "FileSendFilter", "",
749 ts->FileSendFilter, sizeof(ts->FileSendFilter),
750 FName);
751
752 /*--------------------------------------------------*/
753 /* 8 bit control code flag -- special option */
754 if (GetOnOff(Section, "Accept8BitCtrl", FName, TRUE))
755 ts->TermFlag |= TF_ACCEPT8BITCTRL;
756
757 /* Wrong sequence flag -- special option */
758 if (GetOnOff(Section, "AllowWrongSequence", FName, FALSE))
759 ts->TermFlag |= TF_ALLOWWRONGSEQUENCE;
760
761 if (((ts->TermFlag & TF_ALLOWWRONGSEQUENCE) == 0) &&
762 (ts->KanjiOut == IdKanjiOutH))
763 ts->KanjiOut = IdKanjiOutJ;
764
765 // Auto file renaming --- special option
766 if (GetOnOff(Section, "AutoFileRename", FName, FALSE))
767 ts->FTFlag |= FT_RENAME;
768
769 // Auto invoking (character set->G0->GL) --- special option
770 if (GetOnOff(Section, "AutoInvoke", FName, FALSE))
771 ts->TermFlag |= TF_AUTOINVOKE;
772
773 // Auto text copy --- special option
774 ts->AutoTextCopy = GetOnOff(Section, "AutoTextCopy", FName, TRUE);
775
776 /* Back wrap -- special option */
777 if (GetOnOff(Section, "BackWrap", FName, FALSE))
778 ts->TermFlag |= TF_BACKWRAP;
779
780 /* Beep type -- special option */
781 GetPrivateProfileString(Section, "Beep", "", Temp, sizeof(Temp), FName);
782 if (_stricmp(Temp, "off") == 0)
783 ts->Beep = IdBeepOff;
784 else if (_stricmp(Temp, "visual") == 0)
785 ts->Beep = IdBeepVisual;
786 else
787 ts->Beep = IdBeepOn;
788
789 /* Beep on connection & disconnection -- special option */
790 if (GetOnOff(Section, "BeepOnConnect", FName, FALSE))
791 ts->PortFlag |= PF_BEEPONCONNECT;
792
793 /* Auto B-Plus activation -- special option */
794 if (GetOnOff(Section, "BPAuto", FName, FALSE))
795 ts->FTFlag |= FT_BPAUTO;
796 if ((ts->FTFlag & FT_BPAUTO) != 0) { /* Answerback */
797 strncpy_s(ts->Answerback, sizeof(ts->Answerback), "\020++\0200",
798 _TRUNCATE);
799 ts->AnswerbackLen = 5;
800 }
801
802 /* B-Plus ESCCTL flag -- special option */
803 if (GetOnOff(Section, "BPEscCtl", FName, FALSE))
804 ts->FTFlag |= FT_BPESCCTL;
805
806 /* B-Plus log -- special option */
807 if (GetOnOff(Section, "BPLog", FName, FALSE))
808 ts->LogFlag |= LOG_BP;
809
810 /* Clear serial port buffer when port opening -- special option */
811 ts->ClearComBuffOnOpen =
812 GetOnOff(Section, "ClearComBuffOnOpen", FName, TRUE);
813
814 /* Confirm disconnection -- special option */
815 if (GetOnOff(Section, "ConfirmDisconnect", FName, TRUE))
816 ts->PortFlag |= PF_CONFIRMDISCONN;
817
818 /* Ctrl code in Kanji -- special option */
819 if (GetOnOff(Section, "CtrlInKanji", FName, TRUE))
820 ts->TermFlag |= TF_CTRLINKANJI;
821
822 /* Debug flag -- special option */
823 ts->Debug = GetOnOff(Section, "Debug", FName, FALSE);
824
825 /* Delimiter list -- special option */
826 GetPrivateProfileString(Section, "DelimList",
827 "$20!\"#$24%&\'()*+,-./:;<=>?@[\\]^`{|}~",
828 Temp, sizeof(Temp), FName);
829 Hex2Str(Temp, ts->DelimList, sizeof(ts->DelimList));
830
831 /* regard DBCS characters as delimiters -- special option */
832 ts->DelimDBCS = GetOnOff(Section, "DelimDBCS", FName, TRUE);
833
834 // Enable popup menu -- special option
835 if (!GetOnOff(Section, "EnablePopupMenu", FName, TRUE))
836 ts->MenuFlag |= MF_NOPOPUP;
837
838 // Enable "Show menu" -- special option
839 if (!GetOnOff(Section, "EnableShowMenu", FName, TRUE))
840 ts->MenuFlag |= MF_NOSHOWMENU;
841
842 // Enable the status line -- special option
843 if (GetOnOff(Section, "EnableStatusLine", FName, TRUE))
844 ts->TermFlag |= TF_ENABLESLINE;
845
846 // fixed JIS --- special
847 if (GetOnOff(Section, "FixedJIS", FName, FALSE))
848 ts->TermFlag |= TF_FIXEDJIS;
849
850 /* IME Flag -- special option */
851 ts->UseIME = GetOnOff(Section, "IME", FName, TRUE);
852
853 /* IME-inline Flag -- special option */
854 ts->IMEInline = GetOnOff(Section, "IMEInline", FName, TRUE);
855
856 /* Kermit log -- special option */
857 if (GetOnOff(Section, "KmtLog", FName, FALSE))
858 ts->LogFlag |= LOG_KMT;
859
860 // Enable language selection -- special option
861 if (!GetOnOff(Section, "LanguageSelection", FName, TRUE))
862 ts->MenuFlag |= MF_NOLANGUAGE;
863
864 /* Maximum scroll buffer size -- special option */
865 ts->ScrollBuffMax =
866 GetPrivateProfileInt(Section, "MaxBuffSize", 10000, FName);
867 if (ts->ScrollBuffMax < 24)
868 ts->ScrollBuffMax = 10000;
869
870 /* Max com port number -- special option */
871 ts->MaxComPort = GetPrivateProfileInt(Section, "MaxComPort", 4, FName);
872 if (ts->MaxComPort < 4)
873 ts->MaxComPort = 4;
874 // COM16����99���g�� (2005.11.30 yutaka)
875 // 99����200���g�� (2007.7.23 maya)
876 if (ts->MaxComPort > MAXCOMPORT)
877 ts->MaxComPort = MAXCOMPORT;
878 if ((ts->ComPort < 1) || (ts->ComPort > ts->MaxComPort))
879 ts->ComPort = 1;
880
881 /* Non-blinking cursor -- special option */
882 ts->NonblinkingCursor =
883 GetOnOff(Section, "NonblinkingCursor", FName, FALSE);
884
885 // �t�H�[�J�X���������|���S���J�[�\�� (2008.1.24 yutaka)
886 ts->KillFocusCursor =
887 GetOnOff(Section, "KillFocusCursor", FName, TRUE);
888
889 /* Delay for pass-thru printing activation */
890 /* -- special option */
891 ts->PassThruDelay =
892 GetPrivateProfileInt(Section, "PassThruDelay", 3, FName);
893
894 /* Printer port for pass-thru printing */
895 /* -- special option */
896 GetPrivateProfileString(Section, "PassThruPort", "",
897 ts->PrnDev, sizeof(ts->PrnDev), FName);
898
899 /* Printer Font --- special option */
900 GetPrivateProfileString(Section, "PrnFont", "",
901 Temp, sizeof(Temp), FName);
902 if (strlen(Temp) == 0) {
903 ts->PrnFont[0] = 0;
904 ts->PrnFontSize.x = 0;
905 ts->PrnFontSize.y = 0;
906 ts->PrnFontCharSet = 0;
907 }
908 else {
909 GetNthString(Temp, 1, sizeof(ts->PrnFont), ts->PrnFont);
910 GetNthNum(Temp, 2, (int far *) &(ts->PrnFontSize.x));
911 GetNthNum(Temp, 3, (int far *) &(ts->PrnFontSize.y));
912 GetNthNum(Temp, 4, &(ts->PrnFontCharSet));
913 }
914
915 // Page margins (left, right, top, bottom) for printing
916 // -- special option
917 GetPrivateProfileString(Section, "PrnMargin", "50,50,50,50",
918 Temp, sizeof(Temp), FName);
919 for (i = 0; i <= 3; i++)
920 GetNthNum(Temp, 1 + i, &ts->PrnMargin[i]);
921
922 /* Quick-VAN log -- special option */
923 if (GetOnOff(Section, "QVLog", FName, FALSE))
924 ts->LogFlag |= LOG_QV;
925
926 /* Quick-VAN window size -- special */
927 ts->QVWinSize = GetPrivateProfileInt(Section, "QVWinSize", 8, FName);
928
929 /* Russian character set (print) -- special option */
930 GetPrivateProfileString(Section, "RussPrint", "",
931 Temp, sizeof(Temp), FName);
932 ts->RussPrint = str2id(RussList, Temp, IdWindows);
933
934 /* Scroll threshold -- special option */
935 ts->ScrollThreshold =
936 GetPrivateProfileInt(Section, "ScrollThreshold", 12, FName);
937
938 ts->MouseWheelScrollLine =
939 GetPrivateProfileInt(Section, "MouseWheelScrollLine", 3, FName);
940
941 // Select on activate -- special option
942 ts->SelOnActive = GetOnOff(Section, "SelectOnActivate", FName, TRUE);
943
944 /* Send 8bit control sequence -- special option */
945 ts->Send8BitCtrl = GetOnOff(Section, "Send8BitCtrl", FName, FALSE);
946
947 /* Startup macro -- special option */
948 GetPrivateProfileString(Section, "StartupMacro", "",
949 ts->MacroFN, sizeof(ts->MacroFN), FName);
950
951 /* TEK GIN Mouse keycode -- special option */
952 ts->GINMouseCode =
953 GetPrivateProfileInt(Section, "TEKGINMouseCode", 32, FName);
954
955 /* Telnet Auto Detect -- special option */
956 ts->TelAutoDetect = GetOnOff(Section, "TelAutoDetect", FName, TRUE);
957
958 /* Telnet binary flag -- special option */
959 ts->TelBin = GetOnOff(Section, "TelBin", FName, FALSE);
960
961 /* Telnet Echo flag -- special option */
962 ts->TelEcho = GetOnOff(Section, "TelEcho", FName, FALSE);
963
964 /* Telnet log -- special option */
965 if (GetOnOff(Section, "TelLog", FName, FALSE))
966 ts->LogFlag |= LOG_TEL;
967
968 /* TCP port num for telnet -- special option */
969 ts->TelPort = GetPrivateProfileInt(Section, "TelPort", 23, FName);
970
971 /* Telnet keep-alive packet(NOP command) interval -- special option */
972 ts->TelKeepAliveInterval =
973 GetPrivateProfileInt(Section, "TelKeepAliveInterval", 300, FName);
974
975 /* Max number of broadcast commad history */
976 ts->MaxBroadcatHistory =
977 GetPrivateProfileInt(Section, "MaxBroadcatHistory", 99, FName);
978
979 /* Local echo for non-telnet */
980 ts->TCPLocalEcho = GetOnOff(Section, "TCPLocalEcho", FName, FALSE);
981
982 /* "new-line (transmit)" option for non-telnet -- special option */
983 GetPrivateProfileString(Section, "TCPCRSend", "",
984 Temp, sizeof(Temp), FName);
985 if (_stricmp(Temp, "CR") == 0)
986 ts->TCPCRSend = IdCR;
987 else if (_stricmp(Temp, "CRLF") == 0)
988 ts->TCPCRSend = IdCRLF;
989 else
990 ts->TCPCRSend = 0; // disabled
991
992 /* Use text (background) color for "white (black)" --- special option */
993 if (GetOnOff(Section, "UseTextColor", FName, FALSE))
994 ts->ColorFlag |= CF_USETEXTCOLOR;
995
996 /* Title format -- special option */
997 ts->TitleFormat =
998 GetPrivateProfileInt(Section, "TitleFormat", 5, FName);
999
1000 /* VT Compatible Tab -- special option */
1001 ts->VTCompatTab = GetOnOff(Section, "VTCompatTab", FName, FALSE);
1002
1003 /* VT Font space --- special option */
1004 GetPrivateProfileString(Section, "VTFontSpace", "0,0,0,0",
1005 Temp, sizeof(Temp), FName);
1006 GetNthNum(Temp, 1, &ts->FontDX);
1007 GetNthNum(Temp, 2, &ts->FontDW);
1008 GetNthNum(Temp, 3, &ts->FontDY);
1009 GetNthNum(Temp, 4, &ts->FontDH);
1010 if (ts->FontDX < 0)
1011 ts->FontDX = 0;
1012 if (ts->FontDW < 0)
1013 ts->FontDW = 0;
1014 ts->FontDW = ts->FontDW + ts->FontDX;
1015 if (ts->FontDY < 0)
1016 ts->FontDY = 0;
1017 if (ts->FontDH < 0)
1018 ts->FontDH = 0;
1019 ts->FontDH = ts->FontDH + ts->FontDY;
1020
1021 // VT-print scaling factors (pixels per inch) --- special option
1022 GetPrivateProfileString(Section, "VTPPI", "0,0",
1023 Temp, sizeof(Temp), FName);
1024 GetNthNum(Temp, 1, (int far *) &ts->VTPPI.x);
1025 GetNthNum(Temp, 2, (int far *) &ts->VTPPI.y);
1026
1027 // TEK-print scaling factors (pixels per inch) --- special option
1028 GetPrivateProfileString(Section, "TEKPPI", "0,0",
1029 Temp, sizeof(Temp), FName);
1030 GetNthNum(Temp, 1, (int far *) &ts->TEKPPI.x);
1031 GetNthNum(Temp, 2, (int far *) &ts->TEKPPI.y);
1032
1033 // Show "Window" menu -- special option
1034 if (GetOnOff(Section, "WindowMenu", FName, TRUE))
1035 ts->MenuFlag |= MF_SHOWWINMENU;
1036
1037 /* XMODEM log -- special option */
1038 if (GetOnOff(Section, "XmodemLog", FName, FALSE))
1039 ts->LogFlag |= LOG_X;
1040
1041 /* YMODEM log -- special option */
1042 if (GetOnOff(Section, "YmodemLog", FName, FALSE))
1043 ts->LogFlag |= LOG_Y;
1044
1045 /* Auto ZMODEM activation -- special option */
1046 if (GetOnOff(Section, "ZmodemAuto", FName, FALSE))
1047 ts->FTFlag |= FT_ZAUTO;
1048
1049 /* ZMODEM data subpacket length for sending -- special */
1050 ts->ZmodemDataLen =
1051 GetPrivateProfileInt(Section, "ZmodemDataLen", 1024, FName);
1052 /* ZMODEM window size for sending -- special */
1053 ts->ZmodemWinSize =
1054 GetPrivateProfileInt(Section, "ZmodemWinSize", 32767, FName);
1055
1056 /* ZMODEM ESCCTL flag -- special option */
1057 if (GetOnOff(Section, "ZmodemEscCtl", FName, FALSE))
1058 ts->FTFlag |= FT_ZESCCTL;
1059
1060 /* ZMODEM log -- special option */
1061 if (GetOnOff(Section, "ZmodemLog", FName, FALSE))
1062 ts->LogFlag |= LOG_Z;
1063
1064 /* ZMODEM ���M�R�}���h (2007.12.21 yutaka) */
1065 GetPrivateProfileString(Section, "ZModemRcvCommand", "rz",
1066 ts->ZModemRcvCommand, sizeof(ts->ZModemRcvCommand), FName);
1067
1068 #ifndef NO_COPYLINE_FIX
1069
1070 /* Enable continued-line copy -- special option */
1071 ts->EnableContinuedLineCopy =
1072 GetOnOff(Section, "EnableContinuedLineCopy", FName, FALSE);
1073 #endif /* NO_COPYLINE_FIX */
1074
1075 ts->DisablePasteMouseRButton =
1076 GetOnOff(Section, "DisablePasteMouseRButton", FName, FALSE);
1077
1078 // added DisablePasteMouseMButton (2008.3.2 maya)
1079 ts->DisablePasteMouseMButton =
1080 GetOnOff(Section, "DisablePasteMouseMButton", FName, TRUE);
1081
1082 // added ConfirmPasteMouseRButton (2007.3.17 maya)
1083 ts->ConfirmPasteMouseRButton =
1084 GetOnOff(Section, "ConfirmPasteMouseRButton", FName, FALSE);
1085
1086 // added ConfirmChangePaste (2008.2.3 yutaka)
1087 ts->ConfirmChangePaste =
1088 GetOnOff(Section, "ConfirmChangePaste", FName, TRUE);
1089
1090 // added ScrollWindowClearScreen (2008.5.3 yutaka)
1091 ts->ScrollWindowClearScreen =
1092 GetOnOff(Section, "ScrollWindowClearScreen", FName, TRUE);
1093
1094 // added SelectOnlyByLButton (2007.11.20 maya)
1095 ts->SelectOnlyByLButton =
1096 GetOnOff(Section, "SelectOnlyByLButton", FName, TRUE);
1097
1098 // added DisableAcceleratorSendBreak (2007.3.17 maya)
1099 ts->DisableAcceleratorSendBreak =
1100 GetOnOff(Section, "DisableAcceleratorSendBreak", FName, FALSE);
1101
1102 // WinSock connecting timeout value (2007.1.11 yutaka)
1103 ts->ConnectingTimeout =
1104 GetPrivateProfileInt(Section, "ConnectingTimeout", 0, FName);
1105
1106 // mouse cursor
1107 GetPrivateProfileString(Section, "MouseCursor", "IBEAM",
1108 Temp, sizeof(Temp), FName);
1109 strncpy_s(ts->MouseCursorName, sizeof(ts->MouseCursorName), Temp,
1110 _TRUNCATE);
1111
1112 // Translucent window
1113 ts->AlphaBlend =
1114 GetPrivateProfileInt(Section, "AlphaBlend ", 255, FName);
1115 ts->AlphaBlend = max(0, ts->AlphaBlend);
1116 ts->AlphaBlend = min(255, ts->AlphaBlend);
1117
1118 // Cygwin install path
1119 GetPrivateProfileString(Section, "CygwinDirectory ", "c:\\cygwin",
1120 Temp, sizeof(Temp), FName);
1121 strncpy_s(ts->CygwinDirectory, sizeof(ts->CygwinDirectory), Temp,
1122 _TRUNCATE);
1123
1124 // Viewlog Editor path
1125 GetPrivateProfileString(Section, "ViewlogEditor ", "notepad.exe",
1126 Temp, sizeof(Temp), FName);
1127 strncpy_s(ts->ViewlogEditor, sizeof(ts->ViewlogEditor), Temp,
1128 _TRUNCATE);
1129
1130 // Locale for UTF-8
1131 GetPrivateProfileString(Section, "Locale ", DEFAULT_LOCALE,
1132 Temp, sizeof(Temp), FName);
1133 strncpy_s(ts->Locale, sizeof(ts->Locale), Temp, _TRUNCATE);
1134
1135 // CodePage
1136 ts->CodePage =
1137 GetPrivateProfileInt(Section, "CodePage ", DEFAULT_CODEPAGE,
1138 FName);
1139
1140 // UI language message file
1141 GetPrivateProfileString(Section, "UILanguageFile", "lang\\Default.lng",
1142 Temp, sizeof(Temp), FName);
1143 {
1144 char CurDir[MAX_PATH];
1145
1146 // �t���p�X�������O������������������������������
1147 strncpy_s(ts->UILanguageFile_ini, sizeof(ts->UILanguageFile_ini), Temp, _TRUNCATE);
1148
1149 GetCurrentDirectory(sizeof(CurDir), CurDir);
1150 SetCurrentDirectory(ts->HomeDir);
1151 _fullpath(ts->UILanguageFile, Temp, sizeof(ts->UILanguageFile));
1152 SetCurrentDirectory(CurDir);
1153 }
1154
1155 // Broadcast Command History (2007.3.3 maya)
1156 ts->BroadcastCommandHistory =
1157 GetOnOff(Section, "BroadcastCommandHistory", FName, FALSE);
1158
1159 // 337: 2007/03/20 Accept Broadcast
1160 ts->AcceptBroadcast =
1161 GetOnOff(Section, "AcceptBroadcast", FName, TRUE);
1162
1163 // Confirm send a file when drag and drop (2007.12.28 maya)
1164 ts->ConfirmFileDragAndDrop =
1165 GetOnOff(Section, "ConfirmFileDragAndDrop", FName, TRUE);
1166
1167 // Translate mouse wheel to cursor key when application cursor mode
1168 ts->TranslateWheelToCursor =
1169 GetOnOff(Section, "TranslateWheelToCursor", FName, TRUE);
1170
1171 // Display "New Connection" dialog on startup (2008.1.18 maya)
1172 ts->HostDialogOnStartup =
1173 GetOnOff(Section, "HostDialogOnStartup", FName, TRUE);
1174
1175 // Mouse event tracking
1176 ts->MouseEventTracking =
1177 GetOnOff(Section, "MouseEventTracking", FName, TRUE);
1178
1179 // Maximized bug tweak
1180 ts->MaximizedBugTweak =
1181 GetOnOff(Section, "MaximizedBugTweak", FName, TRUE);
1182
1183 // Convert Unicode symbol characters to DEC Special characters
1184 ts->UnicodeDecSpMapping =
1185 GetPrivateProfileInt(Section, "UnicodeToDecSpMapping", 3, FName);
1186
1187 // VT Window Icon
1188 GetPrivateProfileString(Section, "VTIcon", "Default",
1189 Temp, sizeof(Temp), FName);
1190 ts->VTIcon = IconName2IconId(Temp);
1191
1192 // Tek Window Icon
1193 GetPrivateProfileString(Section, "TEKIcon", "Default",
1194 Temp, sizeof(Temp), FName);
1195 ts->TEKIcon = IconName2IconId(Temp);
1196
1197 // Unknown Unicode Character
1198 ts->UnknownUnicodeCharaAsWide =
1199 GetOnOff(Section, "UnknownUnicodeCharacterAsWide", FName, FALSE);
1200
1201 #ifdef USE_NORMAL_BGCOLOR
1202 // UseNormalBGColor
1203 ts->UseNormalBGColor =
1204 GetOnOff(Section, "UseNormalBGColor", FName, FALSE);
1205 // 2006/03/11 by 337
1206 if (ts->UseNormalBGColor) {
1207 ts->VTBoldColor[1] =
1208 ts->VTBlinkColor[1] = ts->URLColor[1] = ts->VTColor[1];
1209 }
1210 #endif
1211
1212 // AutoScrollOnlyInBottomLine
1213 ts->AutoScrollOnlyInBottomLine =
1214 GetOnOff(Section, "AutoScrollOnlyInBottomLine", FName, FALSE);
1215
1216 // Accept remote-controlled window title changing
1217 GetPrivateProfileString(Section, "AcceptTitleChangeRequest", "overwrite",
1218 Temp, sizeof(Temp), FName);
1219 if (_stricmp(Temp, "overwrite") == 0 || _stricmp(Temp, "on") == 0)
1220 ts->AcceptTitleChangeRequest = IdTitleChangeRequestOverwrite;
1221 else if (_stricmp(Temp, "ahead") == 0)
1222 ts->AcceptTitleChangeRequest = IdTitleChangeRequestAhead;
1223 else if (_stricmp(Temp, "last") == 0)
1224 ts->AcceptTitleChangeRequest = IdTitleChangeRequestLast;
1225 else
1226 ts->AcceptTitleChangeRequest = IdTitleChangeRequestOff;
1227
1228 // Size of paste confirm dialog
1229 GetPrivateProfileString(Section, "PasteDialogSize", "330,220",
1230 Temp, sizeof(Temp), FName);
1231 GetNthNum(Temp, 1, &ts->PasteDialogSize.cx);
1232 GetNthNum(Temp, 2, &ts->PasteDialogSize.cy);
1233 if (ts->PasteDialogSize.cx < 0)
1234 ts->PasteDialogSize.cx = 330;
1235 if (ts->PasteDialogSize.cy < 0)
1236 ts->PasteDialogSize.cy = 220;
1237
1238 // Disable mouse event tracking when Control-Key is pressed.
1239 ts->DisableMouseTrackingByCtrl =
1240 GetOnOff(Section, "DisableMouseTrackingByCtrl", FName, TRUE);
1241
1242 // Disable TranslateWheelToCursor setting when Control-Key is pressed.
1243 ts->DisableWheelToCursorByCtrl =
1244 GetOnOff(Section, "DisableWheelToCursorByCtrl", FName, TRUE);
1245
1246 // Strict Key Mapping.
1247 ts->StrictKeyMapping =
1248 GetOnOff(Section, "StrictKeyMapping", FName, FALSE);
1249
1250 // added Wait4allMacroCommand (2009.3.23 yutaka)
1251 ts->Wait4allMacroCommand =
1252 GetOnOff(Section, "Wait4allMacroCommand", FName, FALSE);
1253 }
1254
1255 void FAR PASCAL WriteIniFile(PCHAR FName, PTTSet ts)
1256 {
1257 int i;
1258 char Temp[MAXPATHLEN];
1259 char buf[20];
1260
1261 /* version */
1262 WritePrivateProfileString(Section, "Version", "2.3", FName);
1263
1264 /* Language */
1265 if (ts->Language == IdJapanese)
1266 strncpy_s(Temp, sizeof(Temp), "Japanese", _TRUNCATE);
1267 else if (ts->Language == IdRussian)
1268 strncpy_s(Temp, sizeof(Temp), "Russian", _TRUNCATE);
1269 else if (ts->Language == IdKorean) //HKS
1270 strncpy_s(Temp, sizeof(Temp), "Korean", _TRUNCATE);
1271 else
1272 strncpy_s(Temp, sizeof(Temp), "English", _TRUNCATE);
1273 WritePrivateProfileString(Section, "Language", Temp, FName);
1274
1275 /* Port type */
1276 if (ts->PortType == IdSerial)
1277 strncpy_s(Temp, sizeof(Temp), "serial", _TRUNCATE);
1278 else /* IdFile -> IdTCPIP */
1279 strncpy_s(Temp, sizeof(Temp), "tcpip", _TRUNCATE);
1280
1281 WritePrivateProfileString(Section, "Port", Temp, FName);
1282
1283 /* Save win position */
1284 if (ts->SaveVTWinPos) {
1285 /* VT win position */
1286 WriteInt2(Section, "VTPos", FName, ts->VTPos.x, ts->VTPos.y);
1287 }
1288
1289 /* VT terminal size */
1290 WriteInt2(Section, "TerminalSize", FName,
1291 ts->TerminalWidth, ts->TerminalHeight);
1292
1293 /* Terminal size = Window size */
1294 WriteOnOff(Section, "TermIsWin", FName, ts->TermIsWin);
1295
1296 /* Auto window resize flag */
1297 WriteOnOff(Section, "AutoWinResize", FName, ts->AutoWinResize);
1298
1299 /* CR Receive */
1300 if (ts->CRReceive == IdCRLF) {
1301 strncpy_s(Temp, sizeof(Temp), "CRLF", _TRUNCATE);
1302 }
1303 else if (ts->CRReceive == IdLF) {
1304 strncpy_s(Temp, sizeof(Temp), "LF", _TRUNCATE);
1305 }
1306 else {
1307 strncpy_s(Temp, sizeof(Temp), "CR", _TRUNCATE);
1308 }
1309 WritePrivateProfileString(Section, "CRReceive", Temp, FName);
1310
1311 /* CR Send */
1312 if (ts->CRSend == IdCRLF)
1313 strncpy_s(Temp, sizeof(Temp), "CRLF", _TRUNCATE);
1314 else
1315 strncpy_s(Temp, sizeof(Temp), "CR", _TRUNCATE);
1316 WritePrivateProfileString(Section, "CRSend", Temp, FName);
1317
1318 /* Local echo */
1319 WriteOnOff(Section, "LocalEcho", FName, ts->LocalEcho);
1320
1321 /* Answerback */
1322 if ((ts->FTFlag & FT_BPAUTO) == 0) {
1323 Str2Hex(ts->Answerback, Temp, ts->AnswerbackLen,
1324 sizeof(Temp) - 1, TRUE);
1325 WritePrivateProfileString(Section, "Answerback", Temp, FName);
1326 }
1327
1328 /* Kanji Code (receive) */
1329 switch (ts->KanjiCode) {
1330 case IdEUC:
1331 strncpy_s(Temp, sizeof(Temp), "EUC", _TRUNCATE);
1332 break;
1333 case IdJIS:
1334 strncpy_s(Temp, sizeof(Temp), "JIS", _TRUNCATE);
1335 break;
1336 case IdUTF8:
1337 strncpy_s(Temp, sizeof(Temp), "UTF-8", _TRUNCATE);
1338 break;
1339 case IdUTF8m:
1340 strncpy_s(Temp, sizeof(Temp), "UTF-8m", _TRUNCATE);
1341 break;
1342 default:
1343 strncpy_s(Temp, sizeof(Temp), "SJIS", _TRUNCATE);
1344 }
1345 WritePrivateProfileString(Section, "KanjiReceive", Temp, FName);
1346
1347 /* Katakana (receive) */
1348 if (ts->JIS7Katakana == 1)
1349 strncpy_s(Temp, sizeof(Temp), "7", _TRUNCATE);
1350 else
1351 strncpy_s(Temp, sizeof(Temp), "8", _TRUNCATE);
1352
1353 WritePrivateProfileString(Section, "KatakanaReceive", Temp, FName);
1354
1355 /* Kanji Code (transmit) */
1356 switch (ts->KanjiCodeSend) {
1357 case IdEUC:
1358 strncpy_s(Temp, sizeof(Temp), "EUC", _TRUNCATE);
1359 break;
1360 case IdJIS:
1361 strncpy_s(Temp, sizeof(Temp), "JIS", _TRUNCATE);
1362 break;
1363 case IdUTF8:
1364 strncpy_s(Temp, sizeof(Temp), "UTF-8", _TRUNCATE);
1365 break;
1366 default:
1367 strncpy_s(Temp, sizeof(Temp), "SJIS", _TRUNCATE);
1368 }
1369 WritePrivateProfileString(Section, "KanjiSend", Temp, FName);
1370
1371 /* Katakana (transmit) */
1372 if (ts->JIS7KatakanaSend == 1)
1373 strncpy_s(Temp, sizeof(Temp), "7", _TRUNCATE);
1374 else
1375 strncpy_s(Temp, sizeof(Temp), "8", _TRUNCATE);
1376
1377 WritePrivateProfileString(Section, "KatakanaSend", Temp, FName);
1378
1379 /* KanjiIn */
1380 if (ts->KanjiIn == IdKanjiInA)
1381 strncpy_s(Temp, sizeof(Temp), "@", _TRUNCATE);
1382 else
1383 strncpy_s(Temp, sizeof(Temp), "B", _TRUNCATE);
1384
1385 WritePrivateProfileString(Section, "KanjiIn", Temp, FName);
1386
1387 /* KanjiOut */
1388 switch (ts->KanjiOut) {
1389 case IdKanjiOutB:
1390 strncpy_s(Temp, sizeof(Temp), "B", _TRUNCATE);
1391 break;
1392 case IdKanjiOutH:
1393 strncpy_s(Temp, sizeof(Temp), "H", _TRUNCATE);
1394 break;
1395 default:
1396 strncpy_s(Temp, sizeof(Temp), "J", _TRUNCATE);
1397 }
1398 WritePrivateProfileString(Section, "KanjiOut", Temp, FName);
1399
1400 // new configuration
1401 WriteInt(Section, "ConnectingTimeout", FName, ts->ConnectingTimeout);
1402
1403 WriteOnOff(Section, "DisablePasteMouseRButton", FName,
1404 ts->DisablePasteMouseRButton);
1405
1406 // added DisablePasteMouseMButton (2008.3.2 maya)
1407 WriteOnOff(Section, "DisablePasteMouseMButton", FName,
1408 ts->DisablePasteMouseMButton);
1409
1410 // added ConfirmPasteMouseRButton (2007.3.17 maya)
1411 WriteOnOff(Section, "ConfirmPasteMouseRButton", FName,
1412 ts->ConfirmPasteMouseRButton);
1413
1414 // added ConfirmChangePaste
1415 WriteOnOff(Section, "ConfirmChangePaste", FName,
1416 ts->ConfirmChangePaste);
1417
1418 // added ScrollWindowClearScreen
1419 WriteOnOff(Section, "ScrollWindowClearScreen", FName,
1420 ts->ScrollWindowClearScreen);
1421
1422 // added SelectOnlyByLButton (2007.11.20 maya)
1423 WriteOnOff(Section, "SelectOnlyByLButton", FName,
1424 ts->SelectOnlyByLButton);
1425 // added DisableAcceleratorSendBreak (2007.3.17 maya)
1426 WriteOnOff(Section, "DisableAcceleratorSendBreak", FName,
1427 ts->DisableAcceleratorSendBreak);
1428 WriteOnOff(Section, "EnableContinuedLineCopy", FName,
1429 ts->EnableContinuedLineCopy);
1430 WritePrivateProfileString(Section, "MouseCursor", ts->MouseCursorName,
1431 FName);
1432 _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d", ts->AlphaBlend);
1433 WritePrivateProfileString(Section, "AlphaBlend", Temp, FName);
1434 WritePrivateProfileString(Section, "CygwinDirectory",
1435 ts->CygwinDirectory, FName);
1436 WritePrivateProfileString(Section, "ViewlogEditor", ts->ViewlogEditor,
1437 FName);
1438 WritePrivateProfileString(Section, "Locale", ts->Locale, FName);
1439 _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d", ts->CodePage);
1440 WritePrivateProfileString(Section, "CodePage", Temp, FName);
1441
1442 // ANSI color(2004.9.5 yutaka)
1443 Temp[0] = '\0';
1444 for (i = 0; i < 15; i++) {
1445 _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%d,%d,%d,%d, ",
1446 i,
1447 GetRValue(ts->ANSIColor[i]),
1448 GetGValue(ts->ANSIColor[i]),
1449 GetBValue(ts->ANSIColor[i])
1450 );
1451 strncat_s(Temp, sizeof(Temp), buf, _TRUNCATE);
1452 }
1453 i = 15;
1454 _snprintf_s(buf, sizeof(buf), _TRUNCATE, "%d,%d,%d,%d",
1455 i,
1456 GetRValue(ts->ANSIColor[i]),
1457 GetGValue(ts->ANSIColor[i]),
1458 GetBValue(ts->ANSIColor[i])
1459 );
1460 strncat_s(Temp, sizeof(Temp), buf, _TRUNCATE);
1461 WritePrivateProfileString(Section, "ANSIColor", Temp, FName);
1462
1463 /* AutoWinChange VT<->TEK */
1464 WriteOnOff(Section, "AutoWinSwitch", FName, ts->AutoWinSwitch);
1465
1466 /* Terminal ID */
1467 id2str(TermList, ts->TerminalID, IdVT100, Temp, sizeof(Temp));
1468 WritePrivateProfileString(Section, "TerminalID", Temp, FName);
1469
1470 /* Russian character set (host) */
1471 id2str(RussList, ts->RussHost, IdKOI8, Temp, sizeof(Temp));
1472 WritePrivateProfileString(Section, "RussHost", Temp, FName);
1473
1474 /* Russian character set (client) */
1475 id2str(RussList, ts->RussClient, IdWindows, Temp, sizeof(Temp));
1476 WritePrivateProfileString(Section, "RussClient", Temp, FName);
1477
1478 /* Title text */
1479 WritePrivateProfileString(Section, "Title", ts->Title, FName);
1480
1481 /* Cursor shape */
1482 switch (ts->CursorShape) {
1483 case IdVCur:
1484 strncpy_s(Temp, sizeof(Temp), "vertical", _TRUNCATE);
1485 break;
1486 case IdHCur:
1487 strncpy_s(Temp, sizeof(Temp), "horizontal", _TRUNCATE);
1488 break;
1489 default:
1490 strncpy_s(Temp, sizeof(Temp), "block", _TRUNCATE);
1491 }
1492 WritePrivateProfileString(Section, "CursorShape", Temp, FName);
1493
1494 /* Hide title */
1495 WriteOnOff(Section, "HideTitle", FName, ts->HideTitle);
1496
1497 /* Popup menu */
1498 WriteOnOff(Section, "PopupMenu", FName, ts->PopupMenu);
1499
1500 /* PC-Style bold color mapping */
1501 WriteOnOff(Section, "PcBoldColor", FName,
1502 (WORD) (ts->ColorFlag & CF_PCBOLD16));
1503
1504 /* aixterm 16 colors mode */
1505 WriteOnOff(Section, "Aixterm16Color", FName,
1506 (WORD) (ts->ColorFlag & CF_AIXTERM16));
1507
1508 /* xterm 256 colors mode */
1509 WriteOnOff(Section, "Xterm256Color", FName,
1510 (WORD) (ts->ColorFlag & CF_XTERM256));
1511
1512 /* Enable scroll buffer */
1513 WriteOnOff(Section, "EnableScrollBuff", FName, ts->EnableScrollBuff);
1514
1515 /* Scroll buffer size */
1516 WriteInt(Section, "ScrollBuffSize", FName, ts->ScrollBuffSize);
1517
1518 /* VT Color */
1519 for (i = 0; i <= 1; i++) {
1520 if (ts->ColorFlag & CF_REVERSEVIDEO) {
1521 if (ts->ColorFlag & CF_REVERSECOLOR) {
1522 ts->TmpColor[0][i * 3] = GetRValue(ts->VTReverseColor[i]);
1523 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->VTReverseColor[i]);
1524 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->VTReverseColor[i]);
1525 }
1526 else {
1527 ts->TmpColor[0][i * 3] = GetRValue(ts->VTColor[!i]);
1528 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->VTColor[!i]);
1529 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->VTColor[!i]);
1530 }
1531 }
1532 else {
1533 ts->TmpColor[0][i * 3] = GetRValue(ts->VTColor[i]);
1534 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->VTColor[i]);
1535 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->VTColor[i]);
1536 }
1537 }
1538 WriteInt6(Section, "VTColor", FName,
1539 ts->TmpColor[0][0], ts->TmpColor[0][1], ts->TmpColor[0][2],
1540 ts->TmpColor[0][3], ts->TmpColor[0][4], ts->TmpColor[0][5]);
1541
1542 /* VT Bold Color */
1543 for (i = 0; i <= 1; i++) {
1544 if (ts->ColorFlag & CF_REVERSEVIDEO) {
1545 ts->TmpColor[0][i * 3] = GetRValue(ts->VTBoldColor[!i]);
1546 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->VTBoldColor[!i]);
1547 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->VTBoldColor[!i]);
1548 }
1549 else {
1550 ts->TmpColor[0][i * 3] = GetRValue(ts->VTBoldColor[i]);
1551 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->VTBoldColor[i]);
1552 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->VTBoldColor[i]);
1553 }
1554 }
1555 WriteInt6(Section, "VTBoldColor", FName,
1556 ts->TmpColor[0][0], ts->TmpColor[0][1], ts->TmpColor[0][2],
1557 ts->TmpColor[0][3], ts->TmpColor[0][4], ts->TmpColor[0][5]);
1558
1559 /* VT Blink Color */
1560 for (i = 0; i <= 1; i++) {
1561 if (ts->ColorFlag & CF_REVERSEVIDEO) {
1562 ts->TmpColor[0][i * 3] = GetRValue(ts->VTBlinkColor[!i]);
1563 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->VTBlinkColor[!i]);
1564 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->VTBlinkColor[!i]);
1565 }
1566 else {
1567 ts->TmpColor[0][i * 3] = GetRValue(ts->VTBlinkColor[i]);
1568 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->VTBlinkColor[i]);
1569 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->VTBlinkColor[i]);
1570 }
1571 }
1572 WriteInt6(Section, "VTBlinkColor", FName,
1573 ts->TmpColor[0][0], ts->TmpColor[0][1], ts->TmpColor[0][2],
1574 ts->TmpColor[0][3], ts->TmpColor[0][4], ts->TmpColor[0][5]);
1575
1576 /* VT Reverse Color */
1577 for (i = 0; i <= 1; i++) {
1578 if (ts->ColorFlag & CF_REVERSEVIDEO && ts->ColorFlag & CF_REVERSECOLOR) {
1579 ts->TmpColor[0][i * 3] = GetRValue(ts->VTColor[i]);
1580 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->VTColor[i]);
1581 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->VTColor[i]);
1582 }
1583 else {
1584 ts->TmpColor[0][i * 3] = GetRValue(ts->VTReverseColor[i]);
1585 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->VTReverseColor[i]);
1586 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->VTReverseColor[i]);
1587 }
1588 }
1589 WriteInt6(Section, "VTReverseColor", FName,
1590 ts->TmpColor[0][0], ts->TmpColor[0][1], ts->TmpColor[0][2],
1591 ts->TmpColor[0][3], ts->TmpColor[0][4], ts->TmpColor[0][5]);
1592
1593 WriteOnOff(Section, "EnableClickableUrl", FName,
1594 ts->EnableClickableUrl);
1595
1596 /* URL color */
1597 for (i = 0; i <= 1; i++) {
1598 if (ts->ColorFlag & CF_REVERSEVIDEO) {
1599 ts->TmpColor[0][i * 3] = GetRValue(ts->URLColor[!i]);
1600 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->URLColor[!i]);
1601 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->URLColor[!i]);
1602 }
1603 else {
1604 ts->TmpColor[0][i * 3] = GetRValue(ts->URLColor[i]);
1605 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->URLColor[i]);
1606 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->URLColor[i]);
1607 }
1608 }
1609 WriteInt6(Section, "URLColor", FName,
1610 ts->TmpColor[0][0], ts->TmpColor[0][1], ts->TmpColor[0][2],
1611 ts->TmpColor[0][3], ts->TmpColor[0][4], ts->TmpColor[0][5]);
1612
1613 WriteOnOff(Section, "EnableBoldAttrColor", FName,
1614 (WORD) (ts->ColorFlag & CF_BOLDCOLOR));
1615
1616 WriteOnOff(Section, "EnableBlinkAttrColor", FName,
1617 (WORD) (ts->ColorFlag & CF_BLINKCOLOR));
1618
1619 WriteOnOff(Section, "EnableReverseAttrColor", FName,
1620 (WORD) (ts->ColorFlag & CF_REVERSECOLOR));
1621
1622 WriteOnOff(Section, "EnableURLColor", FName,
1623 (WORD) (ts->ColorFlag & CF_URLCOLOR));
1624
1625 WriteOnOff(Section, "EnableANSIColor", FName,
1626 (WORD) (ts->ColorFlag & CF_ANSICOLOR));
1627
1628 /* TEK Color */
1629 for (i = 0; i <= 1; i++) {
1630 ts->TmpColor[0][i * 3] = GetRValue(ts->TEKColor[i]);
1631 ts->TmpColor[0][i * 3 + 1] = GetGValue(ts->TEKColor[i]);
1632 ts->TmpColor[0][i * 3 + 2] = GetBValue(ts->TEKColor[i]);
1633 }
1634 WriteInt6(Section, "TEKColor", FName,
1635 ts->TmpColor[0][0], ts->TmpColor[0][1], ts->TmpColor[0][2],
1636 ts->TmpColor[0][3], ts->TmpColor[0][4], ts->TmpColor[0][5]);
1637
1638 /* TEK color emulation */
1639 WriteOnOff(Section, "TEKColorEmulation", FName, ts->TEKColorEmu);
1640
1641 /* VT Font */
1642 WriteFont(Section, "VTFont", FName,
1643 ts->VTFont, ts->VTFontSize.x, ts->VTFontSize.y,
1644 ts->VTFontCharSet);
1645
1646 /* Enable bold font flag */
1647 WriteOnOff(Section, "EnableBold", FName, ts->EnableBold);
1648
1649 /* Russian character set (font) */
1650 id2str(RussList, ts->RussFont, IdWindows, Temp, sizeof(Temp));
1651 WritePrivateProfileString(Section, "RussFont", Temp, FName);
1652
1653 /* TEK Font */
1654 WriteFont(Section, "TEKFont", FName,
1655 ts->TEKFont, ts->TEKFontSize.x, ts->TEKFontSize.y,
1656 ts->TEKFontCharSet);
1657
1658 /* BS key */
1659 if (ts->BSKey == IdDEL)
1660 strncpy_s(Temp, sizeof(Temp), "DEL", _TRUNCATE);
1661 else
1662 strncpy_s(Temp, sizeof(Temp), "BS", _TRUNCATE);
1663 WritePrivateProfileString(Section, "BSKey", Temp, FName);
1664
1665 /* Delete key */
1666 WriteOnOff(Section, "DeleteKey", FName, ts->DelKey);
1667
1668 /* Meta key */
1669 WriteOnOff(Section, "MetaKey", FName, ts->MetaKey);
1670
1671 /* Application Keypad */
1672 WriteOnOff(Section, "DisableAppKeypad", FName, ts->DisableAppKeypad);
1673
1674 /* Application Cursor */
1675 WriteOnOff(Section, "DisableAppCursor", FName, ts->DisableAppCursor);
1676
1677 /* Russian keyboard type */
1678 id2str(RussList2, ts->RussKeyb, IdWindows, Temp, sizeof(Temp));
1679 WritePrivateProfileString(Section, "RussKeyb", Temp, FName);
1680
1681 /* Serial port ID */
1682 _snprintf_s(Temp, sizeof(Temp), _TRUNCATE, "%d", ts->ComPort);
1683 WritePrivateProfileString(Section, "ComPort", Temp, FName);
1684
1685 /* Baud rate */
1686 id2str(BaudList, ts->Baud, IdBaud9600, Temp, sizeof(Temp));
1687 WritePrivateProfileString(Section, "BaudRate", Temp, FName);
1688
1689 /* Parity */
1690 switch (ts->Parity) {
1691 case IdParityEven:
1692 strncpy_s(Temp, sizeof(Temp), "even", _TRUNCATE);
1693 break;
1694 case IdParityOdd:
1695 strncpy_s(Temp, sizeof(Temp), "odd", _TRUNCATE);
1696 break;
1697 default:
1698 strncpy_s(Temp, sizeof(Temp), "none", _TRUNCATE);
1699 }
1700 WritePrivateProfileString(Section, "Parity", Temp, FName);
1701
1702 /* Data bit */
1703 if (ts->DataBit == IdDataBit7)
1704 strncpy_s(Temp, sizeof(Temp), "7", _TRUNCATE);
1705 else
1706 strncpy_s(Temp, sizeof(Temp), "8", _TRUNCATE);
1707
1708 WritePrivateProfileString(Section, "DataBit", Temp, FName);
1709
1710 /* Stop bit */
1711 if (ts->StopBit == IdStopBit2)
1712 strncpy_s(Temp, sizeof(Temp), "2", _TRUNCATE);
1713 else
1714 strncpy_s(Temp, sizeof(Temp), "1", _TRUNCATE);
1715
1716 WritePrivateProfileString(Section, "StopBit", Temp, FName);
1717
1718 /* Flow control */
1719 switch (ts->Flow) {
1720 case IdFlowX:
1721 strncpy_s(Temp, sizeof(Temp), "x", _TRUNCATE);
1722 break;
1723 case IdFlowHard:
1724 strncpy_s(Temp, sizeof(Temp), "hard", _TRUNCATE);
1725 break;
1726 default:
1727 strncpy_s(Temp, sizeof(Temp), "none", _TRUNCATE);
1728 }
1729 WritePrivateProfileString(Section, "FlowCtrl", Temp, FName);
1730
1731 /* Delay per character */
1732 WriteInt(Section, "DelayPerChar", FName, ts->DelayPerChar);
1733
1734 /* Delay per line */
1735 WriteInt(Section, "DelayPerLine", FName, ts->DelayPerLine);
1736
1737 /* Telnet flag */
1738 WriteOnOff(Section, "Telnet", FName, ts->Telnet);
1739
1740 /* Telnet terminal type */
1741 WritePrivateProfileString(Section, "TermType", ts->TermType, FName);
1742
1743 /* TCP port num for non-telnet */
1744 WriteUint(Section, "TCPPort", FName, ts->TCPPort);
1745
1746 /* Auto close flag */
1747 WriteOnOff(Section, "AutoWinClose", FName, ts->AutoWinClose);
1748
1749 /* History list */
1750 WriteOnOff(Section, "Historylist", FName, ts->HistoryList);
1751
1752 /* File transfer binary flag */
1753 WriteOnOff(Section, "TransBin", FName, ts->TransBin);
1754
1755 /* Log append */
1756 WriteOnOff(Section, "LogAppend", FName, ts->Append);
1757
1758 /* File transfer binary flag */
1759 WriteOnOff(Section, "LogTypePlainText", FName, ts->LogTypePlainText);
1760
1761 /* Log with timestamp (2006.7.23 maya) */
1762 WriteOnOff(Section, "LogTimestamp", FName, ts->LogTimestamp);
1763
1764 /* Log without transfer dialog */
1765 WriteOnOff(Section, "LogHideDialog", FName, ts->LogHideDialog);
1766
1767 /* Default Log file name (2006.8.28 maya) */
1768 WritePrivateProfileString(Section, "LogDefaultName",
1769 ts->LogDefaultName, FName);
1770
1771 /* Default Log file path (2007.5.30 maya) */
1772 WritePrivateProfileString(Section, "LogDefaultPath",
1773 ts->LogDefaultPath, FName);
1774
1775 /* Auto start logging (2007.5.31 maya) */
1776 WriteOnOff(Section, "LogAutoStart", FName, ts->LogAutoStart);
1777
1778 /* XMODEM option */
1779 switch (ts->XmodemOpt) {
1780 case XoptCRC:
1781 strncpy_s(Temp, sizeof(Temp), "crc", _TRUNCATE);
1782 break;
1783 case Xopt1K:
1784 strncpy_s(Temp, sizeof(Temp), "1k", _TRUNCATE);
1785 break;
1786 default:
1787 strncpy_s(Temp, sizeof(Temp), "checksum", _TRUNCATE);
1788 }
1789 WritePrivateProfileString(Section, "XmodemOpt", Temp, FName);
1790
1791 /* XMODEM binary flag */
1792 WriteOnOff(Section, "XmodemBin", FName, ts->XmodemBin);
1793
1794 /* XMODEM ���M�R�}���h (2007.12.21 yutaka) */
1795 WritePrivateProfileString(Section, "XmodemRcvCommand",
1796 ts->XModemRcvCommand, FName);
1797
1798 /* Default directory for file transfer */
1799 WritePrivateProfileString(Section, "FileDir", ts->FileDir, FName);
1800
1801 /* filter on file send (2007.6.5 maya) */
1802 WritePrivateProfileString(Section, "FileSendFilter",
1803 ts->FileSendFilter, FName);
1804
1805 /*------------------------------------------------------------------*/
1806 /* 8 bit control code flag -- special option */
1807 WriteOnOff(Section, "Accept8BitCtrl", FName,
1808 (WORD) (ts->TermFlag & TF_ACCEPT8BITCTRL));
1809
1810 /* Wrong sequence flag -- special option */
1811 WriteOnOff(Section, "AllowWrongSequence", FName,
1812 (WORD) (ts->TermFlag & TF_ALLOWWRONGSEQUENCE));
1813
1814 /* Auto file renaming --- special option */
1815 WriteOnOff(Section, "AutoFileRename", FName,
1816 (WORD) (ts->FTFlag & FT_RENAME));
1817
1818 /* Auto text copy --- special option */
1819 WriteOnOff(Section, "AutoTextCopy", FName, ts->AutoTextCopy);
1820
1821 /* Back wrap -- special option */
1822 WriteOnOff(Section, "BackWrap", FName,
1823 (WORD) (ts->TermFlag & TF_BACKWRAP));
1824
1825 /* Beep type -- special option */
1826 WriteOnOff(Section, "Beep", FName, ts->Beep);
1827 switch (ts->Beep) {
1828 case IdBeepOff:
1829 WritePrivateProfileString(Section, "Beep", "off", FName);
1830 break;
1831 case IdBeepOn:
1832 WritePrivateProfileString(Section, "Beep", "on", FName);
1833 break;
1834 case IdBeepVisual:
1835 WritePrivateProfileString(Section, "Beep", "visual", FName);
1836 break;
1837 }
1838
1839 /* Beep on connection & disconnection -- special option */
1840 WriteOnOff(Section, "BeepOnConnect", FName,
1841 (WORD) (ts->PortFlag & PF_BEEPONCONNECT));
1842
1843 /* Auto B-Plus activation -- special option */
1844 WriteOnOff(Section, "BPAuto", FName, (WORD) (ts->FTFlag & FT_BPAUTO));
1845
1846 /* B-Plus ESCCTL flag -- special option */
1847 WriteOnOff(Section, "BPEscCtl", FName,
1848 (WORD) (ts->FTFlag & FT_BPESCCTL));
1849
1850 /* B-Plus log -- special option */
1851 WriteOnOff(Section, "BPLog", FName, (WORD) (ts->LogFlag & LOG_BP));
1852
1853 /* Clear serial port buffer when port opening -- special option */
1854 WriteOnOff(Section, "ClearComBuffOnOpen", FName, ts->ClearComBuffOnOpen);
1855
1856 /* Confirm disconnection -- special option */
1857 WriteOnOff(Section, "ConfirmDisconnect", FName,
1858 (WORD) (ts->PortFlag & PF_CONFIRMDISCONN));
1859
1860 /* Ctrl code in Kanji -- special option */
1861 WriteOnOff(Section, "CtrlInKanji", FName,
1862 (WORD) (ts->TermFlag & TF_CTRLINKANJI));
1863
1864 /* Debug flag -- special option */
1865 WriteOnOff(Section, "Debug", FName, ts->Debug);
1866
1867 /* Delimiter list -- special option */
1868 Str2Hex(ts->DelimList, Temp, strlen(ts->DelimList),
1869 sizeof(Temp) - 1, TRUE);
1870 WritePrivateProfileString(Section, "DelimList", Temp, FName);
1871
1872 /* regard DBCS characters as delimiters -- special option */
1873 WriteOnOff(Section, "DelimDBCS", FName, ts->DelimDBCS);
1874
1875 // Enable popup menu -- special option
1876 if ((ts->MenuFlag & MF_NOPOPUP) == 0)
1877 WriteOnOff(Section, "EnablePopupMenu", FName, 1);
1878 else
1879 WriteOnOff(Section, "EnablePopupMenu", FName, 0);
1880
1881 // Enable "Show menu" -- special option
1882 if ((ts->MenuFlag & MF_NOSHOWMENU) == 0)
1883 WriteOnOff(Section, "EnableShowMenu", FName, 1);
1884 else
1885 WriteOnOff(Section, "EnableShowMenu", FName, 0);
1886
1887 /* Enable the status line -- special option */
1888 WriteOnOff(Section, "EnableStatusLine", FName,
1889 (WORD) (ts->TermFlag & TF_ENABLESLINE));
1890
1891 /* IME Flag -- special option */
1892 WriteOnOff(Section, "IME", FName, ts->UseIME);
1893
1894 /* IME-inline Flag -- special option */
1895 WriteOnOff(Section, "IMEInline", FName, ts->IMEInline);
1896
1897 /* Kermit log -- special option */
1898 WriteOnOff(Section, "KmtLog", FName, (WORD) (ts->LogFlag & LOG_KMT));
1899
1900 // Enable language selection -- special option
1901 if ((ts->MenuFlag & MF_NOLANGUAGE) == 0)
1902 WriteOnOff(Section, "LanguageSelection", FName, 1);
1903 else
1904 WriteOnOff(Section, "LanguageSelection", FName, 0);
1905
1906 /* Maximum scroll buffer size -- special option */
1907 WriteInt(Section, "MaxBuffSize", FName, ts->ScrollBuffMax);
1908
1909 /* Max com port number -- special option */
1910 WriteInt(Section, "MaxComPort", FName, ts->MaxComPort);
1911
1912 /* Non-blinking cursor -- special option */
1913 WriteOnOff(Section, "NonblinkingCursor", FName, ts->NonblinkingCursor);
1914
1915 WriteOnOff(Section, "KillFocusCursor", FName, ts->KillFocusCursor);
1916
1917 /* Delay for pass-thru printing activation */
1918 /* -- special option */
1919 WriteUint(Section, "PassThruDelay", FName, ts->PassThruDelay);
1920
1921 /* Printer port for pass-thru printing */
1922 /* -- special option */
1923 WritePrivateProfileString(Section, "PassThruPort", ts->PrnDev, FName);
1924
1925 /* Printer Font --- special option */
1926 WriteFont(Section, "PrnFont", FName,
1927 ts->PrnFont, ts->PrnFontSize.x, ts->PrnFontSize.y,
1928 ts->PrnFontCharSet);
1929
1930 // Page margins (left, right, top, bottom) for printing
1931 // -- special option
1932 WriteInt4(Section, "PrnMargin", FName,
1933 ts->PrnMargin[0], ts->PrnMargin[1],
1934 ts->PrnMargin[2], ts->PrnMargin[3]);
1935
1936 /* Quick-VAN log -- special option */
1937 WriteOnOff(Section, "QVLog", FName, (WORD) (ts->LogFlag & LOG_QV));
1938
1939 /* Quick-VAN window size -- special */
1940 WriteInt(Section, "QVWinSize", FName, ts->QVWinSize);
1941
1942 /* Russian character set (print) -- special option */
1943 id2str(RussList, ts->RussPrint, IdWindows, Temp, sizeof(Temp));
1944 WritePrivateProfileString(Section, "RussPrint", Temp, FName);
1945
1946 /* Scroll threshold -- special option */
1947 WriteInt(Section, "ScrollThreshold", FName, ts->ScrollThreshold);
1948
1949 WriteInt(Section, "MouseWheelScrollLine", FName, ts->MouseWheelScrollLine);
1950
1951 // Select on activate -- special option
1952 WriteOnOff(Section, "SelectOnActivate", FName, ts->SelOnActive);
1953
1954 /* Send 8bit control sequence -- special option */
1955 WriteOnOff(Section, "Send8BitCtrl", FName, ts->Send8BitCtrl);
1956
1957 /* Startup macro -- special option */
1958 WritePrivateProfileString(Section, "StartupMacro", ts->MacroFN, FName);
1959
1960 /* TEK GIN Mouse keycode -- special option */
1961 WriteInt(Section, "TEKGINMouseCode", FName, ts->GINMouseCode);
1962
1963 /* Telnet Auto Detect -- special option */
1964 WriteOnOff(Section, "TelAutoDetect", FName, ts->TelAutoDetect);
1965
1966 /* Telnet binary flag -- special option */
1967 WriteOnOff(Section, "TelBin", FName, ts->TelBin);
1968
1969 /* Telnet Echo flag -- special option */
1970 WriteOnOff(Section, "TelEcho", FName, ts->TelEcho);
1971
1972 /* Telnet log -- special option */
1973 WriteOnOff(Section, "TelLog", FName, (WORD) (ts->LogFlag & LOG_TEL));
1974
1975 /* TCP port num for telnet -- special option */
1976 WriteUint(Section, "TelPort", FName, ts->TelPort);
1977
1978 /* Telnet keep-alive packet(NOP command) interval -- special option */
1979 WriteUint(Section, "TelKeepAliveInterval", FName,
1980 ts->TelKeepAliveInterval);
1981
1982 /* Max number of broadcast commad history */
1983 WriteUint(Section, "MaxBroadcatHistory", FName,
1984 ts->MaxBroadcatHistory);
1985
1986 /* Local echo for non-telnet */
1987 WriteOnOff(Section, "TCPLocalEcho", FName, ts->TCPLocalEcho);
1988
1989 /* "new-line (transmit)" option for non-telnet -- special option */
1990 if (ts->TCPCRSend == IdCRLF)
1991 strncpy_s(Temp, sizeof(Temp), "CRLF", _TRUNCATE);
1992 else if (ts->TCPCRSend == IdCR)
1993 strncpy_s(Temp, sizeof(Temp), "CR", _TRUNCATE);
1994 else
1995 Temp[0] = 0;
1996 WritePrivateProfileString(Section, "TCPCRSend", Temp, FName);
1997
1998 /* Use text (background) color for "white (black)"
1999 --- special option */
2000 WriteOnOff(Section, "UseTextColor", FName,
2001 (WORD) (ts->ColorFlag & CF_USETEXTCOLOR));
2002
2003 /* Title format -- special option */
2004 WriteUint(Section, "TitleFormat", FName, ts->TitleFormat);
2005
2006 /* VT Compatible Tab -- special option */
2007 WriteOnOff(Section, "VTCompatTab", FName, ts->VTCompatTab);
2008
2009 /* VT Font space --- special option */
2010 WriteInt4(Section, "VTFontSpace", FName,
2011 ts->FontDX, ts->FontDW - ts->FontDX,
2012 ts->FontDY, ts->FontDH - ts->FontDY);
2013
2014 // VT-print scaling factors (pixels per inch) --- special option
2015 WriteInt2(Section, "VTPPI", FName, ts->VTPPI.x, ts->VTPPI.y);
2016
2017 // TEK-print scaling factors (pixels per inch) --- special option
2018 WriteInt2(Section, "TEKPPI", FName, ts->TEKPPI.x, ts->TEKPPI.y);
2019
2020 // Show "Window" menu -- special option
2021 WriteOnOff(Section, "WindowMenu", FName,
2022 (WORD) (ts->MenuFlag & MF_SHOWWINMENU));
2023
2024 /* XMODEM log -- special option */
2025 WriteOnOff(Section, "XmodemLog", FName, (WORD) (ts->LogFlag & LOG_X));
2026
2027 /* YMODEM log -- special option */
2028 WriteOnOff(Section, "YmodemLog", FName, (WORD) (ts->LogFlag & LOG_Y));
2029
2030 /* Auto ZMODEM activation -- special option */
2031 WriteOnOff(Section, "ZmodemAuto", FName,
2032 (WORD) (ts->FTFlag & FT_ZAUTO));
2033
2034 /* ZMODEM data subpacket length for sending -- special */
2035 WriteInt(Section, "ZmodemDataLen", FName, ts->ZmodemDataLen);
2036 /* ZMODEM window size for sending -- special */
2037 WriteInt(Section, "ZmodemWinSize", FName, ts->ZmodemWinSize);
2038
2039 /* ZMODEM ESCCTL flag -- special option */
2040 WriteOnOff(Section, "ZmodemEscCtl", FName,
2041 (WORD) (ts->FTFlag & FT_ZESCCTL));
2042
2043 /* ZMODEM log -- special option */
2044 WriteOnOff(Section, "ZmodemLog", FName, (WORD) (ts->LogFlag & LOG_Z));
2045
2046 /* ZMODEM ���M�R�}���h (2007.12.21 yutaka) */
2047 WritePrivateProfileString(Section, "ZmodemRcvCommand", ts->ZModemRcvCommand, FName);
2048
2049 /* update file */
2050 WritePrivateProfileString(NULL, NULL, NULL, FName);
2051
2052 // Eterm lookfeel alphablend (2005.4.24 yutaka)
2053 #define ETERM_SECTION "BG"
2054 WriteOnOff(ETERM_SECTION, "BGEnable", FName,
2055 ts->EtermLookfeel.BGEnable);
2056 WriteOnOff(ETERM_SECTION, "BGUseAlphaBlendAPI", FName,
2057 ts->EtermLookfeel.BGUseAlphaBlendAPI);
2058 WritePrivateProfileString(ETERM_SECTION, "BGSPIPath",
2059 ts->EtermLookfeel.BGSPIPath, FName);
2060 WriteOnOff(ETERM_SECTION, "BGFastSizeMove", FName,
2061 ts->EtermLookfeel.BGFastSizeMove);
2062 WriteOnOff(ETERM_SECTION, "BGFlickerlessMove", FName,
2063 ts->EtermLookfeel.BGNoCopyBits);
2064 WriteOnOff(ETERM_SECTION, "BGNoFrame", FName,
2065 ts->EtermLookfeel.BGNoFrame);
2066 WritePrivateProfileString(ETERM_SECTION, "BGThemeFile",
2067 ts->EtermLookfeel.BGThemeFile, FName);
2068
2069 #ifdef USE_NORMAL_BGCOLOR
2070 // UseNormalBGColor
2071 WriteOnOff(Section, "UseNormalBGColor", FName, ts->UseNormalBGColor);
2072 #endif
2073
2074 // UI language message file
2075 WritePrivateProfileString(Section, "UILanguageFile",
2076 ts->UILanguageFile_ini, FName);
2077
2078 // Broadcast Command History (2007.3.3 maya)
2079 WriteOnOff(Section, "BroadcastCommandHistory", FName,
2080 ts->BroadcastCommandHistory);
2081
2082 // 337: 2007/03/20 Accept Broadcast
2083 WriteOnOff(Section, "AcceptBroadcast", FName, ts->AcceptBroadcast);
2084
2085 // Confirm send a file when drag and drop (2007.12.28 maya)
2086 WriteOnOff(Section, "ConfirmFileDragAndDrop", FName,
2087 ts->ConfirmFileDragAndDrop);
2088
2089 // Translate mouse wheel to cursor key when application cursor mode
2090 WriteOnOff(Section, "TranslateWheelToCursor", FName,
2091 ts->TranslateWheelToCursor);
2092
2093 // Display "New Connection" dialog on startup (2008.1.18 maya)
2094 WriteOnOff(Section, "HostDialogOnStartup", FName,
2095 ts->HostDialogOnStartup);
2096
2097 // Mouse event tracking
2098 WriteOnOff(Section, "MouseEventTracking", FName,
2099 ts->MouseEventTracking);
2100
2101 // Maximized bug tweak
2102 WriteOnOff(Section, "MaximizedBugTweak", FName, ts->MaximizedBugTweak);
2103
2104 // Convert Unicode symbol characters to DEC Special characters
2105 WriteUint(Section, "UnicodeToDecSpMapping", FName, ts->UnicodeDecSpMapping);
2106
2107 // VT Window Icon
2108 IconId2IconName(Temp, sizeof(Temp), ts->VTIcon);
2109 WritePrivateProfileString(Section, "VTIcon", Temp, FName);
2110
2111 // Tek Window Icon
2112 IconId2IconName(Temp, sizeof(Temp), ts->TEKIcon);
2113 WritePrivateProfileString(Section, "TEKIcon", Temp, FName);
2114
2115 // AutoScrollOnlyInBottomLine
2116 WriteOnOff(Section, "AutoScrollOnlyInBottomLine", FName,
2117 ts->AutoScrollOnlyInBottomLine);
2118
2119 // Unknown Unicode Character
2120 WriteOnOff(Section, "UnknownUnicodeCharacterAsWide", FName,
2121 ts->UnknownUnicodeCharaAsWide);
2122
2123 // Accept remote-controlled window title changing
2124 if (ts->AcceptTitleChangeRequest == IdTitleChangeRequestOff)
2125 strncpy_s(Temp, sizeof(Temp), "off", _TRUNCATE);
2126 else if (ts->AcceptTitleChangeRequest == IdTitleChangeRequestOverwrite)
2127 strncpy_s(Temp, sizeof(Temp), "overwrite", _TRUNCATE);
2128 else if (ts->AcceptTitleChangeRequest == IdTitleChangeRequestAhead)
2129 strncpy_s(Temp, sizeof(Temp), "ahead", _TRUNCATE);
2130 else if (ts->AcceptTitleChangeRequest == IdTitleChangeRequestLast)
2131 strncpy_s(Temp, sizeof(Temp), "last", _TRUNCATE);
2132 else
2133 Temp[0] = 0;
2134 WritePrivateProfileString(Section, "AcceptTitleChangeRequest", Temp, FName);
2135
2136 // Size of paste confirm dialog
2137 WriteInt2(Section, "PasteDialogSize", FName,
2138 ts->PasteDialogSize.cx, ts->PasteDialogSize.cy);
2139
2140 // Disable mouse event tracking when Control-Key is pressed.
2141 WriteOnOff(Section, "DisableMouseTrackingByCtrl", FName,
2142 ts->DisableMouseTrackingByCtrl);
2143
2144 // Disable TranslateWHeelToCursor when Control-Key is pressed.
2145 WriteOnOff(Section, "DisableWheelToCursorByCtrl", FName,
2146 ts->DisableWheelToCursorByCtrl);
2147
2148 // Strict Key Mapping.
2149 WriteOnOff(Section, "StrictKeyMapping", FName,
2150 ts->StrictKeyMapping);
2151
2152 // Wait4allMacroCommand
2153 WriteOnOff(Section, "Wait4allMacroCommand", FName,
2154 ts->Wait4allMacroCommand);
2155 }
2156
2157 #define VTEditor "VT editor keypad"
2158 #define VTNumeric "VT numeric keypad"
2159 #define VTFunction "VT function keys"
2160 #define XFunction "X function keys"
2161 #define ShortCut "Shortcut keys"
2162
2163 void GetInt(PKeyMap KeyMap, int KeyId, PCHAR Sect, PCHAR Key, PCHAR FName)
2164 {
2165 char Temp[11];
2166 WORD Num;
2167
2168 GetPrivateProfileString(Sect, Key, "", Temp, sizeof(Temp), FName);
2169 if (Temp[0] == 0)
2170 Num = 0xFFFF;
2171 else if (_stricmp(Temp, "off") == 0)
2172 Num = 0xFFFF;
2173 else if (sscanf(Temp, "%d", &Num) != 1)
2174 Num = 0xFFFF;
2175
2176 KeyMap->Map[KeyId - 1] = Num;
2177 }
2178
2179 void FAR PASCAL ReadKeyboardCnf
2180 (PCHAR FName, PKeyMap KeyMap, BOOL ShowWarning) {
2181 int i, j, Ptr;
2182 char EntName[7];
2183 char TempStr[221];
2184 char KStr[201];
2185
2186 // clear key map
2187 for (i = 0; i <= IdKeyMax - 1; i++)
2188 KeyMap->Map[i] = 0xFFFF;
2189 for (i = 0; i <= NumOfUserKey - 1; i++) {
2190 KeyMap->UserKeyPtr[i] = 0;
2191 KeyMap->UserKeyLen[i] = 0;
2192 }
2193
2194 // VT editor keypad
2195 GetInt(KeyMap, IdUp, VTEditor, "Up", FName);
2196
2197 GetInt(KeyMap, IdDown, VTEditor, "Down", FName);
2198
2199 GetInt(KeyMap, IdRight, VTEditor, "Right", FName);
2200
2201 GetInt(KeyMap, IdLeft, VTEditor, "Left", FName);
2202
2203 GetInt(KeyMap, IdFind, VTEditor, "Find", FName);
2204
2205 GetInt(KeyMap, IdInsert, VTEditor, "Insert", FName);
2206
2207 GetInt(KeyMap, IdRemove, VTEditor, "Remove", FName);
2208
2209 GetInt(KeyMap, IdSelect, VTEditor, "Select", FName);
2210
2211 GetInt(KeyMap, IdPrev, VTEditor, "Prev", FName);
2212
2213 GetInt(KeyMap, IdNext, VTEditor, "Next", FName);
2214
2215 // VT numeric keypad
2216 GetInt(KeyMap, Id0, VTNumeric, "Num0", FName);
2217
2218 GetInt(KeyMap, Id1, VTNumeric, "Num1", FName);
2219
2220 GetInt(KeyMap, Id2, VTNumeric, "Num2", FName);
2221
2222 GetInt(KeyMap, Id3, VTNumeric, "Num3", FName);
2223
2224 GetInt(KeyMap, Id4, VTNumeric, "Num4", FName);
2225
2226 GetInt(KeyMap, Id5, VTNumeric, "Num5", FName);
2227
2228 GetInt(KeyMap, Id6, VTNumeric, "Num6", FName);
2229
2230 GetInt(KeyMap, Id7, VTNumeric, "Num7", FName);
2231
2232 GetInt(KeyMap, Id8, VTNumeric, "Num8", FName);
2233
2234 GetInt(KeyMap, Id9, VTNumeric, "Num9", FName);
2235
2236 GetInt(KeyMap, IdMinus, VTNumeric, "NumMinus", FName);
2237
2238 GetInt(KeyMap, IdComma, VTNumeric, "NumComma", FName);
2239
2240 GetInt(KeyMap, IdPeriod, VTNumeric, "NumPeriod", FName);
2241
2242 GetInt(KeyMap, IdEnter, VTNumeric, "NumEnter", FName);
2243
2244 GetInt(KeyMap, IdSlash, VTNumeric, "NumSlash", FName);
2245
2246 GetInt(KeyMap, IdAsterisk, VTNumeric, "NumAsterisk", FName);
2247
2248 GetInt(KeyMap, IdPlus, VTNumeric, "NumPlus", FName);
2249
2250 GetInt(KeyMap, IdPF1, VTNumeric, "PF1", FName);
2251
2252 GetInt(KeyMap, IdPF2, VTNumeric, "PF2", FName);
2253
2254 GetInt(KeyMap, IdPF3, VTNumeric, "PF3", FName);
2255
2256 GetInt(KeyMap, IdPF4, VTNumeric, "PF4", FName);
2257
2258 // VT function keys
2259 GetInt(KeyMap, IdHold, VTFunction, "Hold", FName);
2260
2261 GetInt(KeyMap, IdPrint, VTFunction, "Print", FName);
2262
2263 GetInt(KeyMap, IdBreak, VTFunction, "Break", FName);
2264
2265 GetInt(KeyMap, IdF6, VTFunction, "F6", FName);
2266
2267 GetInt(KeyMap, IdF7, VTFunction, "F7", FName);
2268
2269 GetInt(KeyMap, IdF8, VTFunction, "F8", FName);
2270
2271 GetInt(KeyMap, IdF9, VTFunction, "F9", FName);
2272
2273 GetInt(KeyMap, IdF10, VTFunction, "F10", FName);
2274
2275 GetInt(KeyMap, IdF11, VTFunction, "F11", FName);
2276
2277 GetInt(KeyMap, IdF12, VTFunction, "F12", FName);
2278
2279 GetInt(KeyMap, IdF13, VTFunction, "F13", FName);
2280
2281 GetInt(KeyMap, IdF14, VTFunction, "F14", FName);
2282
2283 GetInt(KeyMap, IdHelp, VTFunction, "Help", FName);
2284
2285 GetInt(KeyMap, IdDo, VTFunction, "Do", FName);
2286
2287 GetInt(KeyMap, IdF17, VTFunction, "F17", FName);
2288
2289 GetInt(KeyMap, IdF18, VTFunction, "F18", FName);
2290
2291 GetInt(KeyMap, IdF19, VTFunction, "F19", FName);
2292
2293 GetInt(KeyMap, IdF20, VTFunction, "F20", FName);
2294
2295 // UDK
2296 GetInt(KeyMap, IdUDK6, VTFunction, "UDK6", FName);
2297
2298 GetInt(KeyMap, IdUDK7, VTFunction, "UDK7", FName);
2299
2300 GetInt(KeyMap, IdUDK8, VTFunction, "UDK8", FName);
2301
2302 GetInt(KeyMap, IdUDK9, VTFunction, "UDK9", FName);
2303
2304 GetInt(KeyMap, IdUDK10, VTFunction, "UDK10", FName);
2305
2306 GetInt(KeyMap, IdUDK11, VTFunction, "UDK11", FName);
2307
2308 GetInt(KeyMap, IdUDK12, VTFunction, "UDK12", FName);
2309
2310 GetInt(KeyMap, IdUDK13, VTFunction, "UDK13", FName);
2311
2312 GetInt(KeyMap, IdUDK14, VTFunction, "UDK14", FName);
2313
2314 GetInt(KeyMap, IdUDK15, VTFunction, "UDK15", FName);
2315
2316 GetInt(KeyMap, IdUDK16, VTFunction, "UDK16", FName);
2317
2318 GetInt(KeyMap, IdUDK17, VTFunction, "UDK17", FName);
2319
2320 GetInt(KeyMap, IdUDK18, VTFunction, "UDK18", FName);
2321
2322 GetInt(KeyMap, IdUDK19, VTFunction, "UDK19", FName);
2323
2324 GetInt(KeyMap, IdUDK20, VTFunction, "UDK20", FName);
2325
2326 // XTERM function keys
2327 GetInt(KeyMap, IdXF1, XFunction, "XF1", FName);
2328
2329 GetInt(KeyMap, IdXF2, XFunction, "XF2", FName);
2330
2331 GetInt(KeyMap, IdXF3, XFunction, "XF3", FName);
2332
2333 GetInt(KeyMap, IdXF4, XFunction, "XF4", FName);
2334
2335 GetInt(KeyMap, IdXF5, XFunction, "XF5", FName);
2336
2337 // accelerator keys
2338 GetInt(KeyMap, IdCmdEditCopy, ShortCut, "EditCopy", FName);
2339
2340 GetInt(KeyMap, IdCmdEditPaste, ShortCut, "EditPaste", FName);
2341
2342 GetInt(KeyMap, IdCmdEditPasteCR, ShortCut, "EditPasteCR", FName);
2343
2344 GetInt(KeyMap, IdCmdEditCLS, ShortCut, "EditCLS", FName);
2345
2346 GetInt(KeyMap, IdCmdEditCLB, ShortCut, "EditCLB", FName);
2347
2348 GetInt(KeyMap, IdCmdCtrlOpenTEK, ShortCut, "ControlOpenTEK", FName);
2349
2350 GetInt(KeyMap, IdCmdCtrlCloseTEK, ShortCut, "ControlCloseTEK", FName);
2351
2352 GetInt(KeyMap, IdCmdLineUp, ShortCut, "LineUp", FName);
2353
2354 GetInt(KeyMap, IdCmdLineDown, ShortCut, "LineDown", FName);
2355
2356 GetInt(KeyMap, IdCmdPageUp, ShortCut, "PageUp", FName);
2357
2358 GetInt(KeyMap, IdCmdPageDown, ShortCut, "PageDown", FName);
2359
2360 GetInt(KeyMap, IdCmdBuffTop, ShortCut, "BuffTop", FName);
2361
2362 GetInt(KeyMap, IdCmdBuffBottom, ShortCut, "BuffBottom", FName);
2363
2364 GetInt(KeyMap, IdCmdNextWin, ShortCut, "NextWin", FName);
2365
2366 GetInt(KeyMap, IdCmdPrevWin, ShortCut, "PrevWin", FName);
2367
2368 GetInt(KeyMap, IdCmdLocalEcho, ShortCut, "LocalEcho", FName);
2369
2370 GetInt(KeyMap, IdScrollLock, ShortCut, "ScrollLock", FName);
2371
2372 /* user keys */
2373
2374 Ptr = 0;
2375
2376 i = IdUser1;
2377 do {
2378 _snprintf_s(EntName, sizeof(EntName), _TRUNCATE, "User%d", i - IdUser1 + 1);
2379 GetPrivateProfileString("User keys", EntName, "",
2380 TempStr, sizeof(TempStr), FName);
2381 if (strlen(TempStr) > 0) {
2382 /* scan code */
2383 GetNthString(TempStr, 1, sizeof(KStr), KStr);
2384 if (_stricmp(KStr, "off") == 0)
2385 KeyMap->Map[i - 1] = 0xFFFF;
2386 else {
2387 GetNthNum(TempStr, 1, &j);
2388 KeyMap->Map[i - 1] = (WORD) j;
2389 }
2390 /* conversion flag */
2391 GetNthNum(TempStr, 2, &j);
2392 KeyMap->UserKeyType[i - IdUser1] = (BYTE) j;
2393 /* key string */
2394 /* GetNthString(TempStr,3,sizeof(KStr),KStr); */
2395 KeyMap->UserKeyPtr[i - IdUser1] = Ptr;
2396 /* KeyMap->UserKeyLen[i-IdUser1] =
2397 Hex2Str(KStr,&(KeyMap->UserKeyStr[Ptr]),KeyStrMax-Ptr+1);
2398 */
2399 GetNthString(TempStr, 3, KeyStrMax - Ptr + 1,
2400 &(KeyMap->UserKeyStr[Ptr]));
2401 KeyMap->UserKeyLen[i - IdUser1] =
2402 strlen(&(KeyMap->UserKeyStr[Ptr]));
2403 Ptr = Ptr + KeyMap->UserKeyLen[i - IdUser1];
2404 }
2405
2406 i++;
2407 }
2408 while ((i <= IdKeyMax) && (strlen(TempStr) > 0) && (Ptr <= KeyStrMax));
2409
2410 for (j = 1; j <= IdKeyMax - 1; j++)
2411 if (KeyMap->Map[j] != 0xFFFF)
2412 for (i = 0; i <= j - 1; i++)
2413 if (KeyMap->Map[i] == KeyMap->Map[j]) {
2414 if (ShowWarning) {
2415 _snprintf_s(TempStr, sizeof(TempStr), _TRUNCATE,
2416 "Keycode %d is used more than once",
2417 KeyMap->Map[j]);
2418 MessageBox(0, TempStr,
2419 "Tera Term: Error in keyboard setup file",
2420 MB_ICONEXCLAMATION);
2421 }
2422 KeyMap->Map[i] = 0xFFFF;
2423 }
2424 }
2425
2426 void FAR PASCAL CopySerialList(PCHAR IniSrc, PCHAR IniDest, PCHAR section,
2427 PCHAR key, int MaxList)
2428 {
2429 int i;
2430 char EntName[10];
2431 char TempHost[HostNameMaxLength + 1];
2432
2433 if (_stricmp(IniSrc, IniDest) == 0)
2434 return;
2435
2436 WritePrivateProfileString(section, NULL, NULL, IniDest);
2437
2438 i = 1;
2439 do {
2440 _snprintf_s(EntName, sizeof(EntName), _TRUNCATE, "%s%i", key, i);
2441
2442 /* Get one hostname from file IniSrc */
2443 GetPrivateProfileString(section, EntName, "",
2444 TempHost, sizeof(TempHost), IniSrc);
2445 /* Copy it to the file IniDest */
2446 if (strlen(TempHost) > 0)
2447 WritePrivateProfileString(section, EntName, TempHost, IniDest);
2448 i++;
2449 }
2450 while ((i <= MaxList) && (strlen(TempHost) > 0));
2451
2452 /* update file */
2453 WritePrivateProfileString(NULL, NULL, NULL, IniDest);
2454 }
2455
2456 void FAR PASCAL AddValueToList(PCHAR FName, PCHAR Host, PCHAR section,
2457 PCHAR key, int MaxList)
2458 {
2459 HANDLE MemH;
2460 PCHAR MemP;
2461 char EntName[13];
2462 int i, j, Len;
2463 BOOL Update;
2464
2465 if ((FName[0] == 0) || (Host[0] == 0))
2466 return;
2467 MemH = GlobalAlloc(GHND, (HostNameMaxLength + 1) * MaxList);
2468 if (MemH == NULL)
2469 return;
2470 MemP = GlobalLock(MemH);
2471 if (MemP != NULL) {
2472 strncpy_s(MemP, (HostNameMaxLength + 1) * MaxList, Host, _TRUNCATE);
2473 j = strlen(Host) + 1;
2474 i = 1;
2475 Update = TRUE;
2476 do {
2477 _snprintf_s(EntName, sizeof(EntName), _TRUNCATE, "%s%i", key, i);
2478
2479 /* Get a hostname */
2480 GetPrivateProfileString(section, EntName, "",
2481 &MemP[j], HostNameMaxLength + 1,
2482 FName);
2483 Len = strlen(&MemP[j]);
2484 if (_stricmp(&MemP[j], Host) == 0) {
2485 if (i == 1)
2486 Update = FALSE;
2487 }
2488 else
2489 j = j + Len + 1;
2490 i++;
2491 } while ((i <= MaxList) && (Len != 0) && Update);
2492
2493 if (Update) {
2494 WritePrivateProfileString(section, NULL, NULL, FName);
2495
2496 j = 0;
2497 i = 1;
2498 do {
2499 _snprintf_s(EntName, sizeof(EntName), _TRUNCATE, "%s%i", key, i);
2500
2501 if (MemP[j] != 0)
2502 WritePrivateProfileString(section, EntName, &MemP[j],
2503 FName);
2504 j = j + strlen(&MemP[j]) + 1;
2505 i++;
2506 } while ((i <= MaxList) && (MemP[j] != 0));
2507 /* update file */
2508 WritePrivateProfileString(NULL, NULL, NULL, FName);
2509 }
2510 GlobalUnlock(MemH);
2511 }
2512 GlobalFree(MemH);
2513 }
2514
2515 /* copy hostlist from source IniFile to dest IniFile */
2516 void FAR PASCAL CopyHostList(PCHAR IniSrc, PCHAR IniDest)
2517 {
2518 CopySerialList(IniSrc, IniDest, "Hosts", "Host", MAXHOSTLIST);
2519 }
2520
2521 void FAR PASCAL AddHostToList(PCHAR FName, PCHAR Host)
2522 {
2523 AddValueToList(FName, Host, "Hosts", "Host", MAXHOSTLIST);
2524 }
2525
2526 BOOL NextParam(PCHAR Param, int *i, PCHAR Temp, int Size)
2527 {
2528 int j;
2529 char c;
2530 BOOL Quoted;
2531
2532 if ((unsigned int) (*i) >= strlen(Param))
2533 return FALSE;
2534 j = 0;
2535
2536 while (Param[*i] == ' ')
2537 (*i)++;
2538
2539 Quoted = FALSE;
2540 c = Param[*i];
2541 (*i)++;
2542 while ((c != 0) && (Quoted || (c != ' ')) &&
2543 (Quoted || (c != ';')) && (j < Size - 1)) {
2544 if (c == '"')
2545 Quoted = !Quoted;
2546 Temp[j] = c;
2547 j++;
2548 c = Param[*i];
2549 (*i)++;
2550 }
2551 if (!Quoted && (c == ';'))
2552 (*i)--;
2553
2554 Temp[j] = 0;
2555 return (strlen(Temp) > 0);
2556 }
2557
2558 void Dequote(PCHAR Source, PCHAR Dest)
2559 {
2560 int i, j;
2561 char q, c;
2562
2563 Dest[0] = 0;
2564 if (Source[0] == 0)
2565 return;
2566 i = 0;
2567 /* quoting char */
2568 q = Source[i];
2569 /* only '"' is used as quoting char */
2570 if (q != '"')
2571 q = 0;
2572 else
2573 i++;
2574
2575 c = Source[i];
2576 i++;
2577 j = 0;
2578 while ((c != 0) && (c != q)) {
2579 Dest[j] = c;
2580 j++;
2581 c = Source[i];
2582 i++;
2583 }
2584
2585 Dest[j] = 0;
2586 }
2587
2588
2589 #ifndef NO_INET6
2590 static void ParseHostName(char *HostStr, WORD * port)
2591 {
2592 /*
2593 * hostname.domain.com
2594 * hostname.domain.com:23
2595 * [3ffe:1234:1234::1] IPv6 raw address
2596 * [3ffe:1234:1234::1]:23 IPv6 raw address and port#
2597 * telnet://hostname.domain.com/
2598 * telnet://hostname.domain.com:23/
2599 * telnet://[3ffe:1234:1234::1]/
2600 * telnet://[3ffe:1234:1234::1]:23/
2601 * tn3270:// .... /
2602 */
2603
2604 int i, is_telnet_handler = 0, is_port = 0;
2605 char *s;
2606 char b;
2607
2608 /* strlen("telnet://") == 9 */
2609 if ((_strnicmp(HostStr, "telnet://", 9) == 0) ||
2610 (_strnicmp(HostStr, "tn3270://", 9) == 0)) {
2611 /* trim "telnet://" and tail "/" */
2612 memmove(HostStr, &(HostStr[9]), strlen(HostStr) - 8);
2613 i = strlen(HostStr);
2614 if (i > 0 && (HostStr[i - 1] == '/'))
2615 HostStr[i - 1] = '\0';
2616 is_telnet_handler = 1;
2617 }
2618
2619 /* parsing string enclosed by [ ] */
2620 s = HostStr;
2621 if (*s == '[') {
2622 BOOL inet6found = FALSE;
2623 s++;
2624 while (*s) {
2625 if (*s == ']') {
2626 /* found IPv6 raw address */
2627 /* triming [ ] */
2628 int len = strlen(HostStr);
2629 char *lastptr = &HostStr[len - 1];
2630 memmove(HostStr, HostStr + 1, len - 1);
2631 s = s - 1;
2632 lastptr = lastptr - 1;
2633 memmove(s, s + 1, lastptr - s);
2634 /* because of triming 2 characters */
2635 HostStr[len - 2] = '\0';
2636
2637
2638 inet6found = TRUE;
2639 break;
2640 }
2641 s++;
2642 }
2643 if (inet6found == FALSE)
2644 s = HostStr;
2645 }
2646
2647 /* parsing port# */
2648 /*
2649 * s points:
2650 * [3ffe:1234:1234::1]:XXX....
2651 * 3ffe:1234:1234::1:XXX....
2652 * |
2653 * s
2654 *
2655 * hostname.domain.com
2656 * |
2657 * s
2658 */
2659 i = 0;
2660 do {
2661 b = s[i];
2662 i++;
2663 } while (b != '\0' && b != ':');
2664 if (b == ':') {
2665 s[i - 1] = '\0';
2666 if (sscanf(&(s[i]), "%d", port) != 1)
2667 *port = 65535;
2668 is_port = 1;
2669 }
2670 if (is_telnet_handler == 1 && is_port == 0) {
2671 *port = 23;
2672 }
2673 }
2674 #endif /* NO_INET6 */
2675
2676
2677 void FAR PASCAL ParseParam(PCHAR Param, PTTSet ts, PCHAR DDETopic)
2678 {
2679 int i, pos, c;
2680 #ifdef NO_INET6
2681 BYTE b;
2682 #endif /* NO_INET6 */
2683 char Temp[MAXPATHLEN + 3];
2684 char Temp2[MAXPATHLEN];
2685 char TempDir[MAXPATHLEN];
2686 WORD ParamPort = 0;
2687 WORD ParamCom = 0;
2688 WORD ParamTCP = 65535;
2689 WORD ParamTel = 2;
2690 WORD ParamBin = 2;
2691 WORD ParamBaud = IdBaudNone;
2692 BOOL HostNameFlag = FALSE;
2693 BOOL JustAfterHost = FALSE;
2694 WORD DisableTCPEchoCR = FALSE;
2695
2696 ts->HostName[0] = 0;
2697 ts->KeyCnfFN[0] = 0;
2698 /* Set AutoConnect true as default (2008.2.16 by steven)*/
2699 ts->ComAutoConnect = TRUE;
2700
2701 #ifndef NO_INET6
2702 /* user specifies the protocol connecting to the host */
2703 /* ts->ProtocolFamily = AF_UNSPEC; */
2704 #endif /* NO_INET6 */
2705
2706 /* Get command line parameters */
2707 if (DDETopic != NULL)
2708 DDETopic[0] = 0;
2709 i = 0;
2710 /* the first term shuld be executable filename of Tera Term */
2711 NextParam(Param, &i, Temp, sizeof(Temp));
2712 while (NextParam(Param, &i, Temp, sizeof(Temp))) {
2713 if (HostNameFlag) {
2714 JustAfterHost = TRUE;
2715 HostNameFlag = FALSE;
2716 }
2717
2718 if (_strnicmp(Temp, "/BAUD=", 6) == 0) { /* Serial port baud rate */
2719 ParamPort = IdSerial;
2720 ParamBaud = str2id(BaudList, &Temp[6], IdBaudNone);
2721 }
2722 else if (_strnicmp(Temp, "/B", 2) == 0) { /* telnet binary */
2723 ParamPort = IdTCPIP;
2724 ParamBin = 1;
2725 }
2726 else if (_strnicmp(Temp, "/C=", 3) == 0) { /* COM port num */
2727 ParamPort = IdSerial;
2728 ParamCom = atoi(&Temp[3]);
2729 if ((ParamCom < 1) || (ParamCom > ts->MaxComPort))
2730 ParamCom = 0;
2731 }
2732 else if (_strnicmp(Temp, "/D=", 3) == 0) {
2733 if (DDETopic != NULL)
2734 strncpy_s(DDETopic, 21, &Temp[3], _TRUNCATE); // 21 = sizeof(TopicName)
2735 }
2736 // "New connection" �_�C�A���O���\�������� (2008.11.14 maya)
2737 else if (_strnicmp(Temp, "/DS", 3) == 0) {
2738 ts->HostDialogOnStartup = FALSE;
2739 }
2740 // TCPLocalEcho/TCPCRSend ������������ (maya 2007.4.25)
2741 else if (_strnicmp(Temp, "/E", 2) == 0) {
2742 DisableTCPEchoCR = TRUE;
2743 }
2744 else if (_strnicmp(Temp, "/F=", 3) == 0) { /* setup filename */
2745 Dequote(&Temp[3], Temp2);
2746 if (strlen(Temp2) > 0) {
2747 ConvFName(ts->HomeDir, Temp2, sizeof(Temp2), ".INI", Temp,
2748 sizeof(Temp));
2749 if (_stricmp(ts->SetupFName, Temp) != 0) {
2750 strncpy_s(ts->SetupFName, sizeof(ts->SetupFName), Temp,
2751 _TRUNCATE);
2752 ReadIniFile(ts->SetupFName, ts);
2753 }
2754 }
2755 }
2756 else if (_strnicmp(Temp, "/FD=", 4) == 0) { /* file transfer directory */
2757 Dequote(&Temp[4], Temp2);
2758 if (strlen(Temp2) > 0) {
2759 _getcwd(TempDir, sizeof(TempDir));
2760 if (_chdir(Temp2) == 0)
2761 strncpy_s(ts->FileDir, sizeof(ts->FileDir), Temp2,
2762 _TRUNCATE);
2763 _chdir(TempDir);
2764 }
2765 }
2766 else if (_strnicmp(Temp, "/H", 2) == 0) /* hide title bar */
2767 ts->HideTitle = 1;
2768 else if (_strnicmp(Temp, "/I", 2) == 0) /* iconize */
2769 ts->Minimize = 1;
2770 else if (_strnicmp(Temp, "/K=", 3) == 0) { /* Keyboard setup file */
2771 Dequote(&Temp[3], Temp2);
2772 ConvFName(ts->HomeDir, Temp2, sizeof(Temp2), ".CNF",
2773 ts->KeyCnfFN, sizeof(ts->KeyCnfFN));
2774 }
2775 else if ((_strnicmp(Temp, "/KR=", 4) == 0) ||
2776 (_strnicmp(Temp, "/KT=", 4) == 0)) { /* kanji code */
2777 if (_strnicmp(&Temp[4], "UTF8m", 5) == 0 ||
2778 _strnicmp(&Temp[4], "UTF-8m", 6) == 0)
2779 c = IdUTF8m;
2780 else if (_strnicmp(&Temp[4], "UTF8", 4) == 0 ||
2781 _strnicmp(&Temp[4], "UTF-8", 5) == 0)
2782 c = IdUTF8;
2783 else if (_strnicmp(&Temp[4], "SJIS", 4) == 0)
2784 c = IdSJIS;
2785 else if (_strnicmp(&Temp[4], "EUC", 3) == 0)
2786 c = IdEUC;
2787 else if (_strnicmp(&Temp[4], "JIS", 3) == 0)
2788 c = IdJIS;
2789 else
2790 c = -1;
2791 if (c != -1) {
2792 if (_strnicmp(Temp, "/KR=", 4) == 0)
2793 ts->KanjiCode = c;
2794 else
2795 ts->KanjiCodeSend = c;
2796 }
2797 }
2798 else if (_strnicmp(Temp, "/L=", 3) == 0) { /* log file */
2799 Dequote(&Temp[3], Temp2);
2800 strncpy_s(ts->LogFN, sizeof(ts->LogFN), Temp2, _TRUNCATE);
2801 }
2802 else if (_strnicmp(Temp, "/LA=", 4) == 0) { /* language */
2803 if (_strnicmp(&Temp[4], "E", 1) == 0)
2804 ts->Language = IdEnglish;
2805 else if (_strnicmp(&Temp[4], "J", 1) == 0)
2806 ts->Language = IdJapanese;
2807 else if (_strnicmp(&Temp[4], "R", 1) == 0)
2808 ts->Language = IdRussian;
2809 }
2810 else if (_strnicmp(Temp, "/M=", 3) == 0) { /* macro filename */
2811 if ((Temp[3] == 0) || (Temp[3] == '*'))
2812 strncpy_s(ts->MacroFN, sizeof(ts->MacroFN), "*",
2813 _TRUNCATE);
2814 else {
2815 Dequote(&Temp[3], Temp2);
2816 ConvFName(ts->HomeDir, Temp2, sizeof(Temp2), ".TTL",
2817 ts->MacroFN, sizeof(ts->MacroFN));
2818 }