fontsrv: always compute new height and ascent for the font file

This commit is contained in:
Xiao-Yong Jin 2020-07-16 11:50:26 -05:00 committed by Dan Cross
parent 85bfd19a7b
commit 1fcdefc585

View file

@ -287,6 +287,7 @@ xread(Req *r)
Fmt fmt; Fmt fmt;
XFont *f; XFont *f;
char *data; char *data;
char *buf;
Memsubfont *sf; Memsubfont *sf;
Memimage *m; Memimage *m;
@ -309,20 +310,24 @@ xread(Req *r)
readstr(r, "font missing\n"); readstr(r, "font missing\n");
break; break;
} }
height = 0;
ascent = 0;
if(f->unit > 0) {
height = f->height * (int)QSIZE(path)/f->unit + 0.99999999;
ascent = height - (int)(-f->originy * (int)QSIZE(path)/f->unit + 0.99999999);
}
if(f->loadheight != nil)
f->loadheight(f, QSIZE(path), &height, &ascent);
fmtprint(&fmt, "%11d %11d\n", height, ascent);
if(f->fonttext == nil) { if(f->fonttext == nil) {
height = 0;
ascent = 0;
if(f->unit > 0) {
height = f->height * (int)QSIZE(path)/f->unit + 0.99999999;
ascent = height - (int)(-f->originy * (int)QSIZE(path)/f->unit + 0.99999999);
}
if(f->loadheight != nil)
f->loadheight(f, QSIZE(path), &height, &ascent);
fmtprint(&fmt, "%11d %11d\n", height, ascent);
for(i=0; i<f->nfile; i++) for(i=0; i<f->nfile; i++)
fmtprint(&fmt, "0x%06x 0x%06x x%06x.bit\n", f->file[i]*SubfontSize, ((f->file[i]+1)*SubfontSize) - 1, f->file[i]*SubfontSize); fmtprint(&fmt, "0x%06x 0x%06x x%06x.bit\n", f->file[i]*SubfontSize, ((f->file[i]+1)*SubfontSize) - 1, f->file[i]*SubfontSize);
f->fonttext = fmtstrflush(&fmt); f->fonttext = fmtstrflush(&fmt);
f->nfonttext = strlen(f->fonttext); f->nfonttext = strlen(f->fonttext);
} else {
buf = fmtstrflush(&fmt);
strncpy(f->fonttext, buf, strlen(buf)); // Do not copy the null byte.
free(buf);
} }
readbuf(r, f->fonttext, f->nfonttext); readbuf(r, f->fonttext, f->nfonttext);
break; break;