… | |
… | |
28 | *----------------------------------------------------------------------*/ |
28 | *----------------------------------------------------------------------*/ |
29 | |
29 | |
30 | #include "../config.h" /* NECESSARY */ |
30 | #include "../config.h" /* NECESSARY */ |
31 | #include "rxvt.h" /* NECESSARY */ |
31 | #include "rxvt.h" /* NECESSARY */ |
32 | #include "version.h" |
32 | #include "version.h" |
33 | #include "xdefaults.intpro" /* PROTOS for internal routines */ |
|
|
34 | |
33 | |
35 | /* #define DEBUG_RESOURCES */ |
34 | /* #define DEBUG_RESOURCES */ |
36 | |
35 | |
37 | static const char *const xnames[2] = { ".Xdefaults", ".Xresources" }; |
36 | static const char *const xnames[2] = { ".Xdefaults", ".Xresources" }; |
38 | |
37 | |
… | |
… | |
63 | #define SWCH(opt, flag, desc) \ |
62 | #define SWCH(opt, flag, desc) \ |
64 | { (flag), -1, NULL, (opt), NULL, (desc)} |
63 | { (flag), -1, NULL, (opt), NULL, (desc)} |
65 | |
64 | |
66 | /* convenient macros */ |
65 | /* convenient macros */ |
67 | #define optList_strlen(i) \ |
66 | #define optList_strlen(i) \ |
68 | (optList[i].flag ? 0 : (optList[i].arg ? STRLEN (optList[i].arg) : 1)) |
67 | (optList[i].flag ? 0 : (optList[i].arg ? strlen (optList[i].arg) : 1)) |
69 | #define optList_isBool(i) \ |
68 | #define optList_isBool(i) \ |
70 | (optList[i].flag & Opt_Boolean) |
69 | (optList[i].flag & Opt_Boolean) |
71 | #define optList_isReverse(i) \ |
70 | #define optList_isReverse(i) \ |
72 | (optList[i].flag & Opt_Reverse) |
71 | (optList[i].flag & Opt_Reverse) |
73 | #define optList_size() \ |
72 | #define optList_size() \ |
… | |
… | |
110 | #if TINTING |
109 | #if TINTING |
111 | STRG (Rs_color + Color_tint, "tintColor", "tint", "color", "tint color"), |
110 | STRG (Rs_color + Color_tint, "tintColor", "tint", "color", "tint color"), |
112 | #endif |
111 | #endif |
113 | #endif |
112 | #endif |
114 | #ifdef OFF_FOCUS_FADING |
113 | #ifdef OFF_FOCUS_FADING |
115 | STRG (Rs_fade, "fading", "fade", "%", "make colors x% darker when urxvt is losing focus."), |
114 | STRG (Rs_fade, "fading", "fade", "%", "make colors x% darker when rxvt-unicode is losing focus."), |
116 | #endif |
115 | #endif |
117 | #ifdef TINTING |
116 | #ifdef TINTING |
118 | STRG (Rs_shade, "shading", "sh", "%", "shade background by x% when tinting."), |
117 | STRG (Rs_shade, "shading", "sh", "%", "shade background by x% when tinting."), |
119 | #endif |
118 | #endif |
120 | BOOL (Rs_utmpInhibit, "utmpInhibit", "ut", Opt_utmpInhibit, "utmp inhibit"), |
119 | BOOL (Rs_utmpInhibit, "utmpInhibit", "ut", Opt_utmpInhibit, "utmp inhibit"), |
… | |
… | |
128 | BOOL (Rs_meta8, "meta8", NULL, Opt_meta8, NULL), |
127 | BOOL (Rs_meta8, "meta8", NULL, Opt_meta8, NULL), |
129 | #endif |
128 | #endif |
130 | #ifdef MOUSE_WHEEL |
129 | #ifdef MOUSE_WHEEL |
131 | BOOL (Rs_mouseWheelScrollPage, "mouseWheelScrollPage", NULL, Opt_mouseWheelScrollPage, NULL), |
130 | BOOL (Rs_mouseWheelScrollPage, "mouseWheelScrollPage", NULL, Opt_mouseWheelScrollPage, NULL), |
132 | #endif |
131 | #endif |
133 | #ifndef NO_FRILLS |
132 | #if ENABLE_FRILLS |
134 | BOOL (Rs_tripleclickwords, "tripleclickwords", "tcw", Opt_tripleclickwords, "triple click word selection"), |
133 | BOOL (Rs_tripleclickwords, "tripleclickwords", "tcw", Opt_tripleclickwords, "triple click word selection"), |
135 | BOOL (Rs_insecure, "insecure", "insecure", Opt_insecure, "enable possibly insecure escape sequences"), |
134 | BOOL (Rs_insecure, "insecure", "insecure", Opt_insecure, "enable possibly insecure escape sequences"), |
136 | #endif |
135 | #endif |
137 | #ifdef CURSOR_BLINK |
136 | #ifdef CURSOR_BLINK |
138 | BOOL (Rs_cursorBlink, "cursorBlink", "bc", Opt_cursorBlink, "blinking cursor"), |
137 | BOOL (Rs_cursorBlink, "cursorBlink", "bc", Opt_cursorBlink, "blinking cursor"), |
… | |
… | |
159 | RSTRG (Rs_color + minBrightCOLOR + 5, "color13", "color"), |
158 | RSTRG (Rs_color + minBrightCOLOR + 5, "color13", "color"), |
160 | RSTRG (Rs_color + minBrightCOLOR + 6, "color14", "color"), |
159 | RSTRG (Rs_color + minBrightCOLOR + 6, "color14", "color"), |
161 | RSTRG (Rs_color + minBrightCOLOR + 7, "color15", "color"), |
160 | RSTRG (Rs_color + minBrightCOLOR + 7, "color15", "color"), |
162 | #endif /* NO_BRIGHTCOLOR */ |
161 | #endif /* NO_BRIGHTCOLOR */ |
163 | #ifndef NO_BOLD_UNDERLINE_REVERSE |
162 | #ifndef NO_BOLD_UNDERLINE_REVERSE |
164 | BOOL (Rs_realBold, "realBold", "rb", Opt_realBold, "use bold fonts for bold text"), |
|
|
165 | RSTRG (Rs_color + Color_BD, "colorBD", "color"), |
163 | RSTRG (Rs_color + Color_BD, "colorBD", "color"), |
|
|
164 | RSTRG (Rs_color + Color_IT, "colorIT", "color"), |
166 | RSTRG (Rs_color + Color_UL, "colorUL", "color"), |
165 | RSTRG (Rs_color + Color_UL, "colorUL", "color"), |
167 | RSTRG (Rs_color + Color_RV, "colorRV", "color"), |
166 | RSTRG (Rs_color + Color_RV, "colorRV", "color"), |
168 | #endif /* ! NO_BOLD_UNDERLINE_REVERSE */ |
167 | #endif /* ! NO_BOLD_UNDERLINE_REVERSE */ |
169 | #ifdef KEEP_SCROLLCOLOR |
168 | #ifdef KEEP_SCROLLCOLOR |
170 | RSTRG (Rs_color + Color_scroll, "scrollColor", "color"), |
169 | RSTRG (Rs_color + Color_scroll, "scrollColor", "color"), |
… | |
… | |
180 | STRG (Rs_backgroundPixmap, "backgroundPixmap", "pixmap", "file[;geom]", "background pixmap"), |
179 | STRG (Rs_backgroundPixmap, "backgroundPixmap", "pixmap", "file[;geom]", "background pixmap"), |
181 | #endif /* XPM_BACKGROUND */ |
180 | #endif /* XPM_BACKGROUND */ |
182 | #if (MENUBAR_MAX) |
181 | #if (MENUBAR_MAX) |
183 | RSTRG (Rs_menu, "menu", "name[;tag]"), |
182 | RSTRG (Rs_menu, "menu", "name[;tag]"), |
184 | #endif |
183 | #endif |
|
|
184 | /* fonts: command-line option = resource name */ |
185 | STRG (Rs_font, "font", "fn", "fontname", "normal text font"), |
185 | STRG (Rs_font, "font", "fn", "fontname", "normal text font"), |
186 | /* fonts: command-line option = resource name */ |
186 | #if ENABLE_STYLES |
|
|
187 | STRG (Rs_boldFont, "boldFont", "fb", "fontname", "bold font"), |
|
|
188 | STRG (Rs_italicFont, "italicFont", "fi", "fontname", "italic font"), |
|
|
189 | STRG (Rs_boldItalicFont, "boldItalicFont", "fbi", "fontname", "bold italic font"), |
|
|
190 | #endif |
187 | #ifdef USE_XIM |
191 | #ifdef USE_XIM |
188 | STRG (Rs_inputMethod, "inputMethod", "im", "name", "name of input method"), |
192 | STRG (Rs_inputMethod, "inputMethod", "im", "name", "name of input method"), |
189 | STRG (Rs_preeditType, "preeditType", "pt", "style", "input style: style = OverTheSpot|OffTheSpot|Root"), |
193 | STRG (Rs_preeditType, "preeditType", "pt", "style", "input style: style = OverTheSpot|OffTheSpot|Root"), |
190 | #if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
194 | #if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
191 | STRG (Rs_imLocale, "imLocale", "imlocale", "string", "locale to use for input method"), |
195 | STRG (Rs_imLocale, "imLocale", "imlocale", "string", "locale to use for input method"), |
… | |
… | |
202 | #endif /* NO_CURSORCOLOR */ |
206 | #endif /* NO_CURSORCOLOR */ |
203 | STRG (Rs_color + Color_pointer_fg, "pointerColor", "pr", "color", "pointer color"), |
207 | STRG (Rs_color + Color_pointer_fg, "pointerColor", "pr", "color", "pointer color"), |
204 | STRG (Rs_color + Color_pointer_bg, "pointerColor2", "pr2", "color", "pointer bg color"), |
208 | STRG (Rs_color + Color_pointer_bg, "pointerColor2", "pr2", "color", "pointer bg color"), |
205 | STRG (Rs_color + Color_border, "borderColor", "bd", "color", "border color"), |
209 | STRG (Rs_color + Color_border, "borderColor", "bd", "color", "border color"), |
206 | STRG (Rs_saveLines, "saveLines", "sl", "number", "number of scrolled lines to save"), |
210 | STRG (Rs_saveLines, "saveLines", "sl", "number", "number of scrolled lines to save"), |
207 | #ifndef NO_FRILLS |
211 | #if ENABLE_FRILLS |
208 | STRG (Rs_ext_bwidth, "externalBorder", "w", "number", "external border in pixels"), |
212 | STRG (Rs_ext_bwidth, "externalBorder", "w", "number", "external border in pixels"), |
209 | STRG (Rs_ext_bwidth, NULL, "bw", NULL, NULL), |
213 | STRG (Rs_ext_bwidth, NULL, "bw", NULL, NULL), |
210 | STRG (Rs_ext_bwidth, NULL, "borderwidth", NULL, NULL), |
214 | STRG (Rs_ext_bwidth, NULL, "borderwidth", NULL, NULL), |
211 | STRG (Rs_int_bwidth, "internalBorder", "b", "number", "internal border in pixels"), |
215 | STRG (Rs_int_bwidth, "internalBorder", "b", "number", "internal border in pixels"), |
|
|
216 | BOOL (Rs_borderLess, "borderLess", "bl", Opt_borderLess, "borderless window"), |
212 | #endif |
217 | #endif |
213 | #ifndef NO_LINESPACE |
218 | #ifndef NO_LINESPACE |
214 | STRG (Rs_lineSpace, "lineSpace", "lsp", "number", "number of extra pixels between rows"), |
219 | STRG (Rs_lineSpace, "lineSpace", "lsp", "number", "number of extra pixels between rows"), |
215 | #endif |
220 | #endif |
216 | STRG (Rs_scrollBar_thickness, "thickness", "sbt", "number", "scrollbar thickness/width in pixels"), |
221 | STRG (Rs_scrollBar_thickness, "thickness", "sbt", "number", "scrollbar thickness/width in pixels"), |
… | |
… | |
249 | #undef RSTRG |
254 | #undef RSTRG |
250 | #undef SWCH |
255 | #undef SWCH |
251 | #undef BOOL |
256 | #undef BOOL |
252 | /*}}} */ |
257 | /*}}} */ |
253 | |
258 | |
254 | static const char releasestring[] = "Rxvt v" VERSION " - released: " DATE "\n"; |
259 | static const char releasestring[] = "rxvt-unicode (" RXVTNAME ") v" VERSION " - released: " DATE "\n"; |
255 | static const char optionsstring[] = "Options: " |
260 | static const char optionsstring[] = "options: " |
|
|
261 | #if XFT |
|
|
262 | "xft," |
|
|
263 | #endif |
|
|
264 | #if ENABLE_STYLES |
|
|
265 | "styles," |
|
|
266 | #endif |
|
|
267 | #if ENABLE_COMBINING |
|
|
268 | "combining," |
|
|
269 | #endif |
|
|
270 | #if TEXT_BLINK |
|
|
271 | "blink," |
|
|
272 | #endif |
|
|
273 | #if ISO_14755 |
|
|
274 | "iso14755," |
|
|
275 | #endif |
|
|
276 | #if UNICODE_3 |
|
|
277 | "unicode3," |
|
|
278 | #endif |
|
|
279 | "encodings=eu+vn" |
|
|
280 | #if ENCODING_JP |
|
|
281 | "+jp" |
|
|
282 | #endif |
|
|
283 | #if ENCODING_JP_EXT |
|
|
284 | "+jp-ext" |
|
|
285 | #endif |
|
|
286 | #if ENCODING_KR |
|
|
287 | "+kr" |
|
|
288 | #endif |
|
|
289 | #if ENCODING_ZH |
|
|
290 | "+zh" |
|
|
291 | #endif |
|
|
292 | #if ENCODING_ZH_EXT |
|
|
293 | "+zh-ext" |
|
|
294 | #endif |
|
|
295 | "," |
|
|
296 | #if OFF_FOCUS_FADING |
|
|
297 | "fade," |
|
|
298 | #endif |
256 | #if defined(XPM_BACKGROUND) |
299 | #if defined(XPM_BACKGROUND) |
257 | "XPM," |
300 | "XPM," |
258 | #endif |
301 | #endif |
259 | #if defined(TRANSPARENT) |
302 | #if defined(TRANSPARENT) |
260 | "transparent," |
303 | "transparent," |
261 | #endif |
304 | #endif |
|
|
305 | #if TINTING |
|
|
306 | "tint," |
|
|
307 | #endif |
262 | #if defined(UTMP_SUPPORT) |
308 | #if defined(UTMP_SUPPORT) |
263 | "utmp," |
309 | "utmp," |
264 | #endif |
310 | #endif |
265 | #if defined(MENUBAR) |
311 | #if defined(MENUBAR) |
266 | "menubar," |
312 | "menubar," |
267 | #endif |
|
|
268 | #if !defined(NO_FRILLS) |
|
|
269 | "frills," |
|
|
270 | #endif |
|
|
271 | #if !defined(NO_LINESPACE) |
|
|
272 | "linespace," |
|
|
273 | #endif |
|
|
274 | #if defined(PREFER_24BIT) |
|
|
275 | "24bit," |
|
|
276 | #endif |
313 | #endif |
277 | #if defined(USE_XIM) |
314 | #if defined(USE_XIM) |
278 | "XIM," |
315 | "XIM," |
279 | #endif |
316 | #endif |
280 | "scrollbars=" |
317 | "scrollbars=" |
… | |
… | |
308 | "no_backspace," |
345 | "no_backspace," |
309 | #endif |
346 | #endif |
310 | #if defined(NO_DELETE_KEY) |
347 | #if defined(NO_DELETE_KEY) |
311 | "no_delete," |
348 | "no_delete," |
312 | #endif |
349 | #endif |
|
|
350 | #if EIGHT_BIT_CONTROLS |
|
|
351 | "8bitctrls," |
|
|
352 | #endif |
313 | #if !defined(NO_STRINGS) |
353 | #if !defined(NO_STRINGS) |
314 | "strings," |
354 | "strings," |
315 | #endif |
355 | #endif |
316 | #if defined(TTY_256COLOR) |
356 | #if defined(ENABLE_FRILLS) |
|
|
357 | "frills," |
|
|
358 | #endif |
|
|
359 | #if !defined(NO_LINESPACE) |
|
|
360 | "linespace," |
|
|
361 | #endif |
|
|
362 | #if defined(PREFER_24BIT) |
317 | "256colour," |
363 | "24bit," |
|
|
364 | #endif |
|
|
365 | #if defined(SELECTION_SCROLLING) |
|
|
366 | "selectionscrolling," |
|
|
367 | #endif |
|
|
368 | #if MOUSE_WHEEL |
|
|
369 | "wheel," |
|
|
370 | #endif |
|
|
371 | #if MOUSE_SLIP_WHEELING |
|
|
372 | "slipwheel," |
|
|
373 | #endif |
|
|
374 | #if defined(SMART_RESIZE) |
|
|
375 | "smart-resize," |
|
|
376 | #endif |
|
|
377 | #if defined(CURSOR_BLINK) |
|
|
378 | "cursorBlink," |
|
|
379 | #endif |
|
|
380 | #if defined(POINTER_BLANK) |
|
|
381 | "pointerBlank," |
318 | #endif |
382 | #endif |
319 | #if defined(NO_RESOURCES) |
383 | #if defined(NO_RESOURCES) |
320 | "NoResources" |
384 | "NoResources" |
321 | #else |
385 | #else |
322 | # if defined(USE_XGETDEFAULT) |
386 | # if defined(USE_XGETDEFAULT) |
… | |
… | |
355 | len++; /* account for space */ |
419 | len++; /* account for space */ |
356 | } |
420 | } |
357 | #ifdef DEBUG_STRICT |
421 | #ifdef DEBUG_STRICT |
358 | assert (optList[i].opt != NULL); |
422 | assert (optList[i].opt != NULL); |
359 | #endif |
423 | #endif |
360 | len += 4 + STRLEN (optList[i].opt) + (optList_isBool (i) ? 2: 0); |
424 | len += 4 + strlen (optList[i].opt) + (optList_isBool (i) ? 2: 0); |
361 | col += len; |
425 | col += len; |
362 | if (col > 79) |
426 | if (col > 79) |
363 | { /* assume regular width */ |
427 | { /* assume regular width */ |
364 | rxvt_log ("\n"); |
428 | rxvt_log ("\n"); |
365 | col = 1 + len; |
429 | col = 1 + len; |
… | |
… | |
382 | #ifdef DEBUG_STRICT |
446 | #ifdef DEBUG_STRICT |
383 | assert (optList[i].opt != NULL); |
447 | assert (optList[i].opt != NULL); |
384 | #endif |
448 | #endif |
385 | rxvt_log (" %s%s %-*s%s%s\n", |
449 | rxvt_log (" %s%s %-*s%s%s\n", |
386 | (optList_isBool (i) ? "-/+" : "-"), optList[i].opt, |
450 | (optList_isBool (i) ? "-/+" : "-"), optList[i].opt, |
387 | (INDENT - STRLEN (optList[i].opt) |
451 | (INDENT - strlen (optList[i].opt) |
388 | + (optList_isBool (i) ? 0 : 2)), |
452 | + (optList_isBool (i) ? 0 : 2)), |
389 | (optList[i].arg ? optList[i].arg : ""), |
453 | (optList[i].arg ? optList[i].arg : ""), |
390 | (optList_isBool (i) ? "turn on/off " : ""), |
454 | (optList_isBool (i) ? "turn on/off " : ""), |
391 | optList[i].desc); |
455 | optList[i].desc); |
392 | } |
456 | } |
… | |
… | |
399 | |
463 | |
400 | for (i = 0; i < optList_size (); i++) |
464 | for (i = 0; i < optList_size (); i++) |
401 | if (optList[i].kw != NULL) |
465 | if (optList[i].kw != NULL) |
402 | rxvt_log (" %s: %*s%s\n", |
466 | rxvt_log (" %s: %*s%s\n", |
403 | optList[i].kw, |
467 | optList[i].kw, |
404 | (INDENT - STRLEN (optList[i].kw)), "", /* XXX */ |
468 | (INDENT - strlen (optList[i].kw)), "", /* XXX */ |
405 | (optList_isBool (i) ? "boolean" : optList[i].arg)); |
469 | (optList_isBool (i) ? "boolean" : optList[i].arg)); |
406 | #ifdef KEYSYM_RESOURCE |
470 | #ifdef KEYSYM_RESOURCE |
407 | rxvt_log (" " "keysym.sym" ": %*s%s\n", |
471 | rxvt_log (" " "keysym.sym" ": %*s%s\n", |
408 | (INDENT - sizeof ("keysym.sym") + 1), "", /* XXX */ |
472 | (INDENT - sizeof ("keysym.sym") + 1), "", /* XXX */ |
409 | "keysym"); |
473 | "keysym"); |
… | |
… | |
452 | bad_option = 1; |
516 | bad_option = 1; |
453 | rxvt_warn ("\"%s\": malformed option.\n", opt); |
517 | rxvt_warn ("\"%s\": malformed option.\n", opt); |
454 | continue; |
518 | continue; |
455 | } |
519 | } |
456 | |
520 | |
457 | if (!STRCMP (opt, "help")) |
521 | if (!strcmp (opt, "help")) |
458 | rxvt_usage (longopt ? 2 : 1); |
522 | rxvt_usage (longopt ? 2 : 1); |
459 | if (!STRCMP (opt, "h")) |
523 | if (!strcmp (opt, "h")) |
460 | rxvt_usage (0); |
524 | rxvt_usage (0); |
461 | |
525 | |
462 | /* feature: always try to match long-options */ |
526 | /* feature: always try to match long-options */ |
463 | for (entry = 0; entry < optList_size (); entry++) |
527 | for (entry = 0; entry < optList_size (); entry++) |
464 | if ((optList[entry].kw && !STRCMP (opt, optList[entry].kw)) |
528 | if ((optList[entry].kw && !strcmp (opt, optList[entry].kw)) |
465 | || (!longopt |
529 | || (!longopt |
466 | && optList[entry].opt && !STRCMP (opt, optList[entry].opt))) |
530 | && optList[entry].opt && !strcmp (opt, optList[entry].opt))) |
467 | break; |
531 | break; |
468 | |
532 | |
469 | if (entry < optList_size ()) |
533 | if (entry < optList_size ()) |
470 | { |
534 | { |
471 | if (optList_isReverse (entry)) |
535 | if (optList_isReverse (entry)) |
… | |
… | |
488 | #ifdef DEBUG_RESOURCES |
552 | #ifdef DEBUG_RESOURCES |
489 | fprintf (stderr, "boolean (%s,%s) = %s\n", |
553 | fprintf (stderr, "boolean (%s,%s) = %s\n", |
490 | optList[entry].opt, optList[entry].kw, flag); |
554 | optList[entry].opt, optList[entry].kw, flag); |
491 | #endif |
555 | #endif |
492 | if (flag == On) |
556 | if (flag == On) |
493 | Options |= (optList[entry].flag); |
557 | options |= (optList[entry].flag); |
494 | else |
558 | else |
495 | Options &= ~ (optList[entry].flag); |
559 | options &= ~ (optList[entry].flag); |
496 | |
560 | |
497 | if (optList[entry].doff != -1) |
561 | if (optList[entry].doff != -1) |
498 | rs[optList[entry].doff] = flag; |
562 | rs[optList[entry].doff] = flag; |
499 | } |
563 | } |
500 | } |
564 | } |
501 | else |
565 | else |
502 | #ifdef KEYSYM_RESOURCE |
566 | #ifdef KEYSYM_RESOURCE |
503 | /* if (!STRNCMP (opt, "keysym.", sizeof ("keysym.") - 1)) */ |
567 | /* if (!strncmp (opt, "keysym.", sizeof ("keysym.") - 1)) */ |
504 | if (rxvt_Str_match (opt, "keysym.")) |
568 | if (rxvt_Str_match (opt, "keysym.")) |
505 | { |
569 | { |
506 | const char *str = argv[++i]; |
570 | const char *str = argv[++i]; |
507 | |
571 | |
508 | if (str != NULL) |
572 | if (str != NULL) |
… | |
… | |
577 | { |
641 | { |
578 | if (str[0] == '0' && toupper (str[1]) == 'X') |
642 | if (str[0] == '0' && toupper (str[1]) == 'X') |
579 | str += 2; |
643 | str += 2; |
580 | if (arg) |
644 | if (arg) |
581 | { |
645 | { |
582 | if (sscanf (str, (STRCHR (str, ':') ? "%x:" : "%x"), &sym) != 1) |
646 | if (sscanf (str, (strchr (str, ':') ? "%x:" : "%x"), &sym) != 1) |
583 | return -1; |
647 | return -1; |
584 | } |
648 | } |
585 | else |
649 | else |
586 | { |
650 | { |
587 | if (sscanf (str, "%x:", &sym) != 1) |
651 | if (sscanf (str, "%x:", &sym) != 1) |
588 | return -1; |
652 | return -1; |
589 | |
653 | |
590 | /* cue to ':', it's there since sscanf () worked */ |
654 | /* cue to ':', it's there since sscanf () worked */ |
591 | STRNCPY (newargstr, STRCHR (str, ':') + 1, NEWARGLIM - 1); |
655 | strncpy (newargstr, strchr (str, ':') + 1, NEWARGLIM - 1); |
592 | newargstr[NEWARGLIM - 1] = '\0'; |
656 | newargstr[NEWARGLIM - 1] = '\0'; |
593 | newarg = newargstr; |
657 | newarg = newargstr; |
594 | } |
658 | } |
595 | } |
659 | } |
596 | else |
660 | else |
597 | { |
661 | { |
598 | /* |
662 | /* |
599 | * convert keysym name to keysym number |
663 | * convert keysym name to keysym number |
600 | */ |
664 | */ |
601 | STRNCPY (newargstr, str, NEWARGLIM - 1); |
665 | strncpy (newargstr, str, NEWARGLIM - 1); |
602 | newargstr[NEWARGLIM - 1] = '\0'; |
666 | newargstr[NEWARGLIM - 1] = '\0'; |
603 | if (arg == NULL) |
667 | if (arg == NULL) |
604 | { |
668 | { |
605 | if ((newarg = STRCHR (newargstr, ':')) == NULL) |
669 | if ((newarg = strchr (newargstr, ':')) == NULL) |
606 | return -1; |
670 | return -1; |
607 | *newarg++ = '\0'; /* terminate keysym name */ |
671 | *newarg++ = '\0'; /* terminate keysym name */ |
608 | } |
672 | } |
609 | if ((sym = XStringToKeysym (newargstr)) == None) |
673 | if ((sym = XStringToKeysym (newargstr)) == None) |
610 | return -1; |
674 | return -1; |
… | |
… | |
616 | if (Keysym_map[sym] != NULL) /* already set ? */ |
680 | if (Keysym_map[sym] != NULL) /* already set ? */ |
617 | return -1; |
681 | return -1; |
618 | |
682 | |
619 | if (newarg == NULL) |
683 | if (newarg == NULL) |
620 | { |
684 | { |
621 | STRNCPY (newargstr, arg, NEWARGLIM - 1); |
685 | strncpy (newargstr, arg, NEWARGLIM - 1); |
622 | newargstr[NEWARGLIM - 1] = '\0'; |
686 | newargstr[NEWARGLIM - 1] = '\0'; |
623 | newarg = newargstr; |
687 | newarg = newargstr; |
624 | } |
688 | } |
625 | rxvt_Str_trim (newarg); |
689 | rxvt_Str_trim (newarg); |
626 | if (*newarg == '\0' || (n = rxvt_Str_escaped (newarg)) == 0) |
690 | if (*newarg == '\0' || (n = rxvt_Str_escaped (newarg)) == 0) |
627 | return -1; |
691 | return -1; |
628 | MIN_IT (n, 255); |
692 | MIN_IT (n, 255); |
629 | key_string = (char *)rxvt_malloc ((n + 1) * sizeof (char)); |
693 | key_string = (char *)rxvt_malloc ((n + 1) * sizeof (char)); |
630 | |
694 | |
631 | key_string[0] = n; |
695 | key_string[0] = n; |
632 | STRNCPY (key_string + 1, newarg, n); |
696 | strncpy (key_string + 1, newarg, n); |
633 | Keysym_map[sym] = (unsigned char *)key_string; |
697 | Keysym_map[sym] = (unsigned char *)key_string; |
634 | |
698 | |
635 | return 1; |
699 | return 1; |
636 | } |
700 | } |
637 | |
701 | |
… | |
… | |
649 | char *str, buffer[256]; |
713 | char *str, buffer[256]; |
650 | |
714 | |
651 | if (stream == NULL) |
715 | if (stream == NULL) |
652 | return; |
716 | return; |
653 | |
717 | |
654 | len = STRLEN (name); |
718 | len = strlen (name); |
655 | while ((str = fgets (buffer, sizeof (buffer), stream)) != NULL) |
719 | while ((str = fgets (buffer, sizeof (buffer), stream)) != NULL) |
656 | { |
720 | { |
657 | unsigned int entry, n; |
721 | unsigned int entry, n; |
658 | |
722 | |
659 | while (*str && isspace (*str)) |
723 | while (*str && isspace (*str)) |
660 | str++; /* leading whitespace */ |
724 | str++; /* leading whitespace */ |
661 | |
725 | |
662 | if ((str[len] != '*' && str[len] != '.') |
726 | if ((str[len] != '*' && str[len] != '.') |
663 | || (len && STRNCMP (str, name, len))) |
727 | || (len && strncmp (str, name, len))) |
664 | continue; |
728 | continue; |
665 | str += (len + 1); /* skip `name*' or `name.' */ |
729 | str += (len + 1); /* skip `name*' or `name.' */ |
666 | |
730 | |
667 | # ifdef KEYSYM_RESOURCE |
731 | # ifdef KEYSYM_RESOURCE |
668 | if (!parse_keysym (str, NULL)) |
732 | if (!parse_keysym (str, NULL)) |
… | |
… | |
672 | const char *kw = optList[entry].kw; |
736 | const char *kw = optList[entry].kw; |
673 | |
737 | |
674 | if (kw == NULL) |
738 | if (kw == NULL) |
675 | continue; |
739 | continue; |
676 | |
740 | |
677 | n = STRLEN (kw); |
741 | n = strlen (kw); |
678 | if (str[n] == ':' && rxvt_Str_match (str, kw)) |
742 | if (str[n] == ':' && rxvt_Str_match (str, kw)) |
679 | { |
743 | { |
680 | /* skip `keyword:' */ |
744 | /* skip `keyword:' */ |
681 | str += n + 1; |
745 | str += n + 1; |
682 | rxvt_Str_trim (str); |
746 | rxvt_Str_trim (str); |
683 | n = STRLEN (str); |
747 | n = strlen (str); |
684 | if (n && rs[optList[entry].doff] == NULL) |
748 | if (n && rs[optList[entry].doff] == NULL) |
685 | { |
749 | { |
686 | /* not already set */ |
750 | /* not already set */ |
687 | int s; |
751 | int s; |
688 | char *p = 0; |
752 | char *p = 0; |
689 | |
753 | |
690 | for (int o = 0;;) |
754 | for (int o = 0;;) |
691 | { |
755 | { |
692 | p = (char *)rxvt_realloc (p, o + n + 1); |
756 | p = (char *)rxvt_realloc (p, o + n + 1); |
693 | MEMCPY (p + o, str, n); |
757 | memcpy (p + o, str, n); |
694 | o += n; |
758 | o += n; |
695 | p[o] = 0; |
759 | p[o] = 0; |
696 | |
760 | |
697 | if (o == 0 || p[o - 1] != '\\') // continuation line |
761 | if (o == 0 || p[o - 1] != '\\') // continuation line |
698 | break; |
762 | break; |
… | |
… | |
701 | |
765 | |
702 | if ((str = fgets (buffer, sizeof (buffer), stream)) == NULL) |
766 | if ((str = fgets (buffer, sizeof (buffer), stream)) == NULL) |
703 | break; |
767 | break; |
704 | |
768 | |
705 | rxvt_Str_trim (str); |
769 | rxvt_Str_trim (str); |
706 | n = STRLEN (str); |
770 | n = strlen (str); |
707 | } |
771 | } |
708 | |
772 | |
709 | rs[optList[entry].doff] = p; |
773 | rs[optList[entry].doff] = p; |
710 | allocated.push_back (p); |
774 | allocated.push_back (p); |
711 | |
775 | |
712 | if (optList_isBool (entry)) |
776 | if (optList_isBool (entry)) |
713 | { |
777 | { |
714 | s = STRCASECMP (str, "TRUE") == 0 |
778 | s = strcasecmp (str, "TRUE") == 0 |
715 | || STRCASECMP (str, "YES") == 0 |
779 | || strcasecmp (str, "YES") == 0 |
716 | || STRCASECMP (str, "ON") == 0 |
780 | || strcasecmp (str, "ON") == 0 |
717 | || STRCASECMP (str, "1") == 0; |
781 | || strcasecmp (str, "1") == 0; |
718 | |
782 | |
719 | if (optList_isReverse (entry)) |
783 | if (optList_isReverse (entry)) |
720 | s = !s; |
784 | s = !s; |
721 | |
785 | |
722 | if (s) |
786 | if (s) |
723 | Options |= optList[entry].flag; |
787 | options |= optList[entry].flag; |
724 | else |
788 | else |
725 | Options &= ~optList[entry].flag; |
789 | options &= ~optList[entry].flag; |
726 | } |
790 | } |
727 | } |
791 | } |
728 | |
792 | |
729 | break; |
793 | break; |
730 | } |
794 | } |
… | |
… | |
789 | database = XrmGetStringDatabase (displayResource); |
853 | database = XrmGetStringDatabase (displayResource); |
790 | |
854 | |
791 | # ifdef HAVE_EXTRA_XRESOURCE_FILES |
855 | # ifdef HAVE_EXTRA_XRESOURCE_FILES |
792 | /* Add in ~/.Xdefaults or ~/.Xresources */ |
856 | /* Add in ~/.Xdefaults or ~/.Xresources */ |
793 | { |
857 | { |
794 | char *ptr; |
858 | char *ptr; |
795 | |
859 | |
796 | if ((ptr = (char *)getenv ("HOME")) == NULL) |
860 | if ((ptr = (char *)getenv ("HOME")) == NULL) |
797 | ptr = "."; |
861 | ptr = "."; |
798 | |
862 | |
799 | for (i = 0; i < (sizeof (xnames) / sizeof (xnames[0])); i++) |
863 | for (i = 0; i < (sizeof (xnames) / sizeof (xnames[0])); i++) |
800 | { |
864 | { |
801 | sprintf (fname, "%-.*s/%s", sizeof (fname) - STRLEN (xnames[i]) - 2, |
865 | sprintf (fname, "%-.*s/%s", sizeof (fname) - strlen (xnames[i]) - 2, |
802 | ptr, xnames[i]); |
866 | ptr, xnames[i]); |
803 | if ((rdb1 = XrmGetFileDatabase (fname))) |
867 | if ((rdb1 = XrmGetFileDatabase (fname))) |
804 | { |
868 | { |
805 | XrmMergeDatabases (rdb1, &database); |
869 | XrmMergeDatabases (rdb1, &database); |
806 | # ifndef HAVE_BOTH_XRESOURCE_FILES |
870 | # ifndef HAVE_BOTH_XRESOURCE_FILES |
… | |
… | |
851 | if (kw == NULL || rs[optList[entry].doff] != NULL) |
915 | if (kw == NULL || rs[optList[entry].doff] != NULL) |
852 | continue; /* previously set */ |
916 | continue; /* previously set */ |
853 | |
917 | |
854 | p = XGetDefault (display, name, kw); |
918 | p = XGetDefault (display, name, kw); |
855 | p0 = XGetDefault (display, "!INVALIDPROGRAMMENAMEDONTMATCH!", kw); |
919 | p0 = XGetDefault (display, "!INVALIDPROGRAMMENAMEDONTMATCH!", kw); |
856 | if (p == NULL || (p0 && STRCMP (p, p0) == 0)) |
920 | if (p == NULL || (p0 && strcmp (p, p0) == 0)) |
857 | { |
921 | { |
858 | p = XGetDefault (display, RESCLASS, kw); |
922 | p = XGetDefault (display, RESCLASS, kw); |
859 | #ifdef RESFALLBACK |
923 | #ifdef RESFALLBACK |
860 | if (p == NULL || (p0 && STRCMP (p, p0) == 0)) |
924 | if (p == NULL || (p0 && strcmp (p, p0) == 0)) |
861 | p = XGetDefault (display, RESFALLBACK, kw); |
925 | p = XGetDefault (display, RESFALLBACK, kw); |
862 | #endif |
926 | #endif |
863 | } |
927 | } |
864 | |
928 | |
865 | if (p == NULL && p0) |
929 | if (p == NULL && p0) |
… | |
… | |
869 | { |
933 | { |
870 | rs[optList[entry].doff] = p; |
934 | rs[optList[entry].doff] = p; |
871 | |
935 | |
872 | if (optList_isBool (entry)) |
936 | if (optList_isBool (entry)) |
873 | { |
937 | { |
874 | s = STRCASECMP (p, "TRUE") == 0 |
938 | s = strcasecmp (p, "TRUE") == 0 |
875 | || STRCASECMP (p, "YES") == 0 |
939 | || strcasecmp (p, "YES") == 0 |
876 | || STRCASECMP (p, "ON") == 0 |
940 | || strcasecmp (p, "ON") == 0 |
877 | || STRCASECMP (p, "1") == 0; |
941 | || strcasecmp (p, "1") == 0; |
878 | if (optList_isReverse (entry)) |
942 | if (optList_isReverse (entry)) |
879 | s = !s; |
943 | s = !s; |
880 | if (s) |
944 | if (s) |
881 | Options |= (optList[entry].flag); |
945 | options |= (optList[entry].flag); |
882 | else |
946 | else |
883 | Options &= ~ (optList[entry].flag); |
947 | options &= ~ (optList[entry].flag); |
884 | } |
948 | } |
885 | } |
949 | } |
886 | } |
950 | } |
887 | |
951 | |
888 | /* |
952 | /* |
… | |
… | |
916 | FILE *fd = NULL; |
980 | FILE *fd = NULL; |
917 | char *home; |
981 | char *home; |
918 | |
982 | |
919 | if ((home = getenv ("HOME")) != NULL) |
983 | if ((home = getenv ("HOME")) != NULL) |
920 | { |
984 | { |
921 | unsigned int i, len = STRLEN (home) + 2; |
985 | unsigned int i, len = strlen (home) + 2; |
922 | char *f = NULL; |
986 | char *f = NULL; |
923 | |
987 | |
924 | for (i = 0; i < (sizeof (xnames) / sizeof (xnames[0])); i++) |
988 | for (i = 0; i < (sizeof (xnames) / sizeof (xnames[0])); i++) |
925 | { |
989 | { |
926 | f = (char *)rxvt_realloc (f, (len + STRLEN (xnames[i])) * sizeof (char)); |
990 | f = (char *)rxvt_realloc (f, (len + strlen (xnames[i])) * sizeof (char)); |
927 | |
991 | |
928 | sprintf (f, "%s/%s", home, xnames[i]); |
992 | sprintf (f, "%s/%s", home, xnames[i]); |
929 | |
993 | |
930 | if ((fd = fopen (f, "r")) != NULL) |
994 | if ((fd = fopen (f, "r")) != NULL) |
931 | break; |
995 | break; |