1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-27 02:02:26 +00:00

GTK: cherry-pick font defaults and fallbacks from main.

This is a combined cherry-pick of three consecutive commits from main:

b088d77d58 GTK: hard-code some last-ditch fallback fonts.
7f4cccde2a GTK: fixes to the previous font fallback patch.
6155365076 GTK: switch the default to client-side fonts.

The combined effect is that now PuTTY's built-in default font is
client-side rather than server-side (advantaging Wayland and
disadvantaging legacy GTK1 builds, which seems like a sensible
tradeoff these days), and also, if the configured main font can't be
found, we'll try falling back to either the client- or server-side
default (whichever is available) before giving up completely and
whinging on standard error.
This commit is contained in:
Simon Tatham 2025-01-13 20:47:01 +00:00
parent f58ddf26fe
commit 293be04298
2 changed files with 65 additions and 22 deletions

View File

@ -394,13 +394,23 @@ void setup_fd_socket(Socket *s, int infd, int outfd, int inerrfd);
void fd_socket_set_psb_prefix(Socket *s, const char *prefix);
/*
* Default font setting, which can vary depending on NOT_X_WINDOWS.
* Default font settings. We have a default font for each of
* client-side and server-side, so that we can use one of each as a
* fallback, and we also have a single overall default which goes into
* Conf to populate the initial state of Default Settings.
*
* In the past, this default varied with NOT_X_WINDOWS. But these days
* non-X11 environments like Wayland with only client-side fonts are
* common, and even an X11-capable _build_ of PuTTY is quite likely to
* find out at run time that X11 and its bitmap fonts aren't
* available. Also, a fixed-size bitmap font doesn't play nicely with
* high-DPI displays. And the GTK1 build of PuTTY, which can _only_
* handle server-side fonts, is legacy. So the default font is
* unconditionally the client-side one.
*/
#ifdef NOT_X_WINDOWS
#define DEFAULT_GTK_FONT "client:Monospace 12"
#else
#define DEFAULT_GTK_FONT "server:fixed"
#endif
#define DEFAULT_GTK_CLIENT_FONT "client:Monospace 12"
#define DEFAULT_GTK_SERVER_FONT "server:fixed"
#define DEFAULT_GTK_FONT DEFAULT_GTK_CLIENT_FONT
/*
* pty.c.

View File

@ -4368,22 +4368,22 @@ static bool gtk_seat_get_windowid(Seat *seat, long *id)
}
#endif
char *setup_fonts_ucs(GtkFrontend *inst)
char *setup_fonts_ucs(GtkFrontend *inst, Conf *conf)
{
bool shadowbold = conf_get_bool(inst->conf, CONF_shadowbold);
int shadowboldoffset = conf_get_int(inst->conf, CONF_shadowboldoffset);
bool shadowbold = conf_get_bool(conf, CONF_shadowbold);
int shadowboldoffset = conf_get_int(conf, CONF_shadowboldoffset);
FontSpec *fs;
unifont *fonts[4];
int i;
fs = conf_get_fontspec(inst->conf, CONF_font);
fs = conf_get_fontspec(conf, CONF_font);
fonts[0] = multifont_create(inst->area, fs->name, false, false,
shadowboldoffset, shadowbold);
if (!fonts[0]) {
return dupprintf("unable to load font \"%s\"", fs->name);
}
fs = conf_get_fontspec(inst->conf, CONF_boldfont);
fs = conf_get_fontspec(conf, CONF_boldfont);
if (shadowbold || !fs->name[0]) {
fonts[1] = NULL;
} else {
@ -4396,7 +4396,7 @@ char *setup_fonts_ucs(GtkFrontend *inst)
}
}
fs = conf_get_fontspec(inst->conf, CONF_widefont);
fs = conf_get_fontspec(conf, CONF_widefont);
if (fs->name[0]) {
fonts[2] = multifont_create(inst->area, fs->name, true, false,
shadowboldoffset, shadowbold);
@ -4410,7 +4410,7 @@ char *setup_fonts_ucs(GtkFrontend *inst)
fonts[2] = NULL;
}
fs = conf_get_fontspec(inst->conf, CONF_wideboldfont);
fs = conf_get_fontspec(conf, CONF_wideboldfont);
if (shadowbold || !fs->name[0]) {
fonts[3] = NULL;
} else {
@ -4861,7 +4861,7 @@ static void after_change_settings_dialog(void *vctx, int retval)
conf_get_bool(newconf, CONF_shadowbold) ||
conf_get_int(oldconf, CONF_shadowboldoffset) !=
conf_get_int(newconf, CONF_shadowboldoffset)) {
char *errmsg = setup_fonts_ucs(inst);
char *errmsg = setup_fonts_ucs(inst, inst->conf);
if (errmsg) {
char *msgboxtext =
dupprintf("Could not change fonts in terminal window: %s\n",
@ -4950,7 +4950,7 @@ static void change_font_size(GtkFrontend *inst, int increment)
}
}
errmsg = setup_fonts_ucs(inst);
errmsg = setup_fonts_ucs(inst, inst->conf);
if (errmsg)
goto cleanup;
@ -5350,15 +5350,48 @@ void new_session_window(Conf *conf, const char *geometry_string)
inst->area = gtk_drawing_area_new();
gtk_widget_set_name(GTK_WIDGET(inst->area), "drawing-area");
/*
* Try to create the fonts for use in the window. If this fails,
* we'll try again with some fallback settings, and only abort
* completely if we can't find any fonts at all.
*/
{
char *errmsg = setup_fonts_ucs(inst);
if (errmsg) {
window_setup_error(errmsg);
sfree(errmsg);
gtk_widget_destroy(inst->area);
sfree(inst);
return;
char *errmsg_main = setup_fonts_ucs(inst, inst->conf);
if (!errmsg_main)
goto fonts_ok;
static const char *const fallbacks[] = {
DEFAULT_GTK_CLIENT_FONT,
DEFAULT_GTK_SERVER_FONT,
};
for (size_t i = 0; i < lenof(fallbacks); i++) {
Conf *fallback_conf = conf_new();
do_defaults(NULL, fallback_conf);
FontSpec *fs = fontspec_new(fallbacks[i]);
conf_set_fontspec(fallback_conf, CONF_font, fs);
fontspec_free(fs);
char *errmsg_fallback = setup_fonts_ucs(inst, fallback_conf);
conf_free(fallback_conf);
if (!errmsg_fallback) {
fprintf(stderr, "%s; falling back to default font '%s'\n",
errmsg_main, fallbacks[i]);
sfree(errmsg_main);
goto fonts_ok;
}
sfree(errmsg_fallback);
}
window_setup_error(errmsg_main);
sfree(errmsg_main);
gtk_widget_destroy(inst->area);
sfree(inst);
return;
fonts_ok:;
}
#if GTK_CHECK_VERSION(2,0,0)