From: Jonathan Nieder Date: Thu, 8 Mar 2012 12:30:11 +0000 (-0600) Subject: gitk: Use symbolic font names "sans" and "monospace" when available X-Git-Tag: v1.7.10-rc3~7^2~3 X-Git-Url: https://git.lorimer.id.au/gitweb.git/diff_plain/5c9096f74756bdac219b9819060b581fc807e194 gitk: Use symbolic font names "sans" and "monospace" when available The following only concerns systems using X and the client-side font rendering framework from freedesktop.org. Windows and Mac OS X are not affected. Starting with version 8.5, Tk uses freetype and fontconfig by default to render fonts on platforms that support it. Gitk currently defaults to the font Helvetica for the interface and Courier for diffs, and both unfortunately look rather bad on screen in the default configuration on many Linux distros with anti-aliasing and poor hinting. It is better to default to "sans" and "monospace", which are mapped by fontconfig to some appropriate font of the sysadmin and user's choosing (typically Bitstream Vera Sans and Mono). The result looks more sensible and it makes gitk feel like a well-behaved software citizen since its fonts match other native apps. This patch does not change the appearance of gitk for users that have already run it, since gitk uses the remembered UI and diff font names from ~/.gitk. Requested-by: Michael Biebl Reviewed-by: Josh Triplett Acked-by: Mark Hills Signed-off-by: Jonathan Nieder Signed-off-by: Paul Mackerras --- diff --git a/gitk b/gitk index 5e3ad15883..36a48d54cd 100755 --- a/gitk +++ b/gitk @@ -11521,6 +11521,11 @@ if {[tk windowingsystem] eq "aqua"} { set mainfont {{Lucida Grande} 9} set textfont {Monaco 9} set uifont {{Lucida Grande} 9 bold} +} elseif {![catch {::tk::pkgconfig get fontsystem} xft] && $xft eq "xft"} { + # fontconfig! + set mainfont {sans 9} + set textfont {monospace 9} + set uifont {sans 9 bold} } else { set mainfont {Helvetica 9} set textfont {Courier 9}