1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 09:12:24 +00:00

pterm will now attempt to guess suitable names for any missing fonts

from the ones given; so it'll ask for a font twice as wide as your
base one if you don't specify a wide font, it'll ask for a bolded
version of your base font if you don't specify a bold font, and
similarly for a wide/bold font. Should solve Debian bug #187389; at
least it works for me.

[originally from svn r3175]
This commit is contained in:
Simon Tatham 2003-05-10 10:15:00 +00:00
parent a2b8d10cd3
commit 4b5ce3f46f

View File

@ -2388,9 +2388,63 @@ void uxsel_input_remove(int id) {
gdk_input_remove(id); gdk_input_remove(id);
} }
char *guess_derived_font_name(GdkFont *font, int bold, int wide)
{
XFontStruct *xfs = GDK_FONT_XFONT(font);
Display *disp = GDK_FONT_XDISPLAY(font);
Atom fontprop = XInternAtom(disp, "FONT", False);
unsigned long ret;
if (XGetFontProperty(xfs, fontprop, &ret)) {
char *name = XGetAtomName(disp, (Atom)ret);
if (name && name[0] == '-') {
char *strings[13];
char *dupname, *extrafree = NULL, *ret;
char *p, *q;
int nstr;
p = q = dupname = dupstr(name); /* skip initial minus */
nstr = 0;
while (*p && nstr < lenof(strings)) {
if (*p == '-') {
*p = '\0';
strings[nstr++] = p+1;
}
p++;
}
if (nstr < lenof(strings))
return NULL; /* XLFD was malformed */
if (bold)
strings[2] = "bold";
if (wide) {
/* 4 is `wideness', which obviously may have changed. */
/* 5 is additional style, which may be e.g. `ja' or `ko'. */
strings[4] = strings[5] = "*";
strings[11] = extrafree = dupprintf("%d", 2*atoi(strings[11]));
}
ret = dupcat("-", strings[ 0], "-", strings[ 1], "-", strings[ 2],
"-", strings[ 3], "-", strings[ 4], "-", strings[ 5],
"-", strings[ 6], "-", strings[ 7], "-", strings[ 8],
"-", strings[ 9], "-", strings[10], "-", strings[11],
"-", strings[12], NULL);
sfree(extrafree);
sfree(dupname);
return ret;
}
}
return NULL;
}
void setup_fonts_ucs(struct gui_data *inst) void setup_fonts_ucs(struct gui_data *inst)
{ {
int font_charset; int font_charset;
char *name;
int guessed;
if (inst->fonts[0]) if (inst->fonts[0])
gdk_font_unref(inst->fonts[0]); gdk_font_unref(inst->fonts[0]);
@ -2408,36 +2462,70 @@ void setup_fonts_ucs(struct gui_data *inst)
exit(1); exit(1);
} }
font_charset = set_font_info(inst, 0); font_charset = set_font_info(inst, 0);
if (inst->cfg.boldfont.name[0]) { if (inst->cfg.boldfont.name[0]) {
inst->fonts[1] = gdk_font_load(inst->cfg.boldfont.name); name = inst->cfg.boldfont.name;
if (!inst->fonts[1]) { guessed = FALSE;
fprintf(stderr, "%s: unable to load bold font \"%s\"\n", appname, } else {
inst->cfg.boldfont.name); name = guess_derived_font_name(inst->fonts[0], TRUE, FALSE);
exit(1); guessed = TRUE;
} }
inst->fonts[1] = name ? gdk_font_load(name) : NULL;
if (inst->fonts[1]) {
set_font_info(inst, 1); set_font_info(inst, 1);
} else } else if (!guessed) {
inst->fonts[1] = NULL; fprintf(stderr, "%s: unable to load bold font \"%s\"\n", appname,
inst->cfg.boldfont.name);
exit(1);
}
if (guessed)
sfree(name);
if (inst->cfg.widefont.name[0]) { if (inst->cfg.widefont.name[0]) {
inst->fonts[2] = gdk_font_load(inst->cfg.widefont.name); name = inst->cfg.widefont.name;
if (!inst->fonts[2]) { guessed = FALSE;
fprintf(stderr, "%s: unable to load wide font \"%s\"\n", appname, } else {
inst->cfg.widefont.name); name = guess_derived_font_name(inst->fonts[0], FALSE, TRUE);
exit(1); guessed = TRUE;
} }
inst->fonts[2] = name ? gdk_font_load(name) : NULL;
if (inst->fonts[2]) {
set_font_info(inst, 2); set_font_info(inst, 2);
} else } else if (!guessed) {
inst->fonts[2] = NULL; fprintf(stderr, "%s: unable to load wide font \"%s\"\n", appname,
inst->cfg.widefont.name);
exit(1);
}
if (guessed)
sfree(name);
if (inst->cfg.wideboldfont.name[0]) { if (inst->cfg.wideboldfont.name[0]) {
inst->fonts[3] = gdk_font_load(inst->cfg.wideboldfont.name); name = inst->cfg.wideboldfont.name;
if (!inst->fonts[3]) { guessed = FALSE;
fprintf(stderr, "%s: unable to load wide/bold font \"%s\"\n", } else {
appname, inst->cfg.wideboldfont.name); /*
exit(1); * Here we have some choices. We can widen the bold font,
} * bolden the wide font, or widen and bolden the standard
* font. Try them all, in that order!
*/
if (inst->cfg.widefont.name[0])
name = guess_derived_font_name(inst->fonts[2], TRUE, FALSE);
else if (inst->cfg.boldfont.name[0])
name = guess_derived_font_name(inst->fonts[1], FALSE, TRUE);
else
name = guess_derived_font_name(inst->fonts[0], TRUE, TRUE);
guessed = TRUE;
}
inst->fonts[3] = name ? gdk_font_load(name) : NULL;
if (inst->fonts[3]) {
set_font_info(inst, 3); set_font_info(inst, 3);
} else } else if (!guessed) {
inst->fonts[3] = NULL; fprintf(stderr, "%s: unable to load wide/bold font \"%s\"\n", appname,
inst->cfg.wideboldfont.name);
exit(1);
}
if (guessed)
sfree(name);
inst->font_width = gdk_char_width(inst->fonts[0], ' '); inst->font_width = gdk_char_width(inst->fonts[0], ' ');
inst->font_height = inst->fonts[0]->ascent + inst->fonts[0]->descent; inst->font_height = inst->fonts[0]->ascent + inst->fonts[0]->descent;