# HG changeset patch # User Stefan Monnier # Date 1213128114 0 # Node ID 82a0e68857159db0e3e42ec06673873440ba9753 # Parent a486132d892c559256ef5259365b7cbbba7ab9f9 * xterm.c (x_underline_minimum_display_offset): New var. (x_draw_glyph_string): Use it. (syms_of_xterm): Declare it. * cus-start.el (x-underline-minimum-display-offset): Give it a type. diff -r a486132d892c -r 82a0e6885715 lisp/ChangeLog --- a/lisp/ChangeLog Tue Jun 10 20:01:06 2008 +0000 +++ b/lisp/ChangeLog Tue Jun 10 20:01:54 2008 +0000 @@ -1,3 +1,7 @@ +2008-06-10 David De La Harpe Golden (tiny change) + + * cus-start.el (x-underline-minimum-display-offset): Give it a type. + 2008-06-10 Chong Yidong * mouse.el (mouse-select-font): New function. diff -r a486132d892c -r 82a0e6885715 lisp/cus-start.el --- a/lisp/cus-start.el Tue Jun 10 20:01:06 2008 +0000 +++ b/lisp/cus-start.el Tue Jun 10 20:01:54 2008 +0000 @@ -348,6 +348,7 @@ ;; xterm.c (x-use-underline-position-properties display boolean "22.1") (x-underline-at-descent-line display boolean "22.1") + (x-underline-minimum-display-offset display integer "23.1") (x-stretch-cursor display boolean "21.1"))) this symbol group type standard version native-p ;; This function turns a value diff -r a486132d892c -r 82a0e6885715 src/ChangeLog --- a/src/ChangeLog Tue Jun 10 20:01:06 2008 +0000 +++ b/src/ChangeLog Tue Jun 10 20:01:54 2008 +0000 @@ -1,3 +1,9 @@ +2008-06-10 David De La Harpe Golden (tiny change) + + * xterm.c (x_underline_minimum_display_offset): New var. + (x_draw_glyph_string): Use it. + (syms_of_xterm): Declare it. + 2008-06-10 Chong Yidong * font.c (font_parse_fcname): Accept GTK-style font names too. diff -r a486132d892c -r 82a0e6885715 src/xterm.c --- a/src/xterm.c Tue Jun 10 20:01:06 2008 +0000 +++ b/src/xterm.c Tue Jun 10 20:01:54 2008 +0000 @@ -183,6 +183,12 @@ int x_underline_at_descent_line; +/* Require underline to be at least this many screen pixels below baseline + This to avoid underline "merging" with the base of letters at small + font sizes, particularly when x_use_underline_position_properties is on. */ + +int x_underline_minimum_display_offset; + /* This is a chain of structures for all the X displays currently in use. */ @@ -2744,6 +2750,8 @@ else if (s->font) position = (s->font->descent + 1) / 2; } + if (x_underline_minimum_display_offset) + position = max (position, eabs (x_underline_minimum_display_offset)); } /* Check the sanity of thickness and position. We should avoid drawing underline out of the current line area. */ @@ -10781,7 +10789,9 @@ doc: /* *Non-nil means make use of UNDERLINE_POSITION font properties. A value of nil means ignore them. If you encounter fonts with bogus UNDERLINE_POSITION font properties, for example 7x13 on XFree prior -to 4.1, set this to nil. */); +to 4.1, set this to nil. Variable `x-underline-minimum-display-offset' may +be used to override the font's UNDERLINE_POSITION for small font display +sizes. */); x_use_underline_position_properties = 1; DEFVAR_BOOL ("x-underline-at-descent-line", @@ -10792,6 +10802,16 @@ baseline level. The default value is nil. */); x_underline_at_descent_line = 0; + DEFVAR_INT ("x-underline-minimum-display-offset", + &x_underline_minimum_display_offset, + doc: /* *When > 0, underline is drawn at least that many screen pixels below baseline. +This can improve legibility of underlined text at small font sizes, +particularly when using variable `x-use-underline-position-properties' +with fonts that specify an UNDERLINE_POSITION relatively close to the +baseline. The default value is 0. */); + x_underline_minimum_display_offset = 0; + + DEFVAR_BOOL ("x-mouse-click-focus-ignore-position", &x_mouse_click_focus_ignore_position, doc: /* Non-nil means that a mouse click to focus a frame does not move point.