… | |
… | |
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 | |
33 | |
|
|
34 | #include <sys/utsname.h> |
|
|
35 | |
34 | #ifdef KEYSYM_RESOURCE |
36 | #ifdef KEYSYM_RESOURCE |
35 | #include "keyboard.h" |
37 | #include "keyboard.h" |
36 | #endif |
38 | #endif |
37 | |
39 | |
38 | /* #define DEBUG_RESOURCES */ |
40 | /* #define DEBUG_RESOURCES */ |
39 | |
|
|
40 | static const char *const xnames[2] = { ".Xdefaults", ".Xresources" }; |
|
|
41 | |
41 | |
42 | /*{{{ monolithic option/resource structure: */ |
42 | /*{{{ monolithic option/resource structure: */ |
43 | /* |
43 | /* |
44 | * `string' options MUST have a usage argument |
44 | * `string' options MUST have a usage argument |
45 | * `switch' and `boolean' options have no argument |
45 | * `switch' and `boolean' options have no argument |
… | |
… | |
71 | (optList[i].flag ? 0 : (optList[i].arg ? strlen (optList[i].arg) : 1)) |
71 | (optList[i].flag ? 0 : (optList[i].arg ? strlen (optList[i].arg) : 1)) |
72 | #define optList_isBool(i) \ |
72 | #define optList_isBool(i) \ |
73 | (optList[i].flag & Opt_Boolean) |
73 | (optList[i].flag & Opt_Boolean) |
74 | #define optList_isReverse(i) \ |
74 | #define optList_isReverse(i) \ |
75 | (optList[i].flag & Opt_Reverse) |
75 | (optList[i].flag & Opt_Reverse) |
76 | #define optList_size() \ |
76 | #define optList_size \ |
77 | (sizeof (optList) / sizeof (optList[0])) |
77 | (sizeof (optList) / sizeof (optList[0])) |
78 | |
78 | |
79 | static const struct |
79 | static const struct |
80 | { |
80 | { |
81 | const unsigned long flag; /* Option flag */ |
81 | const unsigned long flag; /* Option flag */ |
… | |
… | |
96 | SWCH ("ic", Opt_iconic, NULL), /* short form */ |
96 | SWCH ("ic", Opt_iconic, NULL), /* short form */ |
97 | BOOL (Rs_reverseVideo, "reverseVideo", "rv", Opt_reverseVideo, "reverse video"), |
97 | BOOL (Rs_reverseVideo, "reverseVideo", "rv", Opt_reverseVideo, "reverse video"), |
98 | BOOL (Rs_loginShell, "loginShell", "ls", Opt_loginShell, "login shell"), |
98 | BOOL (Rs_loginShell, "loginShell", "ls", Opt_loginShell, "login shell"), |
99 | BOOL (Rs_jumpScroll, "jumpScroll", "j", Opt_jumpScroll, "jump scrolling"), |
99 | BOOL (Rs_jumpScroll, "jumpScroll", "j", Opt_jumpScroll, "jump scrolling"), |
100 | BOOL (Rs_pastableTabs, "pastableTabs", "ptab", Opt_pastableTabs, "tab characters are pastable"), |
100 | BOOL (Rs_pastableTabs, "pastableTabs", "ptab", Opt_pastableTabs, "tab characters are pastable"), |
101 | #ifdef HAVE_SCROLLBARS |
101 | #if HAVE_SCROLLBARS |
102 | RSTRG (Rs_scrollstyle, "scrollstyle", "mode"), |
102 | RSTRG (Rs_scrollstyle, "scrollstyle", "mode"), |
103 | BOOL (Rs_scrollBar, "scrollBar", "sb", Opt_scrollBar, "scrollbar"), |
103 | BOOL (Rs_scrollBar, "scrollBar", "sb", Opt_scrollBar, "scrollbar"), |
104 | BOOL (Rs_scrollBar_right, "scrollBar_right", "sr", Opt_scrollBar_right, "scrollbar right"), |
104 | BOOL (Rs_scrollBar_right, "scrollBar_right", "sr", Opt_scrollBar_right, "scrollbar right"), |
105 | BOOL (Rs_scrollBar_floating, "scrollBar_floating", "st", Opt_scrollBar_floating, "scrollbar without a trough"), |
105 | BOOL (Rs_scrollBar_floating, "scrollBar_floating", "st", Opt_scrollBar_floating, "scrollbar without a trough"), |
106 | RSTRG (Rs_scrollBar_align, "scrollBar_align", "mode"), |
106 | RSTRG (Rs_scrollBar_align, "scrollBar_align", "mode"), |
… | |
… | |
108 | #endif |
108 | #endif |
109 | BOOL (Rs_scrollTtyOutput, "scrollTtyOutput", NULL, Opt_scrollTtyOutput, NULL), |
109 | BOOL (Rs_scrollTtyOutput, "scrollTtyOutput", NULL, Opt_scrollTtyOutput, NULL), |
110 | BOOL (Rs_scrollTtyOutput, NULL, "si", Opt_Reverse | Opt_scrollTtyOutput, "scroll-on-tty-output inhibit"), |
110 | BOOL (Rs_scrollTtyOutput, NULL, "si", Opt_Reverse | Opt_scrollTtyOutput, "scroll-on-tty-output inhibit"), |
111 | BOOL (Rs_scrollTtyKeypress, "scrollTtyKeypress", "sk", Opt_scrollTtyKeypress, "scroll-on-keypress"), |
111 | BOOL (Rs_scrollTtyKeypress, "scrollTtyKeypress", "sk", Opt_scrollTtyKeypress, "scroll-on-keypress"), |
112 | BOOL (Rs_scrollWithBuffer, "scrollWithBuffer", "sw", Opt_scrollWithBuffer, "scroll-with-buffer"), |
112 | BOOL (Rs_scrollWithBuffer, "scrollWithBuffer", "sw", Opt_scrollWithBuffer, "scroll-with-buffer"), |
113 | #ifdef TRANSPARENT |
113 | #if TRANSPARENT |
114 | BOOL (Rs_transparent, "inheritPixmap", "ip", Opt_transparent, "inherit parent pixmap"), |
114 | BOOL (Rs_transparent, "inheritPixmap", "ip", Opt_transparent, "inherit parent pixmap"), |
115 | BOOL (Rs_transparent_all, "inheritPixmapforce", "ipf", Opt_transparent_all, "forcefully inherit root pixmap"), |
|
|
116 | SWCH ("tr", Opt_transparent, NULL), |
115 | SWCH ("tr", Opt_transparent, NULL), |
|
|
116 | # if TINTING |
|
|
117 | STRG (Rs_color + Color_tint, "tintColor", "tint", "color", "tint color"), |
|
|
118 | # endif |
|
|
119 | #endif |
|
|
120 | #if OFF_FOCUS_FADING |
|
|
121 | STRG (Rs_fade, "fading", "fade", "%", "fade colors x% percent when rxvt-unicode is losing focus"), |
|
|
122 | STRG (Rs_color + Color_fade, "fadeColor", "fadecolor", "color", "target color for off-focus fading"), |
|
|
123 | #endif |
117 | #if TINTING |
124 | #if TINTING |
118 | STRG (Rs_color + Color_tint, "tintColor", "tint", "color", "tint color"), |
|
|
119 | #endif |
|
|
120 | #endif |
|
|
121 | #ifdef OFF_FOCUS_FADING |
|
|
122 | STRG (Rs_fade, "fading", "fade", "%", "make colors x% darker when rxvt-unicode is losing focus."), |
|
|
123 | #endif |
|
|
124 | #ifdef TINTING |
|
|
125 | STRG (Rs_shade, "shading", "sh", "%", "shade background by x% when tinting."), |
125 | STRG (Rs_shade, "shading", "sh", "%", "shade background by x% when tinting."), |
126 | #endif |
126 | #endif |
127 | BOOL (Rs_utmpInhibit, "utmpInhibit", "ut", Opt_utmpInhibit, "utmp inhibit"), |
127 | BOOL (Rs_utmpInhibit, "utmpInhibit", "ut", Opt_utmpInhibit, "utmp inhibit"), |
128 | #ifndef NO_BELL |
128 | #ifndef NO_BELL |
129 | BOOL (Rs_visualBell, "visualBell", "vb", Opt_visualBell, "visual bell"), |
129 | BOOL (Rs_visualBell, "visualBell", "vb", Opt_visualBell, "visual bell"), |
… | |
… | |
138 | BOOL (Rs_mouseWheelScrollPage, "mouseWheelScrollPage", NULL, Opt_mouseWheelScrollPage, NULL), |
138 | BOOL (Rs_mouseWheelScrollPage, "mouseWheelScrollPage", NULL, Opt_mouseWheelScrollPage, NULL), |
139 | #endif |
139 | #endif |
140 | #if ENABLE_FRILLS |
140 | #if ENABLE_FRILLS |
141 | BOOL (Rs_tripleclickwords, "tripleclickwords", "tcw", Opt_tripleclickwords, "triple click word selection"), |
141 | BOOL (Rs_tripleclickwords, "tripleclickwords", "tcw", Opt_tripleclickwords, "triple click word selection"), |
142 | BOOL (Rs_insecure, "insecure", "insecure", Opt_insecure, "enable possibly insecure escape sequences"), |
142 | BOOL (Rs_insecure, "insecure", "insecure", Opt_insecure, "enable possibly insecure escape sequences"), |
|
|
143 | BOOL (Rs_cursorUnderline, "cursorUnderline", "uc", Opt_cursorUnderline, "underline cursor"), |
143 | #endif |
144 | #endif |
144 | #ifdef CURSOR_BLINK |
145 | #if CURSOR_BLINK |
145 | BOOL (Rs_cursorBlink, "cursorBlink", "bc", Opt_cursorBlink, "blinking cursor"), |
146 | BOOL (Rs_cursorBlink, "cursorBlink", "bc", Opt_cursorBlink, "blinking cursor"), |
146 | #endif |
147 | #endif |
147 | #ifdef POINTER_BLANK |
148 | #ifdef POINTER_BLANK |
148 | BOOL (Rs_pointerBlank, "pointerBlank", "pb", Opt_pointerBlank, "switch off pointer after delay"), |
149 | BOOL (Rs_pointerBlank, "pointerBlank", "pb", Opt_pointerBlank, "switch off pointer after delay"), |
149 | #endif |
150 | #endif |
… | |
… | |
216 | STRG (Rs_name, NULL, "name", "string", "client instance, icon, and title strings"), |
217 | STRG (Rs_name, NULL, "name", "string", "client instance, icon, and title strings"), |
217 | STRG (Rs_title, "title", "title", "string", "title name for window"), |
218 | STRG (Rs_title, "title", "title", "string", "title name for window"), |
218 | STRG (Rs_title, NULL, "T", NULL, NULL), /* short form */ |
219 | STRG (Rs_title, NULL, "T", NULL, NULL), /* short form */ |
219 | STRG (Rs_iconName, "iconName", "n", "string", "icon name for window"), |
220 | STRG (Rs_iconName, "iconName", "n", "string", "icon name for window"), |
220 | STRG (Rs_saveLines, "saveLines", "sl", "number", "number of scrolled lines to save"), |
221 | STRG (Rs_saveLines, "saveLines", "sl", "number", "number of scrolled lines to save"), |
|
|
222 | #if ENABLE_XEMBED |
|
|
223 | STRG (Rs_embed, NULL, "embed", "windowid", "window id to embed terminal in"), |
|
|
224 | #endif |
221 | #if ENABLE_FRILLS |
225 | #if ENABLE_FRILLS |
|
|
226 | STRG (Rs_pty_fd, NULL, "pty-fd", "fileno", "file descriptor of pty to use"), |
222 | STRG (Rs_ext_bwidth, "externalBorder", "w", "number", "external border in pixels"), |
227 | STRG (Rs_ext_bwidth, "externalBorder", "w", "number", "external border in pixels"), |
223 | STRG (Rs_ext_bwidth, NULL, "bw", NULL, NULL), |
228 | STRG (Rs_ext_bwidth, NULL, "bw", NULL, NULL), |
224 | STRG (Rs_ext_bwidth, NULL, "borderwidth", NULL, NULL), |
229 | STRG (Rs_ext_bwidth, NULL, "borderwidth", NULL, NULL), |
225 | STRG (Rs_int_bwidth, "internalBorder", "b", "number", "internal border in pixels"), |
230 | STRG (Rs_int_bwidth, "internalBorder", "b", "number", "internal border in pixels"), |
226 | BOOL (Rs_borderLess, "borderLess", "bl", Opt_borderLess, "borderless window"), |
231 | BOOL (Rs_borderLess, "borderLess", "bl", Opt_borderLess, "borderless window"), |
… | |
… | |
246 | RSTRG (Rs_answerbackstring, "answerbackString", "string"), |
251 | RSTRG (Rs_answerbackstring, "answerbackString", "string"), |
247 | #ifndef NO_SECONDARY_SCREEN |
252 | #ifndef NO_SECONDARY_SCREEN |
248 | BOOL (Rs_secondaryScreen, "secondaryScreen", "ssc", Opt_secondaryScreen, "enable secondary screen"), |
253 | BOOL (Rs_secondaryScreen, "secondaryScreen", "ssc", Opt_secondaryScreen, "enable secondary screen"), |
249 | BOOL (Rs_secondaryScroll, "secondaryScroll", "ssr", Opt_secondaryScroll, "enable secondary screen scroll"), |
254 | BOOL (Rs_secondaryScroll, "secondaryScroll", "ssr", Opt_secondaryScroll, "enable secondary screen scroll"), |
250 | #endif |
255 | #endif |
|
|
256 | #if 0 && TODO |
251 | #if !defined(NO_RESOURCES) && defined(USE_XGETDEFAULT) |
257 | #if !defined(NO_RESOURCES) && defined(USE_XGETDEFAULT) |
252 | INFO ("xrm", "string", "X resource"), |
258 | INFO ("xrm", "string", "X resource"), |
|
|
259 | #endif |
253 | #endif |
260 | #endif |
254 | INFO ("e", "command arg ...", "command to execute") |
261 | INFO ("e", "command arg ...", "command to execute") |
255 | }; |
262 | }; |
256 | |
263 | |
257 | #undef INFO |
264 | #undef INFO |
… | |
… | |
407 | switch (type) |
414 | switch (type) |
408 | { |
415 | { |
409 | case 0: /* brief listing */ |
416 | case 0: /* brief listing */ |
410 | rxvt_log (" [-help] [--help]\n"); |
417 | rxvt_log (" [-help] [--help]\n"); |
411 | |
418 | |
412 | for (col = 1, i = 0; i < optList_size (); i++) |
419 | for (col = 1, i = 0; i < optList_size; i++) |
413 | if (optList[i].desc != NULL) |
420 | if (optList[i].desc != NULL) |
414 | { |
421 | { |
415 | int len = 0; |
422 | int len = 0; |
416 | |
423 | |
417 | if (!optList_isBool (i)) |
424 | if (!optList_isBool (i)) |
… | |
… | |
440 | break; |
447 | break; |
441 | |
448 | |
442 | case 1: /* full command-line listing */ |
449 | case 1: /* full command-line listing */ |
443 | rxvt_log (" [options] [-e command args]\n\nwhere options include:\n"); |
450 | rxvt_log (" [options] [-e command args]\n\nwhere options include:\n"); |
444 | |
451 | |
445 | for (i = 0; i < optList_size (); i++) |
452 | for (i = 0; i < optList_size; i++) |
446 | if (optList[i].desc != NULL) |
453 | if (optList[i].desc != NULL) |
447 | { |
454 | { |
448 | #ifdef DEBUG_STRICT |
455 | #ifdef DEBUG_STRICT |
449 | assert (optList[i].opt != NULL); |
456 | assert (optList[i].opt != NULL); |
450 | #endif |
457 | #endif |
… | |
… | |
461 | |
468 | |
462 | case 2: /* full resource listing */ |
469 | case 2: /* full resource listing */ |
463 | rxvt_log (" [options] [-e command args]\n\n" |
470 | rxvt_log (" [options] [-e command args]\n\n" |
464 | "where resources (long-options) include:\n"); |
471 | "where resources (long-options) include:\n"); |
465 | |
472 | |
466 | for (i = 0; i < optList_size (); i++) |
473 | for (i = 0; i < optList_size; i++) |
467 | if (optList[i].kw != NULL) |
474 | if (optList[i].kw != NULL) |
468 | rxvt_log (" %s: %*s%s\n", |
475 | rxvt_log (" %s: %*s%s\n", |
469 | optList[i].kw, |
476 | optList[i].kw, |
470 | (INDENT - strlen (optList[i].kw)), "", /* XXX */ |
477 | (INDENT - strlen (optList[i].kw)), "", /* XXX */ |
471 | (optList_isBool (i) ? "boolean" : optList[i].arg)); |
478 | (optList_isBool (i) ? "boolean" : optList[i].arg)); |
… | |
… | |
492 | int i, bad_option = 0; |
499 | int i, bad_option = 0; |
493 | static const char On[3] = "ON", Off[4] = "OFF"; |
500 | static const char On[3] = "ON", Off[4] = "OFF"; |
494 | |
501 | |
495 | for (i = 1; i < argc; i++) |
502 | for (i = 1; i < argc; i++) |
496 | { |
503 | { |
497 | unsigned int entry, longopt = 0; |
504 | unsigned int entry, longopt = 0; |
498 | const char *flag, *opt; |
505 | const char *flag, *opt; |
499 | |
506 | |
500 | opt = argv[i]; |
507 | opt = argv[i]; |
501 | #ifdef DEBUG_RESOURCES |
508 | #ifdef DEBUG_RESOURCES |
502 | fprintf (stderr, "argv[%d] = %s: ", i, opt); |
509 | fprintf (stderr, "argv[%d] = %s: ", i, opt); |
503 | #endif |
510 | #endif |
… | |
… | |
524 | rxvt_usage (longopt ? 2 : 1); |
531 | rxvt_usage (longopt ? 2 : 1); |
525 | if (!strcmp (opt, "h")) |
532 | if (!strcmp (opt, "h")) |
526 | rxvt_usage (0); |
533 | rxvt_usage (0); |
527 | |
534 | |
528 | /* feature: always try to match long-options */ |
535 | /* feature: always try to match long-options */ |
529 | for (entry = 0; entry < optList_size (); entry++) |
536 | for (entry = 0; entry < optList_size; entry++) |
530 | if ((optList[entry].kw && !strcmp (opt, optList[entry].kw)) |
537 | if ((optList[entry].kw && !strcmp (opt, optList[entry].kw)) |
531 | || (!longopt |
538 | || (!longopt |
532 | && optList[entry].opt && !strcmp (opt, optList[entry].opt))) |
539 | && optList[entry].opt && !strcmp (opt, optList[entry].opt))) |
533 | break; |
540 | break; |
534 | |
541 | |
535 | if (entry < optList_size ()) |
542 | if (entry < optList_size) |
536 | { |
543 | { |
537 | if (optList_isReverse (entry)) |
544 | if (optList_isReverse (entry)) |
538 | flag = flag == On ? Off : On; |
545 | flag = flag == On ? Off : On; |
539 | |
546 | |
540 | if (optList_strlen (entry)) |
547 | if (optList_strlen (entry)) |
… | |
… | |
554 | #ifdef DEBUG_RESOURCES |
561 | #ifdef DEBUG_RESOURCES |
555 | fprintf (stderr, "boolean (%s,%s) = %s\n", |
562 | fprintf (stderr, "boolean (%s,%s) = %s\n", |
556 | optList[entry].opt, optList[entry].kw, flag); |
563 | optList[entry].opt, optList[entry].kw, flag); |
557 | #endif |
564 | #endif |
558 | if (flag == On) |
565 | if (flag == On) |
559 | options |= (optList[entry].flag); |
566 | options |= optList[entry].flag; |
560 | else |
567 | else |
561 | options &= ~ (optList[entry].flag); |
568 | options &= ~optList[entry].flag; |
562 | |
569 | |
563 | if (optList[entry].doff != -1) |
570 | if (optList[entry].doff != -1) |
564 | rs[optList[entry].doff] = flag; |
571 | rs[optList[entry].doff] = flag; |
565 | } |
572 | } |
566 | } |
573 | } |
… | |
… | |
781 | return; |
788 | return; |
782 | |
789 | |
783 | len = strlen (name); |
790 | len = strlen (name); |
784 | while ((str = fgets (buffer, sizeof (buffer), stream)) != NULL) |
791 | while ((str = fgets (buffer, sizeof (buffer), stream)) != NULL) |
785 | { |
792 | { |
786 | unsigned int entry, n; |
793 | unsigned int entry, n; |
787 | |
794 | |
788 | while (*str && isspace (*str)) |
795 | while (*str && isspace (*str)) |
789 | str++; /* leading whitespace */ |
796 | str++; /* leading whitespace */ |
790 | |
797 | |
791 | if ((str[len] != '*' && str[len] != '.') |
798 | if ((str[len] != '*' && str[len] != '.') |
… | |
… | |
794 | str += (len + 1); /* skip `name*' or `name.' */ |
801 | str += (len + 1); /* skip `name*' or `name.' */ |
795 | |
802 | |
796 | # ifdef KEYSYM_RESOURCE |
803 | # ifdef KEYSYM_RESOURCE |
797 | if (!parse_keysym (str, NULL)) |
804 | if (!parse_keysym (str, NULL)) |
798 | # endif /* KEYSYM_RESOURCE */ |
805 | # endif /* KEYSYM_RESOURCE */ |
799 | for (entry = 0; entry < optList_size (); entry++) |
806 | for (entry = 0; entry < optList_size; entry++) |
800 | { |
807 | { |
801 | const char *kw = optList[entry].kw; |
808 | const char *kw = optList[entry].kw; |
802 | |
809 | |
803 | if (kw == NULL) |
810 | if (kw == NULL) |
804 | continue; |
811 | continue; |
… | |
… | |
808 | { |
815 | { |
809 | /* skip `keyword:' */ |
816 | /* skip `keyword:' */ |
810 | str += n + 1; |
817 | str += n + 1; |
811 | rxvt_Str_trim (str); |
818 | rxvt_Str_trim (str); |
812 | n = strlen (str); |
819 | n = strlen (str); |
|
|
820 | |
813 | if (n && rs[optList[entry].doff] == NULL) |
821 | if (n && rs[optList[entry].doff] == NULL) |
814 | { |
822 | { |
815 | /* not already set */ |
823 | /* not already set */ |
816 | int s; |
824 | int s; |
817 | char *p = 0; |
825 | char *p = 0; |
… | |
… | |
838 | rs[optList[entry].doff] = p; |
846 | rs[optList[entry].doff] = p; |
839 | allocated.push_back (p); |
847 | allocated.push_back (p); |
840 | |
848 | |
841 | if (optList_isBool (entry)) |
849 | if (optList_isBool (entry)) |
842 | { |
850 | { |
843 | s = strcasecmp (str, "TRUE") == 0 |
851 | s = strcasecmp (str, "true") == 0 |
844 | || strcasecmp (str, "YES") == 0 |
852 | || strcasecmp (str, "yes") == 0 |
845 | || strcasecmp (str, "ON") == 0 |
853 | || strcasecmp (str, "on") == 0 |
846 | || strcasecmp (str, "1") == 0; |
854 | || strcmp (str, "1") == 0; |
847 | |
855 | |
848 | if (optList_isReverse (entry)) |
856 | if (optList_isReverse (entry)) |
849 | s = !s; |
857 | s = !s; |
850 | |
858 | |
851 | if (s) |
859 | if (s) |
… | |
… | |
871 | /* |
879 | /* |
872 | * using XGetDefault () or the hand-rolled replacement |
880 | * using XGetDefault () or the hand-rolled replacement |
873 | */ |
881 | */ |
874 | /* ARGSUSED */ |
882 | /* ARGSUSED */ |
875 | void |
883 | void |
876 | rxvt_term::extract_resources (Display *display __attribute__ ((unused)), const char *name) |
884 | rxvt_term::extract_resources () |
877 | { |
885 | { |
|
|
886 | dDisp; |
|
|
887 | |
878 | #ifndef NO_RESOURCES |
888 | #ifndef NO_RESOURCES |
|
|
889 | |
|
|
890 | char *homedir = (char *)getenv ("HOME"); |
|
|
891 | char fname[1024]; |
879 | |
892 | |
880 | # if defined XAPPLOADDIR |
893 | # if defined XAPPLOADDIR |
881 | # if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
894 | # if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
882 | /* Compute the path of the possibly available localized Rxvt file */ |
895 | /* Compute the path of the possibly available localized Rxvt file */ |
883 | char *localepath = NULL; |
896 | char localepath[1024]; |
884 | |
897 | |
885 | if (locale != NULL) |
898 | if (locale) |
886 | { /* XXX: must limit length of string */ |
|
|
887 | localepath = (char *)rxvt_malloc (256); |
|
|
888 | sprintf (localepath, XAPPLOADDIRLOCALE "/" RESCLASS, |
899 | snprintf (localepath, sizeof (localepath), XAPPLOADDIRLOCALE "/" RESCLASS, locale); |
889 | (int) (258 - sizeof (XAPPLOADDIRLOCALE) - sizeof (RESCLASS)), |
900 | else |
890 | locale); /* 258 = 255 + 4 (-.*s) - 1 (/) */ |
901 | localepath[0] = 0; |
891 | } |
|
|
892 | |
|
|
893 | { |
|
|
894 | # endif |
902 | # endif |
895 | # endif |
903 | # endif |
896 | |
904 | |
897 | # ifdef USE_XGETDEFAULT |
905 | # ifdef USE_XGETDEFAULT |
898 | /* |
906 | /* |
899 | * get resources using the X library function |
907 | * get resources using the X library function |
900 | */ |
908 | */ |
901 | int entry; |
909 | int entry; |
902 | |
910 | |
903 | # ifdef XrmEnumOneLevel |
911 | # ifdef XrmEnumOneLevel |
904 | int i; |
912 | int i; |
905 | char *displayResource, *xe; |
913 | char *displayResource, *xe; |
906 | XrmName name_prefix[3]; |
914 | XrmName name_prefix[3]; |
907 | XrmClass class_prefix[3]; |
915 | XrmClass class_prefix[3]; |
908 | XrmDatabase database, rdb1; |
916 | XrmDatabase database, rdb1; |
909 | char fname[1024]; |
|
|
910 | |
917 | |
911 | XrmInitialize (); |
918 | XrmInitialize (); |
912 | database = NULL; |
919 | database = NULL; |
913 | |
920 | |
|
|
921 | // for ordering, see for example http://www.faqs.org/faqs/Xt-FAQ/ Subject: 20 |
|
|
922 | |
|
|
923 | // 6. System wide per application default file. |
|
|
924 | /* Add in Rxvt file */ |
|
|
925 | # if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
|
|
926 | if (*localepath |
|
|
927 | && ((rdb1 = XrmGetFileDatabase (localepath)) |
|
|
928 | || (rdb1 = XrmGetFileDatabase (XAPPLOADDIR "/" RESCLASS)))) |
|
|
929 | # endif |
|
|
930 | XrmMergeDatabases (rdb1, &database); |
|
|
931 | |
|
|
932 | /* Add in $XAPPLRESDIR/Rxvt only; not bothering with XUSERFILESEARCHPATH */ |
|
|
933 | if ((xe = (char *)getenv ("XAPPLRESDIR"))) |
|
|
934 | { |
|
|
935 | snprintf (fname, sizeof (fname), "%s/%s", xe, RESCLASS); |
|
|
936 | |
|
|
937 | if ((rdb1 = XrmGetFileDatabase (fname))) |
|
|
938 | XrmMergeDatabases (rdb1, &database); |
|
|
939 | } |
|
|
940 | |
|
|
941 | // 5. User's per application default file. |
|
|
942 | // none |
|
|
943 | |
|
|
944 | // 4. User's defaults file. |
914 | /* Get any Xserver defaults */ |
945 | /* Get any Xserver defaults */ |
915 | |
|
|
916 | displayResource = XResourceManagerString (display); |
946 | displayResource = XResourceManagerString (disp); |
917 | if (displayResource != NULL) |
947 | if (displayResource != NULL) |
|
|
948 | { |
918 | database = XrmGetStringDatabase (displayResource); |
949 | if ((rdb1 = XrmGetStringDatabase (displayResource))) |
919 | |
950 | XrmMergeDatabases (rdb1, &database); |
920 | # ifdef HAVE_EXTRA_XRESOURCE_FILES |
|
|
921 | /* Add in ~/.Xdefaults or ~/.Xresources */ |
|
|
922 | { |
951 | } |
923 | char *ptr; |
952 | else if (homedir) |
|
|
953 | { |
|
|
954 | snprintf (fname, sizeof (fname), "%s/.Xdefaults", homedir); |
924 | |
955 | |
925 | if ((ptr = (char *)getenv ("HOME")) == NULL) |
956 | if ((rdb1 = XrmGetFileDatabase (fname))) |
926 | ptr = "."; |
957 | XrmMergeDatabases (rdb1, &database); |
|
|
958 | } |
927 | |
959 | |
928 | for (i = 0; i < (sizeof (xnames) / sizeof (xnames[0])); i++) |
960 | /* Get screen specific resources */ |
|
|
961 | displayResource = XScreenResourceString (ScreenOfDisplay (disp, display->screen)); |
|
|
962 | if (displayResource != NULL) |
|
|
963 | { |
|
|
964 | if ((rdb1 = XrmGetStringDatabase (displayResource))) |
|
|
965 | /* Merge with screen-independent resources */ |
|
|
966 | XrmMergeDatabases (rdb1, &database); |
|
|
967 | |
|
|
968 | XFree (displayResource); |
|
|
969 | } |
|
|
970 | |
|
|
971 | // 3. User's per host defaults file |
|
|
972 | /* Add in XENVIRONMENT file */ |
|
|
973 | if ((xe = (char *)getenv ("XENVIRONMENT")) |
|
|
974 | && (rdb1 = XrmGetFileDatabase (xe))) |
|
|
975 | XrmMergeDatabases (rdb1, &database); |
|
|
976 | else if (homedir) |
|
|
977 | { |
|
|
978 | struct utsname un; |
|
|
979 | |
|
|
980 | if (!uname (&un)) |
929 | { |
981 | { |
930 | sprintf (fname, "%-.*s/%s", sizeof (fname) - strlen (xnames[i]) - 2, |
982 | snprintf (fname, sizeof (fname), "%s/.Xdefaults-%s", homedir, un.nodename); |
931 | ptr, xnames[i]); |
983 | |
932 | if ((rdb1 = XrmGetFileDatabase (fname))) |
984 | if ((rdb1 = XrmGetFileDatabase (fname))) |
|
|
985 | XrmMergeDatabases (rdb1, &database); |
|
|
986 | } |
|
|
987 | } |
|
|
988 | |
|
|
989 | XrmSetDatabase (disp, database); |
|
|
990 | # endif |
|
|
991 | |
|
|
992 | /* |
|
|
993 | * Query resources for options that affect us |
|
|
994 | */ |
|
|
995 | for (entry = 0; entry < optList_size; entry++) |
|
|
996 | { |
|
|
997 | int s; |
|
|
998 | char *p, *p0; |
|
|
999 | const char *kw = optList[entry].kw; |
|
|
1000 | |
|
|
1001 | if (kw == NULL || rs[optList[entry].doff] != NULL) |
|
|
1002 | continue; /* previously set */ |
|
|
1003 | |
|
|
1004 | p = XGetDefault (disp, rs[Rs_name], kw); |
|
|
1005 | p0 = XGetDefault (disp, "!INVALIDPROGRAMMENAMEDONTMATCH!", kw); |
|
|
1006 | if (p == NULL || (p0 && strcmp (p, p0) == 0)) |
|
|
1007 | { |
|
|
1008 | p = XGetDefault (disp, RESCLASS, kw); |
|
|
1009 | #ifdef RESFALLBACK |
|
|
1010 | if (p == NULL || (p0 && strcmp (p, p0) == 0)) |
|
|
1011 | p = XGetDefault (disp, RESFALLBACK, kw); |
|
|
1012 | #endif |
|
|
1013 | } |
|
|
1014 | |
|
|
1015 | if (p == NULL && p0) |
|
|
1016 | p = p0; |
|
|
1017 | |
|
|
1018 | if (p) |
|
|
1019 | { |
|
|
1020 | rs[optList[entry].doff] = p; |
|
|
1021 | |
|
|
1022 | if (optList_isBool (entry)) |
933 | { |
1023 | { |
934 | XrmMergeDatabases (rdb1, &database); |
1024 | s = strcasecmp (p, "TRUE") == 0 |
935 | # ifndef HAVE_BOTH_XRESOURCE_FILES |
1025 | || strcasecmp (p, "YES") == 0 |
|
|
1026 | || strcasecmp (p, "ON") == 0 |
|
|
1027 | || strcasecmp (p, "1") == 0; |
|
|
1028 | |
|
|
1029 | if (optList_isReverse (entry)) |
|
|
1030 | s = !s; |
|
|
1031 | |
|
|
1032 | if (s) |
|
|
1033 | options |= optList[entry].flag; |
936 | break; |
1034 | else |
937 | # endif |
1035 | options &= ~optList[entry].flag; |
938 | } |
1036 | } |
939 | } |
1037 | } |
940 | } |
1038 | } |
941 | # endif |
|
|
942 | |
1039 | |
943 | /* Add in XENVIRONMENT file */ |
|
|
944 | |
|
|
945 | if ((xe = (char *)getenv ("XENVIRONMENT")) != NULL |
|
|
946 | && (rdb1 = XrmGetFileDatabase (xe)) != NULL) |
|
|
947 | XrmMergeDatabases (rdb1, &database); |
|
|
948 | |
|
|
949 | /* Add in Rxvt file */ |
|
|
950 | # if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
|
|
951 | if (localepath == NULL || (rdb1 = XrmGetFileDatabase (localepath)) == NULL) |
|
|
952 | # endif |
|
|
953 | rdb1 = XrmGetFileDatabase (XAPPLOADDIR "/" RESCLASS); |
|
|
954 | |
|
|
955 | if (rdb1 != NULL) |
|
|
956 | XrmMergeDatabases (rdb1, &database); |
|
|
957 | |
|
|
958 | /* Add in $XAPPLRESDIR/Rxvt only; not bothering with XUSERFILESEARCHPATH */ |
|
|
959 | if ((xe = (char *)getenv ("XAPPLRESDIR")) != NULL) |
|
|
960 | { |
|
|
961 | sprintf (fname, "%-.*s/" RESCLASS, sizeof (fname) |
|
|
962 | - sizeof (RESCLASS) - 2, xe); |
|
|
963 | if ((rdb1 = XrmGetFileDatabase (fname)) != NULL) |
|
|
964 | XrmMergeDatabases (rdb1, &database); |
|
|
965 | } |
|
|
966 | |
|
|
967 | XrmSetDatabase (display, database); |
|
|
968 | # endif |
|
|
969 | |
|
|
970 | /* |
1040 | /* |
971 | * Query resources for options that affect us |
|
|
972 | */ |
|
|
973 | for (entry = 0; entry < optList_size (); entry++) |
|
|
974 | { |
|
|
975 | int s; |
|
|
976 | char *p, *p0; |
|
|
977 | const char *kw = optList[entry].kw; |
|
|
978 | |
|
|
979 | if (kw == NULL || rs[optList[entry].doff] != NULL) |
|
|
980 | continue; /* previously set */ |
|
|
981 | |
|
|
982 | p = XGetDefault (display, name, kw); |
|
|
983 | p0 = XGetDefault (display, "!INVALIDPROGRAMMENAMEDONTMATCH!", kw); |
|
|
984 | if (p == NULL || (p0 && strcmp (p, p0) == 0)) |
|
|
985 | { |
|
|
986 | p = XGetDefault (display, RESCLASS, kw); |
|
|
987 | #ifdef RESFALLBACK |
|
|
988 | if (p == NULL || (p0 && strcmp (p, p0) == 0)) |
|
|
989 | p = XGetDefault (display, RESFALLBACK, kw); |
|
|
990 | #endif |
|
|
991 | } |
|
|
992 | |
|
|
993 | if (p == NULL && p0) |
|
|
994 | p = p0; |
|
|
995 | |
|
|
996 | if (p) |
|
|
997 | { |
|
|
998 | rs[optList[entry].doff] = p; |
|
|
999 | |
|
|
1000 | if (optList_isBool (entry)) |
|
|
1001 | { |
|
|
1002 | s = strcasecmp (p, "TRUE") == 0 |
|
|
1003 | || strcasecmp (p, "YES") == 0 |
|
|
1004 | || strcasecmp (p, "ON") == 0 |
|
|
1005 | || strcasecmp (p, "1") == 0; |
|
|
1006 | if (optList_isReverse (entry)) |
|
|
1007 | s = !s; |
|
|
1008 | if (s) |
|
|
1009 | options |= (optList[entry].flag); |
|
|
1010 | else |
|
|
1011 | options &= ~ (optList[entry].flag); |
|
|
1012 | } |
|
|
1013 | } |
|
|
1014 | } |
|
|
1015 | |
|
|
1016 | /* |
|
|
1017 | * [R5 or later]: enumerate the resource database |
1041 | * [R5 or later]: enumerate the resource database |
1018 | */ |
1042 | */ |
1019 | # ifdef XrmEnumOneLevel |
|
|
1020 | # ifdef KEYSYM_RESOURCE |
1043 | # ifdef KEYSYM_RESOURCE |
1021 | name_prefix[0] = XrmStringToName (name); |
1044 | name_prefix[0] = XrmStringToName (rs[Rs_name]); |
1022 | name_prefix[1] = XrmStringToName ("keysym"); |
1045 | name_prefix[1] = XrmStringToName ("keysym"); |
1023 | name_prefix[2] = NULLQUARK; |
1046 | name_prefix[2] = NULLQUARK; |
1024 | class_prefix[0] = XrmStringToName (RESCLASS); |
1047 | class_prefix[0] = XrmStringToName (RESCLASS); |
1025 | class_prefix[1] = XrmStringToName ("Keysym"); |
1048 | class_prefix[1] = XrmStringToName ("Keysym"); |
1026 | class_prefix[2] = NULLQUARK; |
1049 | class_prefix[2] = NULLQUARK; |
1027 | /* XXX: Need to check sizeof (rxvt_t) == sizeof (XPointer) */ |
1050 | /* XXX: Need to check sizeof (rxvt_t) == sizeof (XPointer) */ |
1028 | XrmEnumerateDatabase (XrmGetDatabase (display), name_prefix, class_prefix, |
1051 | XrmEnumerateDatabase (XrmGetDatabase (disp), name_prefix, class_prefix, |
1029 | XrmEnumOneLevel, rxvt_define_key, NULL); |
1052 | XrmEnumOneLevel, rxvt_define_key, NULL); |
1030 | # ifdef RESFALLBACK |
1053 | # ifdef RESFALLBACK |
1031 | name_prefix[0] = XrmStringToName (RESFALLBACK); |
1054 | name_prefix[0] = XrmStringToName (RESFALLBACK); |
1032 | name_prefix[1] = XrmStringToName ("keysym"); |
1055 | name_prefix[1] = XrmStringToName ("keysym"); |
1033 | class_prefix[0] = XrmStringToName (RESFALLBACK); |
1056 | class_prefix[0] = XrmStringToName (RESFALLBACK); |
1034 | class_prefix[1] = XrmStringToName ("Keysym"); |
1057 | class_prefix[1] = XrmStringToName ("Keysym"); |
1035 | /* XXX: Need to check sizeof (rxvt_t) == sizeof (XPointer) */ |
1058 | /* XXX: Need to check sizeof (rxvt_t) == sizeof (XPointer) */ |
1036 | XrmEnumerateDatabase (XrmGetDatabase (display), name_prefix, class_prefix, |
1059 | XrmEnumerateDatabase (XrmGetDatabase (disp), name_prefix, class_prefix, |
1037 | XrmEnumOneLevel, rxvt_define_key, NULL); |
1060 | XrmEnumOneLevel, rxvt_define_key, NULL); |
1038 | # endif |
|
|
1039 | # endif |
1061 | # endif |
1040 | # endif |
1062 | # endif |
1041 | |
1063 | |
1042 | # else /* USE_XGETDEFAULT */ |
1064 | # else /* USE_XGETDEFAULT */ |
1043 | /* get resources the hard way, but save lots of memory */ |
1065 | /* get resources the hard way, but save lots of memory */ |
|
|
1066 | FILE *fd = NULL; |
|
|
1067 | |
|
|
1068 | if (homedir) |
|
|
1069 | { |
|
|
1070 | static const char *const xnames[2] = { ".Xdefaults", ".Xresources" }; |
|
|
1071 | |
|
|
1072 | for (int i = 0; i < (sizeof (xnames) / sizeof (xnames [0])); i++) |
|
|
1073 | { |
|
|
1074 | snprintf (fname, sizeof (fname), "%s/%s", homedir, xnames [i]); |
|
|
1075 | |
|
|
1076 | if ((fd = fopen (fname, "r")) != NULL) |
|
|
1077 | break; |
|
|
1078 | } |
|
|
1079 | } |
|
|
1080 | /* |
|
|
1081 | * The normal order to match resources is the following: |
|
|
1082 | * @ global resources (partial match, ~/.Xdefaults) |
|
|
1083 | * @ application file resources (XAPPLOADDIR/Rxvt) |
|
|
1084 | * @ class resources (~/.Xdefaults) |
|
|
1085 | * @ private resources (~/.Xdefaults) |
|
|
1086 | * |
|
|
1087 | * However, for the hand-rolled resources, the matching algorithm |
|
|
1088 | * checks if a resource string value has already been allocated |
|
|
1089 | * and won't overwrite it with (in this case) a less specific |
|
|
1090 | * resource value. |
|
|
1091 | * |
|
|
1092 | * This avoids multiple allocation. Also, when we've called this |
|
|
1093 | * routine command-line string options have already been applied so we |
|
|
1094 | * needn't to allocate for those resources. |
|
|
1095 | * |
|
|
1096 | * So, search in resources from most to least specific. |
|
|
1097 | * |
|
|
1098 | * Also, use a special sub-class so that we can use either or both of |
|
|
1099 | * "XTerm" and "Rxvt" as class names. |
|
|
1100 | */ |
|
|
1101 | |
|
|
1102 | get_xdefaults (fd, rs[Rs_name]); |
|
|
1103 | get_xdefaults (fd, RESCLASS); |
|
|
1104 | # ifdef RESFALLBACK |
|
|
1105 | get_xdefaults (fd, RESFALLBACK); |
|
|
1106 | # endif |
|
|
1107 | |
|
|
1108 | # if defined(XAPPLOADDIR) && defined(USE_XAPPLOADDIR) |
|
|
1109 | { |
1044 | FILE *fd = NULL; |
1110 | FILE *ad = NULL; |
1045 | char *home; |
|
|
1046 | |
1111 | |
1047 | if ((home = getenv ("HOME")) != NULL) |
1112 | # if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
|
|
1113 | if (!*localepath || (ad = fopen (localepath, "r")) == NULL) |
|
|
1114 | # endif |
|
|
1115 | ad = fopen (XAPPLOADDIR "/" RESCLASS, "r"); |
|
|
1116 | if (ad != NULL) |
1048 | { |
1117 | { |
1049 | unsigned int i, len = strlen (home) + 2; |
1118 | get_xdefaults (ad, RESCLASS); |
1050 | char *f = NULL; |
1119 | get_xdefaults (ad, ""); |
1051 | |
|
|
1052 | for (i = 0; i < (sizeof (xnames) / sizeof (xnames[0])); i++) |
|
|
1053 | { |
|
|
1054 | f = (char *)rxvt_realloc (f, len + strlen (xnames[i])); |
|
|
1055 | |
|
|
1056 | sprintf (f, "%s/%s", home, xnames[i]); |
|
|
1057 | |
|
|
1058 | if ((fd = fopen (f, "r")) != NULL) |
|
|
1059 | break; |
|
|
1060 | } |
|
|
1061 | |
|
|
1062 | free (f); |
1120 | fclose (ad); |
1063 | } |
1121 | } |
1064 | /* |
|
|
1065 | * The normal order to match resources is the following: |
|
|
1066 | * @ global resources (partial match, ~/.Xdefaults) |
|
|
1067 | * @ application file resources (XAPPLOADDIR/Rxvt) |
|
|
1068 | * @ class resources (~/.Xdefaults) |
|
|
1069 | * @ private resources (~/.Xdefaults) |
|
|
1070 | * |
|
|
1071 | * However, for the hand-rolled resources, the matching algorithm |
|
|
1072 | * checks if a resource string value has already been allocated |
|
|
1073 | * and won't overwrite it with (in this case) a less specific |
|
|
1074 | * resource value. |
|
|
1075 | * |
|
|
1076 | * This avoids multiple allocation. Also, when we've called this |
|
|
1077 | * routine command-line string options have already been applied so we |
|
|
1078 | * needn't to allocate for those resources. |
|
|
1079 | * |
|
|
1080 | * So, search in resources from most to least specific. |
|
|
1081 | * |
|
|
1082 | * Also, use a special sub-class so that we can use either or both of |
|
|
1083 | * "XTerm" and "Rxvt" as class names. |
|
|
1084 | */ |
|
|
1085 | |
|
|
1086 | get_xdefaults (fd, name); |
|
|
1087 | get_xdefaults (fd, RESCLASS); |
|
|
1088 | # ifdef RESFALLBACK |
|
|
1089 | get_xdefaults (fd, RESFALLBACK); |
|
|
1090 | # endif |
|
|
1091 | |
|
|
1092 | # if defined(XAPPLOADDIR) && defined(USE_XAPPLOADDIR) |
|
|
1093 | { |
|
|
1094 | FILE *ad = NULL; |
|
|
1095 | |
|
|
1096 | # if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
|
|
1097 | if (localepath == NULL || (ad = fopen (localepath, "r")) == NULL) |
|
|
1098 | # endif |
|
|
1099 | ad = fopen (XAPPLOADDIR "/" RESCLASS, "r"); |
|
|
1100 | if (ad != NULL) |
|
|
1101 | { |
|
|
1102 | get_xdefaults (ad, RESCLASS); |
|
|
1103 | get_xdefaults (ad, ""); |
|
|
1104 | fclose (ad); |
|
|
1105 | } |
|
|
1106 | } |
1122 | } |
1107 | # endif /* XAPPLOADDIR */ |
1123 | # endif /* XAPPLOADDIR */ |
1108 | |
1124 | |
1109 | get_xdefaults (fd, ""); /* partial match */ |
1125 | get_xdefaults (fd, ""); /* partial match */ |
1110 | if (fd != NULL) |
1126 | if (fd != NULL) |
1111 | fclose (fd); |
1127 | fclose (fd); |
1112 | # endif /* USE_XGETDEFAULT */ |
1128 | # endif /* USE_XGETDEFAULT */ |
1113 | |
|
|
1114 | # if defined XAPPLOADDIR |
|
|
1115 | # if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
|
|
1116 | |
|
|
1117 | } |
|
|
1118 | |
|
|
1119 | /* Free the path of the possibly available localized Rxvt file */ |
|
|
1120 | free (localepath); |
|
|
1121 | # endif |
|
|
1122 | # endif |
|
|
1123 | |
1129 | |
1124 | #endif /* NO_RESOURCES */ |
1130 | #endif /* NO_RESOURCES */ |
1125 | } |
1131 | } |
1126 | |
1132 | |
1127 | /*}}} */ |
1133 | /*}}} */ |