… | |
… | |
4 | * |
4 | * |
5 | * All portions of code are copyright by their respective author/s. |
5 | * All portions of code are copyright by their respective author/s. |
6 | * Copyright (c) 1994 Robert Nation <nation@rocket.sanders.lockheed.com> |
6 | * Copyright (c) 1994 Robert Nation <nation@rocket.sanders.lockheed.com> |
7 | * - original version |
7 | * - original version |
8 | * Copyright (c) 1997,1998 mj olesen <olesen@me.queensu.ca> |
8 | * Copyright (c) 1997,1998 mj olesen <olesen@me.queensu.ca> |
9 | * Copyright (c) 2003-2004 Marc Lehmann <pcg@goof.com> |
9 | * Copyright (c) 2003-2006 Marc Lehmann <pcg@goof.com> |
10 | * |
10 | * |
11 | * This program is free software; you can redistribute it and/or modify |
11 | * This program is free software; you can redistribute it and/or modify |
12 | * it under the terms of the GNU General Public License as published by |
12 | * it under the terms of the GNU General Public License as published by |
13 | * the Free Software Foundation; either version 2 of the License, or |
13 | * the Free Software Foundation; either version 2 of the License, or |
14 | * (at your option) any later version. |
14 | * (at your option) any later version. |
… | |
… | |
20 | * |
20 | * |
21 | * You should have received a copy of the GNU General Public License |
21 | * You should have received a copy of the GNU General Public License |
22 | * along with this program; if not, write to the Free Software |
22 | * along with this program; if not, write to the Free Software |
23 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
23 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
24 | *----------------------------------------------------------------------*/ |
24 | *----------------------------------------------------------------------*/ |
25 | /*----------------------------------------------------------------------* |
|
|
26 | * get resources from ~/.Xdefaults or ~/.Xresources with the memory-saving |
|
|
27 | * default or with XGetDefault() (#define USE_XGETDEFAULT) |
|
|
28 | *----------------------------------------------------------------------*/ |
|
|
29 | |
25 | |
30 | #include "../config.h" /* NECESSARY */ |
26 | #include "../config.h" /* NECESSARY */ |
31 | #include "rxvt.h" /* NECESSARY */ |
27 | #include "rxvt.h" /* NECESSARY */ |
32 | #include "version.h" |
28 | #include "version.h" |
33 | |
|
|
34 | #include <sys/utsname.h> |
|
|
35 | |
29 | |
36 | #ifdef KEYSYM_RESOURCE |
30 | #ifdef KEYSYM_RESOURCE |
37 | #include "keyboard.h" |
31 | #include "keyboard.h" |
38 | #endif |
32 | #endif |
39 | |
33 | |
… | |
… | |
161 | RSTRG (Rs_color + minCOLOR + 3, "color3", "color"), |
155 | RSTRG (Rs_color + minCOLOR + 3, "color3", "color"), |
162 | RSTRG (Rs_color + minCOLOR + 4, "color4", "color"), |
156 | RSTRG (Rs_color + minCOLOR + 4, "color4", "color"), |
163 | RSTRG (Rs_color + minCOLOR + 5, "color5", "color"), |
157 | RSTRG (Rs_color + minCOLOR + 5, "color5", "color"), |
164 | RSTRG (Rs_color + minCOLOR + 6, "color6", "color"), |
158 | RSTRG (Rs_color + minCOLOR + 6, "color6", "color"), |
165 | RSTRG (Rs_color + minCOLOR + 7, "color7", "color"), |
159 | RSTRG (Rs_color + minCOLOR + 7, "color7", "color"), |
166 | #ifndef NO_BRIGHTCOLOR |
|
|
167 | RSTRG (Rs_color + minBrightCOLOR + 0, "color8", "color"), |
160 | RSTRG (Rs_color + minBrightCOLOR + 0, "color8", "color"), |
168 | RSTRG (Rs_color + minBrightCOLOR + 1, "color9", "color"), |
161 | RSTRG (Rs_color + minBrightCOLOR + 1, "color9", "color"), |
169 | RSTRG (Rs_color + minBrightCOLOR + 2, "color10", "color"), |
162 | RSTRG (Rs_color + minBrightCOLOR + 2, "color10", "color"), |
170 | RSTRG (Rs_color + minBrightCOLOR + 3, "color11", "color"), |
163 | RSTRG (Rs_color + minBrightCOLOR + 3, "color11", "color"), |
171 | RSTRG (Rs_color + minBrightCOLOR + 4, "color12", "color"), |
164 | RSTRG (Rs_color + minBrightCOLOR + 4, "color12", "color"), |
172 | RSTRG (Rs_color + minBrightCOLOR + 5, "color13", "color"), |
165 | RSTRG (Rs_color + minBrightCOLOR + 5, "color13", "color"), |
173 | RSTRG (Rs_color + minBrightCOLOR + 6, "color14", "color"), |
166 | RSTRG (Rs_color + minBrightCOLOR + 6, "color14", "color"), |
174 | RSTRG (Rs_color + minBrightCOLOR + 7, "color15", "color"), |
167 | RSTRG (Rs_color + minBrightCOLOR + 7, "color15", "color"), |
175 | #endif /* NO_BRIGHTCOLOR */ |
|
|
176 | #ifndef NO_BOLD_UNDERLINE_REVERSE |
168 | #ifndef NO_BOLD_UNDERLINE_REVERSE |
177 | RSTRG (Rs_color + Color_BD, "colorBD", "color"), |
169 | RSTRG (Rs_color + Color_BD, "colorBD", "color"), |
178 | RSTRG (Rs_color + Color_IT, "colorIT", "color"), |
170 | RSTRG (Rs_color + Color_IT, "colorIT", "color"), |
179 | RSTRG (Rs_color + Color_UL, "colorUL", "color"), |
171 | RSTRG (Rs_color + Color_UL, "colorUL", "color"), |
180 | RSTRG (Rs_color + Color_RV, "colorRV", "color"), |
172 | RSTRG (Rs_color + Color_RV, "colorRV", "color"), |
… | |
… | |
195 | RSTRG (Rs_color + Color_cursor2, "cursorColor2", "color"), |
187 | RSTRG (Rs_color + Color_cursor2, "cursorColor2", "color"), |
196 | #endif /* NO_CURSORCOLOR */ |
188 | #endif /* NO_CURSORCOLOR */ |
197 | STRG (Rs_color + Color_pointer_fg, "pointerColor", "pr", "color", "pointer color"), |
189 | STRG (Rs_color + Color_pointer_fg, "pointerColor", "pr", "color", "pointer color"), |
198 | STRG (Rs_color + Color_pointer_bg, "pointerColor2", "pr2", "color", "pointer bg color"), |
190 | STRG (Rs_color + Color_pointer_bg, "pointerColor2", "pr2", "color", "pointer bg color"), |
199 | STRG (Rs_color + Color_border, "borderColor", "bd", "color", "border color"), |
191 | STRG (Rs_color + Color_border, "borderColor", "bd", "color", "border color"), |
200 | #if defined (XPM_BACKGROUND) || (MENUBAR_MAX) |
192 | #ifdef XPM_BACKGROUND |
201 | RSTRG (Rs_path, "path", "search path"), |
193 | RSTRG (Rs_path, "path", "search path"), |
202 | #endif /* defined (XPM_BACKGROUND) || (MENUBAR_MAX) */ |
|
|
203 | #ifdef XPM_BACKGROUND |
|
|
204 | STRG (Rs_backgroundPixmap, "backgroundPixmap", "pixmap", "file[;geom]", "background pixmap"), |
194 | STRG (Rs_backgroundPixmap, "backgroundPixmap", "pixmap", "file[;geom]", "background pixmap"), |
205 | #endif /* XPM_BACKGROUND */ |
|
|
206 | #if (MENUBAR_MAX) |
|
|
207 | RSTRG (Rs_menu, "menu", "name[;tag]"), |
|
|
208 | #endif |
195 | #endif |
209 | /* fonts: command-line option = resource name */ |
196 | /* fonts: command-line option = resource name */ |
210 | STRG (Rs_font, "font", "fn", "fontname", "normal text font"), |
197 | STRG (Rs_font, "font", "fn", "fontname", "normal text font"), |
211 | #if ENABLE_STYLES |
198 | #if ENABLE_STYLES |
212 | STRG (Rs_boldFont, "boldFont", "fb", "fontname", "bold font"), |
199 | STRG (Rs_boldFont, "boldFont", "fb", "fontname", "bold font"), |
… | |
… | |
227 | STRG (Rs_saveLines, "saveLines", "sl", "number", "number of scrolled lines to save"), |
214 | STRG (Rs_saveLines, "saveLines", "sl", "number", "number of scrolled lines to save"), |
228 | #if ENABLE_XEMBED |
215 | #if ENABLE_XEMBED |
229 | STRG (Rs_embed, NULL, "embed", "windowid", "window id to embed terminal in"), |
216 | STRG (Rs_embed, NULL, "embed", "windowid", "window id to embed terminal in"), |
230 | #endif |
217 | #endif |
231 | #if ENABLE_FRILLS |
218 | #if ENABLE_FRILLS |
|
|
219 | RSTRG (Rs_transient_for, "transient-for", "windowid"), |
232 | STRG (Rs_pty_fd, NULL, "pty-fd", "fileno", "file descriptor of pty to use"), |
220 | STRG (Rs_pty_fd, NULL, "pty-fd", "fileno", "file descriptor of pty to use"), |
233 | BOOL (Rs_hold, "hold", "hold", Opt_hold, "retain window after shell exit"), |
221 | BOOL (Rs_hold, "hold", "hold", Opt_hold, "retain window after shell exit"), |
234 | STRG (Rs_ext_bwidth, "externalBorder", "w", "number", "external border in pixels"), |
222 | STRG (Rs_ext_bwidth, "externalBorder", "w", "number", "external border in pixels"), |
235 | STRG (Rs_ext_bwidth, NULL, "bw", NULL, NULL), |
223 | STRG (Rs_ext_bwidth, NULL, "bw", NULL, NULL), |
236 | STRG (Rs_ext_bwidth, NULL, "borderwidth", NULL, NULL), |
224 | STRG (Rs_ext_bwidth, NULL, "borderwidth", NULL, NULL), |
237 | STRG (Rs_int_bwidth, "internalBorder", "b", "number", "internal border in pixels"), |
225 | STRG (Rs_int_bwidth, "internalBorder", "b", "number", "internal border in pixels"), |
238 | BOOL (Rs_borderLess, "borderLess", "bl", Opt_borderLess, "borderless window"), |
226 | BOOL (Rs_borderLess, "borderLess", "bl", Opt_borderLess, "borderless window"), |
|
|
227 | BOOL (Rs_skipBuiltinGlyphs, "skipBuiltinGlyphs", "sbg", Opt_skipBuiltinGlyphs, "do not use internal glyphs"), |
239 | STRG (Rs_lineSpace, "lineSpace", "lsp", "number", "number of extra pixels between rows"), |
228 | STRG (Rs_lineSpace, "lineSpace", "lsp", "number", "number of extra pixels between rows"), |
240 | #endif |
229 | #endif |
241 | #ifdef POINTER_BLANK |
230 | #ifdef POINTER_BLANK |
242 | RSTRG (Rs_pointerBlankDelay, "pointerBlankDelay", "number"), |
231 | RSTRG (Rs_pointerBlankDelay, "pointerBlankDelay", "number"), |
243 | #endif |
232 | #endif |
… | |
… | |
259 | #ifndef NO_SECONDARY_SCREEN |
248 | #ifndef NO_SECONDARY_SCREEN |
260 | BOOL (Rs_secondaryScreen, "secondaryScreen", "ssc", Opt_secondaryScreen, "enable secondary screen"), |
249 | BOOL (Rs_secondaryScreen, "secondaryScreen", "ssc", Opt_secondaryScreen, "enable secondary screen"), |
261 | BOOL (Rs_secondaryScroll, "secondaryScroll", "ssr", Opt_secondaryScroll, "enable secondary screen scroll"), |
250 | BOOL (Rs_secondaryScroll, "secondaryScroll", "ssr", Opt_secondaryScroll, "enable secondary screen scroll"), |
262 | #endif |
251 | #endif |
263 | #if ENABLE_PERL |
252 | #if ENABLE_PERL |
264 | STRG (Rs_perl_lib, "perl-lib", "perl-lib", "string", "colon-separated directories with extension scripts"), |
253 | RSTRG (Rs_perl_lib, "perl-lib", "string"), //, "colon-separated directories with extension scripts"),TODO |
265 | STRG (Rs_perl_eval, "perl-eval", "perl-eval", "string", "code to be evaluated after all extensions have been loaded"), |
254 | RSTRG (Rs_perl_eval, "perl-eval", "perl-eval"), // "string", "code to be evaluated after all extensions have been loaded"),TODO |
|
|
255 | RSTRG (Rs_perl_ext_1, "perl-ext-common", "string"), //, "colon-separated list of perl extensions to enable"),TODO |
266 | STRG (Rs_perl_ext, "perl-ext", "pe", "string", "colon-separated list of perl extensions to enable"), |
256 | STRG (Rs_perl_ext_2, "perl-ext", "pe", "string", "colon-separated list of perl extensions to enable for this instance"), |
267 | #endif |
257 | #endif |
268 | #if 0 && TODO |
258 | #ifndef NO_RESOURCES |
269 | #if !defined(NO_RESOURCES) && defined(USE_XGETDEFAULT) |
|
|
270 | INFO ("xrm", "string", "X resource"), |
259 | INFO ("xrm", "string", "X resource"), |
271 | #endif |
|
|
272 | #endif |
260 | #endif |
273 | INFO ("e", "command arg ...", "command to execute") |
261 | INFO ("e", "command arg ...", "command to execute") |
274 | }; |
262 | }; |
275 | |
263 | |
276 | #undef INFO |
264 | #undef INFO |
… | |
… | |
280 | #undef BOOL |
268 | #undef BOOL |
281 | /*}}} */ |
269 | /*}}} */ |
282 | |
270 | |
283 | static const char releasestring[] = "rxvt-unicode (" RXVTNAME ") v" VERSION " - released: " DATE "\n"; |
271 | static const char releasestring[] = "rxvt-unicode (" RXVTNAME ") v" VERSION " - released: " DATE "\n"; |
284 | static const char optionsstring[] = "options: " |
272 | static const char optionsstring[] = "options: " |
|
|
273 | #if ENABLE_PERL |
|
|
274 | "perl," |
|
|
275 | #endif |
285 | #if XFT |
276 | #if XFT |
286 | "xft," |
277 | "xft," |
287 | #endif |
278 | #endif |
288 | #if ENABLE_STYLES |
279 | #if ENABLE_STYLES |
289 | "styles," |
280 | "styles," |
… | |
… | |
329 | #if TINTING |
320 | #if TINTING |
330 | "tint," |
321 | "tint," |
331 | #endif |
322 | #endif |
332 | #if defined(UTMP_SUPPORT) |
323 | #if defined(UTMP_SUPPORT) |
333 | "utmp," |
324 | "utmp," |
334 | #endif |
|
|
335 | #if defined(MENUBAR) |
|
|
336 | "menubar," |
|
|
337 | #endif |
325 | #endif |
338 | #if defined(USE_XIM) |
326 | #if defined(USE_XIM) |
339 | "XIM," |
327 | "XIM," |
340 | #endif |
328 | #endif |
341 | "scrollbars=" |
329 | "scrollbars=" |
… | |
… | |
372 | "no_delete," |
360 | "no_delete," |
373 | #endif |
361 | #endif |
374 | #if EIGHT_BIT_CONTROLS |
362 | #if EIGHT_BIT_CONTROLS |
375 | "8bitctrls," |
363 | "8bitctrls," |
376 | #endif |
364 | #endif |
377 | #if !defined(NO_STRINGS) |
|
|
378 | "strings," |
|
|
379 | #endif |
|
|
380 | #if defined(ENABLE_FRILLS) |
365 | #if defined(ENABLE_FRILLS) |
381 | "frills," |
366 | "frills," |
382 | #endif |
367 | #endif |
383 | #if defined(PREFER_24BIT) |
368 | #if defined(PREFER_24BIT) |
384 | "24bit," |
369 | "24bit," |
… | |
… | |
401 | #if defined(POINTER_BLANK) |
386 | #if defined(POINTER_BLANK) |
402 | "pointerBlank," |
387 | "pointerBlank," |
403 | #endif |
388 | #endif |
404 | #if defined(NO_RESOURCES) |
389 | #if defined(NO_RESOURCES) |
405 | "NoResources" |
390 | "NoResources" |
406 | #else |
|
|
407 | # if defined(USE_XGETDEFAULT) |
|
|
408 | "XGetDefaults" |
|
|
409 | # else |
|
|
410 | ".Xdefaults" |
|
|
411 | # endif |
|
|
412 | #endif |
391 | #endif |
413 | "\nUsage: "; /* Usage */ |
392 | "\nUsage: "; /* Usage */ |
414 | |
393 | |
415 | #define INDENT 18 |
394 | #define INDENT 18 |
416 | |
395 | |
… | |
… | |
572 | { /* boolean value */ |
551 | { /* boolean value */ |
573 | #ifdef DEBUG_RESOURCES |
552 | #ifdef DEBUG_RESOURCES |
574 | fprintf (stderr, "boolean (%s,%s) = %s\n", |
553 | fprintf (stderr, "boolean (%s,%s) = %s\n", |
575 | optList[entry].opt, optList[entry].kw, flag); |
554 | optList[entry].opt, optList[entry].kw, flag); |
576 | #endif |
555 | #endif |
577 | if (flag == On) |
|
|
578 | SET_OPTION (optList[entry].flag & Optflag_mask); |
556 | set_option (optList[entry].flag & Optflag_mask, flag == On); |
579 | else |
|
|
580 | CLR_OPTION (optList[entry].flag & Optflag_mask); |
|
|
581 | |
557 | |
582 | if (optList[entry].doff != -1) |
558 | if (optList[entry].doff != -1) |
583 | rs[optList[entry].doff] = flag; |
559 | rs[optList[entry].doff] = flag; |
584 | } |
560 | } |
585 | } |
561 | } |
… | |
… | |
694 | { |
670 | { |
695 | if ((n = rxvt_Str_match (str, "keysym.")) == 0) |
671 | if ((n = rxvt_Str_match (str, "keysym.")) == 0) |
696 | return 0; |
672 | return 0; |
697 | |
673 | |
698 | str += n; /* skip `keysym.' */ |
674 | str += n; /* skip `keysym.' */ |
699 | if ((pmodend = strchr (str, ':')) < str) |
675 | if (!(pmodend = strchr (str, ':'))) |
700 | return -1; |
676 | return -1; |
701 | } |
677 | } |
702 | else |
678 | else |
703 | pmodend = str + strlen(str); |
679 | pmodend = str + strlen(str); |
704 | |
680 | |
… | |
… | |
782 | keyboard->register_user_translation (sym, state, newarg); |
758 | keyboard->register_user_translation (sym, state, newarg); |
783 | return 1; |
759 | return 1; |
784 | } |
760 | } |
785 | |
761 | |
786 | # endif /* KEYSYM_RESOURCE */ |
762 | # endif /* KEYSYM_RESOURCE */ |
|
|
763 | #endif /* NO_RESOURCES */ |
787 | |
764 | |
788 | # ifndef USE_XGETDEFAULT |
765 | static char * |
789 | /*{{{ rxvt_get_xdefaults () */ |
766 | get_res (XrmDatabase database, const char *program, const char *option) |
790 | /* |
|
|
791 | * the matching algorithm used for memory-save fake resources |
|
|
792 | */ |
|
|
793 | void |
|
|
794 | rxvt_term::get_xdefaults (FILE *stream, const char *name) |
|
|
795 | { |
767 | { |
796 | unsigned int len; |
768 | char resource[512]; |
797 | char *str, buffer[256]; |
769 | char *type; |
|
|
770 | XrmValue result; |
798 | |
771 | |
799 | if (stream == NULL) |
772 | snprintf (resource, sizeof (resource), "%s.%s", program, option); |
800 | return; |
773 | XrmGetResource (database, resource, resource, &type, &result); |
801 | |
774 | |
802 | len = strlen (name); |
775 | return result.addr; |
803 | while ((str = fgets (buffer, sizeof (buffer), stream)) != NULL) |
776 | } |
|
|
777 | |
|
|
778 | const char * |
|
|
779 | rxvt_term::x_resource (const char *name) |
|
|
780 | { |
|
|
781 | XrmDatabase database = XrmGetDatabase (display->display); |
|
|
782 | |
|
|
783 | const char *p = get_res (database, rs[Rs_name], name); |
|
|
784 | const char *p0 = get_res (database, "!INVALIDPROGRAMMENAMEDONTMATCH!", name); |
|
|
785 | |
|
|
786 | if (p == NULL || (p0 && strcmp (p, p0) == 0)) |
804 | { |
787 | { |
805 | unsigned int entry, n; |
788 | p = get_res (database, RESCLASS, name); |
806 | |
789 | #ifdef RESFALLBACK |
807 | while (*str && isspace (*str)) |
790 | if (p == NULL || (p0 && strcmp (p, p0) == 0)) |
808 | str++; /* leading whitespace */ |
791 | p = get_res (database, RESFALLBACK, name); |
809 | |
792 | #endif |
810 | if ((str[len] != '*' && str[len] != '.') |
|
|
811 | || (len && strncmp (str, name, len))) |
|
|
812 | continue; |
|
|
813 | str += (len + 1); /* skip `name*' or `name.' */ |
|
|
814 | |
|
|
815 | # ifdef KEYSYM_RESOURCE |
|
|
816 | if (!parse_keysym (str, NULL)) |
|
|
817 | # endif /* KEYSYM_RESOURCE */ |
|
|
818 | for (entry = 0; entry < optList_size; entry++) |
|
|
819 | { |
|
|
820 | const char *kw = optList[entry].kw; |
|
|
821 | |
|
|
822 | if (kw == NULL) |
|
|
823 | continue; |
|
|
824 | |
|
|
825 | n = strlen (kw); |
|
|
826 | if (str[n] == ':' && rxvt_Str_match (str, kw)) |
|
|
827 | { |
|
|
828 | /* skip `keyword:' */ |
|
|
829 | str += n + 1; |
|
|
830 | rxvt_Str_trim (str); |
|
|
831 | n = strlen (str); |
|
|
832 | |
|
|
833 | if (n && rs[optList[entry].doff] == NULL) |
|
|
834 | { |
|
|
835 | /* not already set */ |
|
|
836 | int s; |
|
|
837 | char *p = 0; |
|
|
838 | |
|
|
839 | for (int o = 0;;) |
|
|
840 | { |
|
|
841 | p = (char *)rxvt_realloc (p, o + n + 1); |
|
|
842 | memcpy (p + o, str, n); |
|
|
843 | o += n; |
|
|
844 | p[o] = 0; |
|
|
845 | |
|
|
846 | if (o == 0 || p[o - 1] != '\\') // continuation line |
|
|
847 | break; |
|
|
848 | |
|
|
849 | o--; // eat "\" |
|
|
850 | |
|
|
851 | if ((str = fgets (buffer, sizeof (buffer), stream)) == NULL) |
|
|
852 | break; |
|
|
853 | |
|
|
854 | rxvt_Str_trim (str); |
|
|
855 | n = strlen (str); |
|
|
856 | } |
|
|
857 | |
|
|
858 | rs[optList[entry].doff] = p; |
|
|
859 | allocated.push_back (p); |
|
|
860 | |
|
|
861 | if (optList_isBool (entry)) |
|
|
862 | { |
|
|
863 | s = strcasecmp (str, "true") == 0 |
|
|
864 | || strcasecmp (str, "yes") == 0 |
|
|
865 | || strcasecmp (str, "on") == 0 |
|
|
866 | || strcmp (str, "1") == 0; |
|
|
867 | |
|
|
868 | if (optList_isReverse (entry)) |
|
|
869 | s = !s; |
|
|
870 | |
|
|
871 | if (s) |
|
|
872 | SET_OPTION (optList[entry].flag & Optflag_mask); |
|
|
873 | else |
|
|
874 | CLR_OPTION (optList[entry].flag & Optflag_mask); |
|
|
875 | } |
|
|
876 | } |
|
|
877 | |
|
|
878 | break; |
|
|
879 | } |
|
|
880 | } |
|
|
881 | } |
793 | } |
882 | |
794 | |
883 | rewind (stream); |
795 | if (p == NULL && p0) |
|
|
796 | p = p0; |
|
|
797 | |
|
|
798 | return p; |
884 | } |
799 | } |
885 | |
800 | |
886 | /*}}} */ |
|
|
887 | # endif /* ! USE_XGETDEFAULT */ |
|
|
888 | #endif /* NO_RESOURCES */ |
|
|
889 | |
|
|
890 | /*{{{ read the resources files */ |
|
|
891 | /* |
|
|
892 | * using XGetDefault () or the hand-rolled replacement |
|
|
893 | */ |
|
|
894 | /* ARGSUSED */ |
|
|
895 | void |
801 | void |
896 | rxvt_term::extract_resources () |
802 | rxvt_term::extract_resources () |
897 | { |
803 | { |
898 | dDisp; |
|
|
899 | |
|
|
900 | #ifndef NO_RESOURCES |
804 | #ifndef NO_RESOURCES |
901 | |
|
|
902 | char *homedir = (char *)getenv ("HOME"); |
|
|
903 | char fname[1024]; |
|
|
904 | |
|
|
905 | # if defined XAPPLOADDIR |
|
|
906 | # if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
|
|
907 | /* Compute the path of the possibly available localized Rxvt file */ |
|
|
908 | char localepath[1024]; |
|
|
909 | |
|
|
910 | if (locale) |
|
|
911 | snprintf (localepath, sizeof (localepath), XAPPLOADDIRLOCALE "/" RESCLASS, locale); |
|
|
912 | else |
|
|
913 | localepath[0] = 0; |
|
|
914 | # endif |
|
|
915 | # endif |
|
|
916 | |
|
|
917 | # ifdef USE_XGETDEFAULT |
|
|
918 | /* |
|
|
919 | * get resources using the X library function |
|
|
920 | */ |
|
|
921 | int entry; |
|
|
922 | |
|
|
923 | # ifdef XrmEnumOneLevel |
|
|
924 | char *displayResource, *xe; |
|
|
925 | XrmName name_prefix[3]; |
|
|
926 | XrmClass class_prefix[3]; |
|
|
927 | XrmDatabase database, rdb1; |
|
|
928 | |
|
|
929 | XrmInitialize (); |
|
|
930 | database = NULL; |
|
|
931 | |
|
|
932 | // for ordering, see for example http://www.faqs.org/faqs/Xt-FAQ/ Subject: 20 |
|
|
933 | |
|
|
934 | // 6. System wide per application default file. |
|
|
935 | /* Add in Rxvt file */ |
|
|
936 | # if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
|
|
937 | if (*localepath |
|
|
938 | && ((rdb1 = XrmGetFileDatabase (localepath)) |
|
|
939 | || (rdb1 = XrmGetFileDatabase (XAPPLOADDIR "/" RESCLASS)))) |
|
|
940 | # endif |
|
|
941 | XrmMergeDatabases (rdb1, &database); |
|
|
942 | |
|
|
943 | /* Add in $XAPPLRESDIR/Rxvt only; not bothering with XUSERFILESEARCHPATH */ |
|
|
944 | if ((xe = (char *)getenv ("XAPPLRESDIR"))) |
|
|
945 | { |
|
|
946 | snprintf (fname, sizeof (fname), "%s/%s", xe, RESCLASS); |
|
|
947 | |
|
|
948 | if ((rdb1 = XrmGetFileDatabase (fname))) |
|
|
949 | XrmMergeDatabases (rdb1, &database); |
|
|
950 | } |
|
|
951 | |
|
|
952 | // 5. User's per application default file. |
|
|
953 | // none |
|
|
954 | |
|
|
955 | // 4. User's defaults file. |
|
|
956 | /* Get any Xserver defaults */ |
|
|
957 | displayResource = XResourceManagerString (disp); |
|
|
958 | if (displayResource != NULL) |
|
|
959 | { |
|
|
960 | if ((rdb1 = XrmGetStringDatabase (displayResource))) |
|
|
961 | XrmMergeDatabases (rdb1, &database); |
|
|
962 | } |
|
|
963 | else if (homedir) |
|
|
964 | { |
|
|
965 | snprintf (fname, sizeof (fname), "%s/.Xdefaults", homedir); |
|
|
966 | |
|
|
967 | if ((rdb1 = XrmGetFileDatabase (fname))) |
|
|
968 | XrmMergeDatabases (rdb1, &database); |
|
|
969 | } |
|
|
970 | |
|
|
971 | /* Get screen specific resources */ |
|
|
972 | displayResource = XScreenResourceString (ScreenOfDisplay (disp, display->screen)); |
|
|
973 | if (displayResource != NULL) |
|
|
974 | { |
|
|
975 | if ((rdb1 = XrmGetStringDatabase (displayResource))) |
|
|
976 | /* Merge with screen-independent resources */ |
|
|
977 | XrmMergeDatabases (rdb1, &database); |
|
|
978 | |
|
|
979 | XFree (displayResource); |
|
|
980 | } |
|
|
981 | |
|
|
982 | // 3. User's per host defaults file |
|
|
983 | /* Add in XENVIRONMENT file */ |
|
|
984 | if ((xe = (char *)getenv ("XENVIRONMENT")) |
|
|
985 | && (rdb1 = XrmGetFileDatabase (xe))) |
|
|
986 | XrmMergeDatabases (rdb1, &database); |
|
|
987 | else if (homedir) |
|
|
988 | { |
|
|
989 | struct utsname un; |
|
|
990 | |
|
|
991 | if (!uname (&un)) |
|
|
992 | { |
|
|
993 | snprintf (fname, sizeof (fname), "%s/.Xdefaults-%s", homedir, un.nodename); |
|
|
994 | |
|
|
995 | if ((rdb1 = XrmGetFileDatabase (fname))) |
|
|
996 | XrmMergeDatabases (rdb1, &database); |
|
|
997 | } |
|
|
998 | } |
|
|
999 | |
|
|
1000 | XrmSetDatabase (disp, database); |
|
|
1001 | # endif |
|
|
1002 | |
|
|
1003 | /* |
805 | /* |
1004 | * Query resources for options that affect us |
806 | * Query resources for options that affect us |
1005 | */ |
807 | */ |
1006 | for (entry = 0; entry < optList_size; entry++) |
808 | for (int entry = 0; entry < optList_size; entry++) |
1007 | { |
809 | { |
1008 | int s; |
810 | int s; |
1009 | char *p, *p0; |
|
|
1010 | const char *kw = optList[entry].kw; |
811 | const char *kw = optList[entry].kw; |
1011 | |
812 | |
1012 | if (kw == NULL || rs[optList[entry].doff] != NULL) |
813 | if (kw == NULL || rs[optList[entry].doff] != NULL) |
1013 | continue; /* previously set */ |
814 | continue; // previously set |
1014 | |
815 | |
1015 | p = XGetDefault (disp, rs[Rs_name], kw); |
816 | const char *p = x_resource (kw); |
1016 | p0 = XGetDefault (disp, "!INVALIDPROGRAMMENAMEDONTMATCH!", kw); |
|
|
1017 | if (p == NULL || (p0 && strcmp (p, p0) == 0)) |
|
|
1018 | { |
|
|
1019 | p = XGetDefault (disp, RESCLASS, kw); |
|
|
1020 | #ifdef RESFALLBACK |
|
|
1021 | if (p == NULL || (p0 && strcmp (p, p0) == 0)) |
|
|
1022 | p = XGetDefault (disp, RESFALLBACK, kw); |
|
|
1023 | #endif |
|
|
1024 | } |
|
|
1025 | |
|
|
1026 | if (p == NULL && p0) |
|
|
1027 | p = p0; |
|
|
1028 | |
817 | |
1029 | if (p) |
818 | if (p) |
1030 | { |
819 | { |
|
|
820 | p = strdup (p); |
|
|
821 | allocated.push_back ((void *)p); |
1031 | rs[optList[entry].doff] = p; |
822 | rs[optList[entry].doff] = p; |
1032 | |
823 | |
1033 | if (optList_isBool (entry)) |
824 | if (optList_isBool (entry)) |
1034 | { |
825 | { |
1035 | s = strcasecmp (p, "TRUE") == 0 |
826 | s = strcasecmp (p, "TRUE") == 0 |
… | |
… | |
1038 | || strcasecmp (p, "1") == 0; |
829 | || strcasecmp (p, "1") == 0; |
1039 | |
830 | |
1040 | if (optList_isReverse (entry)) |
831 | if (optList_isReverse (entry)) |
1041 | s = !s; |
832 | s = !s; |
1042 | |
833 | |
1043 | if (s) |
|
|
1044 | SET_OPTION (optList[entry].flag & Optflag_mask); |
834 | set_option (optList[entry].flag & Optflag_mask, s); |
1045 | else |
|
|
1046 | CLR_OPTION (optList[entry].flag & Optflag_mask); |
|
|
1047 | } |
835 | } |
1048 | } |
836 | } |
1049 | } |
837 | } |
1050 | |
838 | |
1051 | /* |
839 | /* |
1052 | * [R5 or later]: enumerate the resource database |
840 | * [R5 or later]: enumerate the resource database |
1053 | */ |
841 | */ |
1054 | # ifdef KEYSYM_RESOURCE |
842 | # ifdef KEYSYM_RESOURCE |
|
|
843 | XrmDatabase database = XrmGetDatabase (display->display); |
|
|
844 | XrmName name_prefix[3]; |
|
|
845 | XrmClass class_prefix[3]; |
|
|
846 | |
1055 | name_prefix[0] = XrmStringToName (rs[Rs_name]); |
847 | name_prefix[0] = XrmStringToName (rs[Rs_name]); |
1056 | name_prefix[1] = XrmStringToName ("keysym"); |
848 | name_prefix[1] = XrmStringToName ("keysym"); |
1057 | name_prefix[2] = NULLQUARK; |
849 | name_prefix[2] = NULLQUARK; |
1058 | class_prefix[0] = XrmStringToName (RESCLASS); |
850 | class_prefix[0] = XrmStringToName (RESCLASS); |
1059 | class_prefix[1] = XrmStringToName ("Keysym"); |
851 | class_prefix[1] = XrmStringToName ("Keysym"); |
1060 | class_prefix[2] = NULLQUARK; |
852 | class_prefix[2] = NULLQUARK; |
1061 | /* XXX: Need to check sizeof (rxvt_t) == sizeof (XPointer) */ |
853 | /* XXX: Need to check sizeof (rxvt_t) == sizeof (XPointer) */ |
1062 | XrmEnumerateDatabase (XrmGetDatabase (disp), name_prefix, class_prefix, |
854 | XrmEnumerateDatabase (database, name_prefix, class_prefix, |
1063 | XrmEnumOneLevel, rxvt_define_key, NULL); |
855 | XrmEnumOneLevel, rxvt_define_key, NULL); |
1064 | # ifdef RESFALLBACK |
856 | # ifdef RESFALLBACK |
1065 | name_prefix[0] = XrmStringToName (RESFALLBACK); |
857 | name_prefix[0] = XrmStringToName (RESFALLBACK); |
1066 | name_prefix[1] = XrmStringToName ("keysym"); |
858 | name_prefix[1] = XrmStringToName ("keysym"); |
1067 | class_prefix[0] = XrmStringToName (RESFALLBACK); |
859 | class_prefix[0] = XrmStringToName (RESFALLBACK); |
1068 | class_prefix[1] = XrmStringToName ("Keysym"); |
860 | class_prefix[1] = XrmStringToName ("Keysym"); |
1069 | /* XXX: Need to check sizeof (rxvt_t) == sizeof (XPointer) */ |
861 | /* XXX: Need to check sizeof (rxvt_t) == sizeof (XPointer) */ |
1070 | XrmEnumerateDatabase (XrmGetDatabase (disp), name_prefix, class_prefix, |
862 | XrmEnumerateDatabase (database, name_prefix, class_prefix, |
1071 | XrmEnumOneLevel, rxvt_define_key, NULL); |
863 | XrmEnumOneLevel, rxvt_define_key, NULL); |
1072 | # endif |
864 | # endif |
1073 | # endif |
865 | # endif |
1074 | |
866 | |
1075 | # else /* USE_XGETDEFAULT */ |
|
|
1076 | /* get resources the hard way, but save lots of memory */ |
|
|
1077 | FILE *fd = NULL; |
|
|
1078 | |
|
|
1079 | if (homedir) |
|
|
1080 | { |
|
|
1081 | static const char *const xnames[2] = { ".Xdefaults", ".Xresources" }; |
|
|
1082 | |
|
|
1083 | for (int i = 0; i < (sizeof (xnames) / sizeof (xnames [0])); i++) |
|
|
1084 | { |
|
|
1085 | snprintf (fname, sizeof (fname), "%s/%s", homedir, xnames [i]); |
|
|
1086 | |
|
|
1087 | if ((fd = fopen (fname, "r")) != NULL) |
|
|
1088 | break; |
|
|
1089 | } |
|
|
1090 | } |
|
|
1091 | /* |
|
|
1092 | * The normal order to match resources is the following: |
|
|
1093 | * @ global resources (partial match, ~/.Xdefaults) |
|
|
1094 | * @ application file resources (XAPPLOADDIR/Rxvt) |
|
|
1095 | * @ class resources (~/.Xdefaults) |
|
|
1096 | * @ private resources (~/.Xdefaults) |
|
|
1097 | * |
|
|
1098 | * However, for the hand-rolled resources, the matching algorithm |
|
|
1099 | * checks if a resource string value has already been allocated |
|
|
1100 | * and won't overwrite it with (in this case) a less specific |
|
|
1101 | * resource value. |
|
|
1102 | * |
|
|
1103 | * This avoids multiple allocation. Also, when we've called this |
|
|
1104 | * routine command-line string options have already been applied so we |
|
|
1105 | * needn't to allocate for those resources. |
|
|
1106 | * |
|
|
1107 | * So, search in resources from most to least specific. |
|
|
1108 | * |
|
|
1109 | * Also, use a special sub-class so that we can use either or both of |
|
|
1110 | * "XTerm" and "Rxvt" as class names. |
|
|
1111 | */ |
|
|
1112 | |
|
|
1113 | get_xdefaults (fd, rs[Rs_name]); |
|
|
1114 | get_xdefaults (fd, RESCLASS); |
|
|
1115 | # ifdef RESFALLBACK |
|
|
1116 | get_xdefaults (fd, RESFALLBACK); |
|
|
1117 | # endif |
|
|
1118 | |
|
|
1119 | # if defined(XAPPLOADDIR) && defined(USE_XAPPLOADDIR) |
|
|
1120 | { |
|
|
1121 | FILE *ad = NULL; |
|
|
1122 | |
|
|
1123 | # if defined(HAVE_XSETLOCALE) || defined(HAVE_SETLOCALE) |
|
|
1124 | if (!*localepath || (ad = fopen (localepath, "r")) == NULL) |
|
|
1125 | # endif |
|
|
1126 | ad = fopen (XAPPLOADDIR "/" RESCLASS, "r"); |
|
|
1127 | if (ad != NULL) |
|
|
1128 | { |
|
|
1129 | get_xdefaults (ad, RESCLASS); |
|
|
1130 | get_xdefaults (ad, ""); |
|
|
1131 | fclose (ad); |
|
|
1132 | } |
|
|
1133 | } |
|
|
1134 | # endif /* XAPPLOADDIR */ |
|
|
1135 | |
|
|
1136 | get_xdefaults (fd, ""); /* partial match */ |
|
|
1137 | if (fd != NULL) |
|
|
1138 | fclose (fd); |
|
|
1139 | # endif /* USE_XGETDEFAULT */ |
|
|
1140 | |
|
|
1141 | #endif /* NO_RESOURCES */ |
867 | #endif /* NO_RESOURCES */ |
1142 | } |
868 | } |
1143 | |
869 | |
1144 | /*}}} */ |
|
|
1145 | /*----------------------- end-of-file (C source) -----------------------*/ |
870 | /*----------------------- end-of-file (C source) -----------------------*/ |