--- ray/src/common/font.c 1992/06/24 17:52:58 2.3 +++ ray/src/common/font.c 1993/05/14 11:30:17 2.7 @@ -17,6 +17,8 @@ static char SCCSid[] = "$SunId$ LBL"; extern char *libpath; /* list of library directories */ +extern char *fgetword(); + static FONT *fontlist = NULL; /* list of loaded fonts */ @@ -30,7 +32,7 @@ char *fname; unsigned wsum, hsum, ngly; int gn, ngv; register int gv; - register GLYPH *g; + register GLYPH *g; GORD *gp; register FONT *f; @@ -122,9 +124,32 @@ memerr: } +freefont(fname) /* free a font (free all if fname==NULL) */ +char *fname; +{ + FONT head; + register FONT *fl, *f; + register int i; + + head.next = fontlist; + fl = &head; + while ((f = fl->next) != NULL) + if (fname == NULL || !strcmp(fname, f->name)) { + fl->next = f->next; + for (i = 0; i < 256; i++) + if (f->fg[i] != NULL) + free((char *)f->fg[i]); + freestr(f->name); + free((char *)f); + } else + fl = f; + fontlist = head.next; +} + + int uniftext(sp, tp, f) /* uniformly space text line */ -register short *sp; /* returned character spacing */ +register short *sp; /* returned character spacing */ register char *tp; /* text line */ register FONT *f; /* font */ { @@ -148,7 +173,7 @@ FONT *f; /* font */ int cis; /* intercharacter spacing */ { int linelen; - register GLYPH *gp; + register GLYPH *gp; gp = NULL; while (*tp && (gp = f->fg[*tp++&0xff]) == NULL) @@ -189,9 +214,9 @@ int nsi; /* minimum number of spaces for indent */ /* start by squeezing it */ squeeztext(sp, tp, f, cis); /* now, realign spacing */ - len = 0; - width = alen = *sp++; + width = *sp++; while (*tp) { + len = alen = 0; nsp = sp; for (end = tp; *end; end = tab) { tab = end + 1; @@ -204,7 +229,7 @@ int nsi; /* minimum number of spaces for indent */ } len += tab - end; } - if (tab - end > nsi) + if (nsi && tab - end > nsi) break; } len *= f->mwidth + cis; /* compute target length */ @@ -215,8 +240,6 @@ int nsi; /* minimum number of spaces for indent */ *sp++ += alen; len -= alen; } - len = 0; - alen = 0; tp = tab; } return(width);