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.9 by greg, Thu Apr 14 04:44:43 1994 UTC vs.
Revision 2.21 by greg, Fri Nov 19 21:56:48 2021 UTC

# Line 1 | Line 1
1 /* Copyright (c) 1992 Regents of the University of California */
2
1   #ifndef lint
2 < static char SCCSid[] = "$SunId$ LBL";
2 > static const char       RCSid[] = "$Id$";
3   #endif
6
4   /*
5   * Polygonal font handling routines
6   */
7  
8 < #include "standard.h"
8 > #include "copyright.h"
9  
10 + #include <stdlib.h>
11 +
12 + #include "paths.h"
13 + #include "rtio.h"
14 + #include "rterror.h"
15   #include "font.h"
16  
17   #define galloc(nv)      (GLYPH *)malloc(sizeof(GLYPH)+2*sizeof(GORD)*(nv))
18  
19  
20 < extern char  *fgetword(), *getlibpath();
20 > int     retainfonts = 0;                /* retain loaded fonts? */
21  
22   static FONT     *fontlist = NULL;       /* list of loaded fonts */
23  
24  
25   FONT *
26 < getfont(fname)                          /* return font fname */
27 < char  *fname;
26 > getfont(                        /* return font fname */
27 >        char  *fname
28 > )
29   {
27        char  buf[16];
30          FILE  *fp;
31 <        char  *pathname, *err;
31 >        char  *pathname, *err = NULL;
32          unsigned  wsum, hsum, ngly;
33 <        int  gn, ngv;
34 <        register int  gv;
33 <        register GLYPH  *g;
33 >        int  gn, ngv, gv;
34 >        GLYPH   *g;
35          GORD  *gp;
36 <        register FONT  *f;
36 >        FONT  *f;
37  
38          for (f = fontlist; f != NULL; f = f->next)
39 <                if (!strcmp(f->name, fname))
39 >                if (!strcmp(f->name, fname)) {
40 >                        f->nref++;
41                          return(f);
42 +                }
43                                                  /* load the font file */
44 <        if ((pathname = getpath(fname, getlibpath(), R_OK)) == NULL) {
44 >        if ((pathname = getpath(fname, getrlibpath(), R_OK)) == NULL) {
45                  sprintf(errmsg, "cannot find font file \"%s\"", fname);
46 <                error(USER, errmsg);
46 >                error(SYSTEM, errmsg);
47          }
48          f = (FONT *)calloc(1, sizeof(FONT));
49          if (f == NULL)
50                  goto memerr;
51          f->name = savestr(fname);
52 +        f->nref = 1;
53          if ((fp = fopen(pathname, "r")) == NULL) {
54                  sprintf(errmsg, "cannot open font file \"%s\"",
55                                  pathname);
56                  error(SYSTEM, errmsg);
57          }
58 <        wsum = hsum = ngly = 0;
59 <        while (fgetword(buf,sizeof(buf),fp) != NULL) {  /* get each glyph */
60 <                if (!isint(buf))
58 >        wsum = hsum = ngly = 0;                 /* get each glyph */
59 >        while ((ngv = fgetval(fp, 'i', (char *)&gn)) != EOF) {
60 >                if (ngv == 0)
61                          goto nonint;
58                gn = atoi(buf);
62                  if (gn < 1 || gn > 255) {
63                          err = "illegal";
64                          goto fonterr;
# Line 64 | Line 67 | char  *fname;
67                          err = "duplicate";
68                          goto fonterr;
69                  }
70 <                if (fgetword(buf,sizeof(buf),fp) == NULL || !isint(buf) ||
71 <                                (ngv = atoi(buf)) < 0 || ngv > 32000) {
70 >                if (fgetval(fp, 'i', (char *)&ngv) <= 0 ||
71 >                                ngv < 0 || ngv > 32000) {
72                          err = "bad # vertices for";
73                          goto fonterr;
74                  }
# Line 77 | Line 80 | char  *fname;
80                  ngv *= 2;
81                  gp = gvlist(g);
82                  while (ngv--) {
83 <                        if (fgetword(buf,sizeof(buf),fp) == NULL ||
84 <                                        !isint(buf) ||
82 <                                        (gv = atoi(buf)) < 0 || gv > 255) {
83 >                        if (fgetval(fp, 'i', (char *)&gv) <= 0 ||
84 >                                        gv < 0 || gv > 255) {
85                                  err = "bad vertex for";
86                                  goto fonterr;
87                          }
# Line 119 | Line 121 | fonterr:
121          error(USER, errmsg);
122   memerr:
123          error(SYSTEM, "out of memory in fontglyph");
124 +        return NULL; /* pro forma return */
125   }
126  
127  
128 < freefont(fname)                 /* free a font (free all if fname==NULL) */
129 < char  *fname;
128 > void
129 > freefont(                       /* release a font (free all if NULL) */
130 >        FONT *fnt
131 > )
132   {
133          FONT  head;
134 <        register FONT  *fl, *f;
135 <        register int  i;
136 <
134 >        FONT  *fl, *f;
135 >        int  i;
136 >                                        /* check reference count */
137 >        if (fnt != NULL && ((fnt->nref-- > 1) | retainfonts))
138 >                return;
139          head.next = fontlist;
140          fl = &head;
141          while ((f = fl->next) != NULL)
142 <                if (fname == NULL || !strcmp(fname, f->name)) {
142 >                if ((fnt == NULL) | (fnt == f)) {
143                          fl->next = f->next;
144                          for (i = 0; i < 256; i++)
145                                  if (f->fg[i] != NULL)
146 <                                        free((char *)f->fg[i]);
146 >                                        free((void *)f->fg[i]);
147                          freestr(f->name);
148 <                        free((char *)f);
148 >                        free((void *)f);
149                  } else
150                          fl = f;
151          fontlist = head.next;
# Line 146 | Line 153 | char  *fname;
153  
154  
155   int
156 < uniftext(sp, tp, f)                     /* uniformly space text line */
157 < register short  *sp;            /* returned character spacing */
158 < register char  *tp;             /* text line */
159 < register FONT  *f;              /* font */
156 > uniftext(                       /* uniformly space text line */
157 >        short   *sp,            /* returned character spacing */
158 >        char  *tp,              /* text line */
159 >        FONT  *f                /* font */
160 > )
161   {
162          int  linelen;
163  
# Line 158 | Line 166 | register FONT  *f;             /* font */
166                  if (f->fg[*tp++&0xff] == NULL)
167                          *sp++ = 0;
168                  else
169 <                        linelen += *sp++ = 256;
169 >                        linelen += *sp++ = 255;
170          return(linelen);
171   }
172  
173  
174   int
175 < squeeztext(sp, tp, f, cis)              /* squeeze text line */
176 < short  *sp;                     /* returned character spacing */
177 < char  *tp;                      /* text line */
178 < FONT  *f;                       /* font */
179 < int  cis;                       /* intercharacter spacing */
175 > squeeztext(             /* squeeze text line */
176 >        short  *sp,                     /* returned character spacing */
177 >        char  *tp,                      /* text line */
178 >        FONT  *f,                       /* font */
179 >        int  cis                        /* intercharacter spacing */
180 > )
181   {
182          int  linelen;
183 <        register GLYPH  *gp;
183 >        GLYPH   *gp;
184  
185          linelen = 0;
186          gp = NULL;
# Line 199 | Line 208 | int  cis;                      /* intercharacter spacing */
208  
209  
210   int
211 < proptext(sp, tp, f, cis, nsi)           /* space line proportionally */
212 < short  *sp;                     /* returned character spacing */
213 < char  *tp;                      /* text line */
214 < FONT  *f;                       /* font */
215 < int  cis;                       /* target intercharacter spacing */
216 < int  nsi;                       /* minimum number of spaces for indent */
211 > proptext(               /* space line proportionally */
212 >        short  *sp,                     /* returned character spacing */
213 >        char  *tp,                      /* text line */
214 >        FONT  *f,                       /* font */
215 >        int  cis,                       /* target intercharacter spacing */
216 >        int  nsi                        /* minimum number of spaces for indent */
217 > )
218   {
219 <        register char  *end, *tab;
219 >        char  *end, *tab = NULL;
220          GLYPH  *gp;
221          short  *nsp;
222          int  alen, len, width;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines