ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/xdefaults.C
(Generate patch)

Comparing rxvt-unicode/src/xdefaults.C (file contents):
Revision 1.190 by sf-exg, Tue Oct 13 08:10:43 2015 UTC vs.
Revision 1.193 by root, Tue Sep 17 20:38:14 2019 UTC

113 STRG (Rs_scrollBar_thickness, "thickness", "sbt", "number", "scrollbar thickness/width in pixels"), 113 STRG (Rs_scrollBar_thickness, "thickness", "sbt", "number", "scrollbar thickness/width in pixels"),
114 BOOL (Rs_scrollTtyOutput, "scrollTtyOutput", NULL, Opt_scrollTtyOutput, 0, NULL), 114 BOOL (Rs_scrollTtyOutput, "scrollTtyOutput", NULL, Opt_scrollTtyOutput, 0, NULL),
115 BOOL (Rs_scrollTtyOutput, NULL, "si", Opt_scrollTtyOutput, Optflag_Reverse, "scroll-on-tty-output inhibit"), 115 BOOL (Rs_scrollTtyOutput, NULL, "si", Opt_scrollTtyOutput, Optflag_Reverse, "scroll-on-tty-output inhibit"),
116 BOOL (Rs_scrollTtyKeypress, "scrollTtyKeypress", "sk", Opt_scrollTtyKeypress, 0, "scroll-on-keypress"), 116 BOOL (Rs_scrollTtyKeypress, "scrollTtyKeypress", "sk", Opt_scrollTtyKeypress, 0, "scroll-on-keypress"),
117 BOOL (Rs_scrollWithBuffer, "scrollWithBuffer", "sw", Opt_scrollWithBuffer, 0, "scroll-with-buffer"), 117 BOOL (Rs_scrollWithBuffer, "scrollWithBuffer", "sw", Opt_scrollWithBuffer, 0, "scroll-with-buffer"),
118#if BG_IMAGE_FROM_ROOT
119 BOOL (Rs_transparent, "inheritPixmap", "ip", Opt_transparent, 0, "inherit parent pixmap"),
120 BOOL (Rs_transparent, "transparent", "tr", Opt_transparent, 0, "inherit parent pixmap"),
121 STRG (Rs_color + Color_tint, "tintColor", "tint", "color", "tint color"),
122 STRG (Rs_shade, "shading", "sh", "number", "shade background by number %."),
123 STRG (Rs_blurradius, "blurRadius", "blr", "HxV", "gaussian blur radii to apply to the root background"),
124#endif
125#if OFF_FOCUS_FADING 118#if OFF_FOCUS_FADING
126 STRG (Rs_fade, "fading", "fade", "number", "fade colors by number % when losing focus"), 119 STRG (Rs_fade, "fading", "fade", "number", "fade colors by number % when losing focus"),
127 STRG (Rs_color + Color_fade, "fadeColor", "fadecolor", "color", "target color for off-focus fading"), 120 STRG (Rs_color + Color_fade, "fadeColor", "fadecolor", "color", "target color for off-focus fading"),
128#endif 121#endif
129 BOOL (Rs_utmpInhibit, "utmpInhibit", "ut", Opt_utmpInhibit, 0, "utmp inhibit"), 122 BOOL (Rs_utmpInhibit, "utmpInhibit", "ut", Opt_utmpInhibit, 0, "utmp inhibit"),
194 RSTRG (Rs_color + Color_cursor2, "cursorColor2", "color"), 187 RSTRG (Rs_color + Color_cursor2, "cursorColor2", "color"),
195#endif /* NO_CURSORCOLOR */ 188#endif /* NO_CURSORCOLOR */
196 STRG (Rs_color + Color_pointer_fg, "pointerColor", "pr", "color", "pointer color"), 189 STRG (Rs_color + Color_pointer_fg, "pointerColor", "pr", "color", "pointer color"),
197 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"),
198 STRG (Rs_color + Color_border, "borderColor", "bd", "color", "border color"), 191 STRG (Rs_color + Color_border, "borderColor", "bd", "color", "border color"),
199#if BG_IMAGE_FROM_FILE
200 RSTRG (Rs_path, "path", "search path"),
201 STRG (Rs_backgroundPixmap, "backgroundPixmap", "pixmap", "file[;geom]", "background pixmap"),
202#endif
203#if ENABLE_EWMH 192#if ENABLE_EWMH
204 STRG (Rs_iconfile, "iconFile", "icon", "file", "path to application icon image"), 193 STRG (Rs_iconfile, "iconFile", "icon", "file", "path to application icon image"),
205#endif 194#endif
206#ifdef HAVE_XMU 195#ifdef HAVE_XMU
207 RSTRG (Rs_pointerShape, "pointerShape", "string"), 196 RSTRG (Rs_pointerShape, "pointerShape", "string"),
637rxvt_define_key (rxvt_term *term, const char *k, const char *v) 626rxvt_define_key (rxvt_term *term, const char *k, const char *v)
638{ 627{
639 term->bind_action (k, v); 628 term->bind_action (k, v);
640} 629}
641 630
631struct rxvt_enumerate_closure
632{
633 rxvt_term *term;
634 void (*cb)(rxvt_term *, const char *, const char *);
635 int specific; // iterate over only a specific subhierarchy
636};
637
642/* 638/*
643 * Define key from XrmEnumerateDatabase. 639 * Define key from XrmEnumerateDatabase.
644 * quarks will be something like 640 * quarks will be something like
645 * "rxvt" "keysym" "0xFF01" 641 * "rxvt" "keysym" "0xFF01"
646 * value will be a string 642 * value will be a string
647 */ 643 */
648static int 644static int
649rxvt_keysym_enumerate_helper ( 645rxvt_enumerate_helper (
650 XrmDatabase *database ecb_unused, 646 XrmDatabase *database ecb_unused,
651 XrmBindingList bindings ecb_unused, 647 XrmBindingList bindings ecb_unused,
652 XrmQuarkList quarks, 648 XrmQuarkList quarks,
653 XrmRepresentation *type ecb_unused, 649 XrmRepresentation *type ecb_unused,
654 XrmValue *value, 650 XrmValue *value,
655 XPointer closure 651 XPointer closure
656) 652)
657{ 653{
658 int last; 654 const rxvt_enumerate_closure *data = (const rxvt_enumerate_closure *)closure;
659 655
660 for (last = 0; quarks[last] != NULLQUARK; last++) /* look for last quark in list */ 656 if (*quarks == NULLQUARK) return False;
657
658 // if the quark list starts with a tighly bound quark, we skip it,
659 // as it is the exactly matched the prefix. Otherwise, it matched because
660 // it started with "*", in which case we assuime the prefix is part
661 // of the "*".
662 if (*bindings == XrmBindTightly)
661 ; 663 {
664 ++quarks, ++bindings; // skip if this is a fixed prefix, rather than a *-match
665 if (*quarks == NULLQUARK) return False;
666 }
662 667
663 rxvt_term *term = (rxvt_term *)(((void **)closure)[0]); 668 // specific, a bit misleadingly named, is used when a specific "subclass"
664 void (*cb)(rxvt_term *, const char *, const char *) 669 // is iterated over, e.g. "keysym", and is used to skip one more
665 = (void (*)(rxvt_term *, const char *, const char *)) 670 // component, as well as all generic prefixes
666 (((void **)closure)[1]); 671 // this is a bit of a hack, ideally, keysym (the only user) should use its
672 // own iteration function, but this ought to be less bloated
673 if (data->specific)
674 {
675 if (*bindings != XrmBindTightly)
676 return False;
667 677
668 cb (term, XrmQuarkToString (quarks[last - 1]), (char *)value->addr); 678 ++quarks, ++bindings; // skip if this is a fixed prefix, rather than a *-match
679 if (*quarks == NULLQUARK) return False;
680 }
681
682 char *pattern;
683 if (quarks[1] == NULLQUARK)
684 pattern = XrmQuarkToString (quarks[0]); // single component, fats path
685 else
686 {
687 // multiple components, slow path - should be rare, to don't optimize for speed
688 int size = 0;
689
690 for (int i = 0; quarks[i] != NULLQUARK; ++i)
691 size += strlen (XrmQuarkToString (quarks[i])) + 1;
692
693 pattern = rxvt_temp_buf<char> (size + 1);
694
695 // now print all components
696 {
697 char *cur = pattern;
698
699 for (int i = 0; quarks[i] != NULLQUARK; ++i)
700 cur += sprintf (cur, ".%s", XrmQuarkToString (quarks[i]));
701 }
702
703 ++pattern; // skip initial dot
704 }
705
706 data->cb (data->term, pattern, (char *)value->addr);
669 707
670 return False; 708 return False;
671} 709}
672 710
673/* 711/*
859 } 897 }
860#endif /* NO_RESOURCES */ 898#endif /* NO_RESOURCES */
861} 899}
862 900
863void 901void
864rxvt_term::enumerate_keysym_resources (void (*cb)(rxvt_term *, const char *, const char *)) 902rxvt_term::enumerate_resources (void (*cb)(rxvt_term *, const char *, const char *), const char *name_p, const char *class_p)
865{ 903{
866 /* 904 /*
867 * [R5 or later]: enumerate the resource database 905 * [R5 or later]: enumerate the resource database
868 */ 906 */
907 assert (!name_p == !class_p); // both must be specified, or missing
908
869#ifdef KEYSYM_RESOURCE 909#ifdef KEYSYM_RESOURCE
870 void *closure[2] = { 910 rxvt_enumerate_closure closure = { this, cb, name_p ? 1 : 0 };
871 (void *)this,
872 (void *)cb,
873 };
874 911
875 XrmDatabase database = XrmGetDatabase (dpy); 912 XrmDatabase database = XrmGetDatabase (dpy);
876 XrmName name_prefix[3]; 913 XrmName name_prefix[3];
877 XrmClass class_prefix[3]; 914 XrmClass class_prefix[3];
878 915
879 name_prefix[1] = XrmStringToName ("keysym"); 916 name_prefix[1] = name_p ? XrmStringToName (name_p) : NULLQUARK;
880 name_prefix[2] = NULLQUARK; 917 name_prefix[2] = NULLQUARK;
881 class_prefix[1] = XrmStringToName ("Keysym"); 918 class_prefix[1] = class_p ? XrmStringToName (class_p) : NULLQUARK;
882 class_prefix[2] = NULLQUARK; 919 class_prefix[2] = NULLQUARK;
883 920
884# ifdef RESFALLBACK 921# ifdef RESFALLBACK
885 name_prefix[0] = class_prefix[0] = XrmStringToName (RESFALLBACK); 922 name_prefix[0] = class_prefix[0] = XrmStringToName (RESFALLBACK);
886 /* XXX: Need to check sizeof (rxvt_t) == sizeof (XPointer) */
887 XrmEnumerateDatabase (database, name_prefix, class_prefix, 923 XrmEnumerateDatabase (database, name_prefix, class_prefix,
888 XrmEnumOneLevel, rxvt_keysym_enumerate_helper, (XPointer)closure); 924 XrmEnumAllLevels, rxvt_enumerate_helper, (XPointer)&closure);
889# endif 925# endif
890 926
891 name_prefix[0] = class_prefix[0] = XrmStringToName (RESCLASS); 927 name_prefix[0] = class_prefix[0] = XrmStringToName (RESCLASS);
892 XrmEnumerateDatabase (database, name_prefix, class_prefix, 928 XrmEnumerateDatabase (database, name_prefix, class_prefix,
893 XrmEnumOneLevel, rxvt_keysym_enumerate_helper, (XPointer)closure); 929 XrmEnumAllLevels, rxvt_enumerate_helper, (XPointer)&closure);
894 930
895 name_prefix[0] = class_prefix[0] = XrmStringToName (rs[Rs_name]); 931 name_prefix[0] = class_prefix[0] = XrmStringToName (rs[Rs_name]);
896 XrmEnumerateDatabase (database, name_prefix, class_prefix, 932 XrmEnumerateDatabase (database, name_prefix, class_prefix,
897 XrmEnumOneLevel, rxvt_keysym_enumerate_helper, (XPointer)closure); 933 XrmEnumAllLevels, rxvt_enumerate_helper, (XPointer)&closure);
898#endif 934#endif
899} 935}
900 936
901void 937void
902rxvt_term::extract_keysym_resources () 938rxvt_term::extract_keysym_resources ()

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines