ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/common/font.c
(Generate patch)

Comparing ray/src/common/font.c (file contents):
Revision 2.7 by greg, Fri May 14 11:30:17 1993 UTC vs.
Revision 2.11 by greg, Fri Jun 30 16:06:40 1995 UTC

# Line 15 | Line 15 | static char SCCSid[] = "$SunId$ LBL";
15   #define galloc(nv)      (GLYPH *)malloc(sizeof(GLYPH)+2*sizeof(GORD)*(nv))
16  
17  
18 < extern char  *libpath;                  /* list of library directories */
18 > extern char  *getlibpath();
19  
20 extern char  *fgetword();
21
20   static FONT     *fontlist = NULL;       /* list of loaded fonts */
21  
22  
# Line 26 | Line 24 | FONT *
24   getfont(fname)                          /* return font fname */
25   char  *fname;
26   {
29        char  buf[16];
27          FILE  *fp;
28          char  *pathname, *err;
29          unsigned  wsum, hsum, ngly;
30 <        int  gn, ngv;
34 <        register int  gv;
30 >        int  gn, ngv, gv;
31          register GLYPH  *g;
32          GORD  *gp;
33          register FONT  *f;
# Line 40 | Line 36 | char  *fname;
36                  if (!strcmp(f->name, fname))
37                          return(f);
38                                                  /* load the font file */
39 <        if ((pathname = getpath(fname, libpath, R_OK)) == NULL) {
39 >        if ((pathname = getpath(fname, getlibpath(), R_OK)) == NULL) {
40                  sprintf(errmsg, "cannot find font file \"%s\"", fname);
41                  error(USER, errmsg);
42          }
# Line 54 | Line 50 | char  *fname;
50                  error(SYSTEM, errmsg);
51          }
52          wsum = hsum = ngly = 0;
53 <        while (fgetword(buf,sizeof(buf),fp) != NULL) {  /* get each glyph */
54 <                if (!isint(buf))
53 >        while ((ngv = fgetval(fp, 'i', &gn)) != EOF) {  /* get each glyph */
54 >                if (ngv == 0)
55                          goto nonint;
60                gn = atoi(buf);
56                  if (gn < 1 || gn > 255) {
57                          err = "illegal";
58                          goto fonterr;
# Line 66 | Line 61 | char  *fname;
61                          err = "duplicate";
62                          goto fonterr;
63                  }
64 <                if (fgetword(buf,sizeof(buf),fp) == NULL || !isint(buf) ||
70 <                                (ngv = atoi(buf)) < 0 || ngv > 32000) {
64 >                if (fgetval(fp, 'i', &ngv) <= 0 || ngv < 0 || ngv > 32000) {
65                          err = "bad # vertices for";
66                          goto fonterr;
67                  }
# Line 79 | Line 73 | char  *fname;
73                  ngv *= 2;
74                  gp = gvlist(g);
75                  while (ngv--) {
76 <                        if (fgetword(buf,sizeof(buf),fp) == NULL ||
83 <                                        !isint(buf) ||
84 <                                        (gv = atoi(buf)) < 0 || gv > 255) {
76 >                        if (fgetval(fp, 'i', &gv) <= 0 || gv < 0 || gv > 255) {
77                                  err = "bad vertex for";
78                                  goto fonterr;
79                          }
# Line 160 | Line 152 | register FONT  *f;             /* font */
152                  if (f->fg[*tp++&0xff] == NULL)
153                          *sp++ = 0;
154                  else
155 <                        linelen += *sp++ = 256;
155 >                        linelen += *sp++ = 255;
156          return(linelen);
157   }
158  
# Line 175 | Line 167 | int  cis;                      /* intercharacter spacing */
167          int  linelen;
168          register GLYPH  *gp;
169  
170 +        linelen = 0;
171          gp = NULL;
172          while (*tp && (gp = f->fg[*tp++&0xff]) == NULL)
173                  *sp++ = 0;
174          cis /= 2;
175 <        linelen = *sp = cis;
175 >        *sp = cis;
176          while (gp != NULL) {
177                  if (gp->nverts) {               /* regular character */
178                          linelen += *sp++ += cis - gp->left;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines