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:
parent
a2b8d10cd3
commit
4b5ce3f46f
136
unix/pterm.c
136
unix/pterm.c
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user