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.5 by greg, Mon Sep 21 12:02:03 1992 UTC vs.
Revision 2.12 by greg, Sat Feb 22 02:07:22 2003 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 + /* ====================================================================
9 + * The Radiance Software License, Version 1.0
10 + *
11 + * Copyright (c) 1990 - 2002 The Regents of the University of California,
12 + * through Lawrence Berkeley National Laboratory.   All rights reserved.
13 + *
14 + * Redistribution and use in source and binary forms, with or without
15 + * modification, are permitted provided that the following conditions
16 + * are met:
17 + *
18 + * 1. Redistributions of source code must retain the above copyright
19 + *         notice, this list of conditions and the following disclaimer.
20 + *
21 + * 2. Redistributions in binary form must reproduce the above copyright
22 + *       notice, this list of conditions and the following disclaimer in
23 + *       the documentation and/or other materials provided with the
24 + *       distribution.
25 + *
26 + * 3. The end-user documentation included with the redistribution,
27 + *           if any, must include the following acknowledgment:
28 + *             "This product includes Radiance software
29 + *                 (http://radsite.lbl.gov/)
30 + *                 developed by the Lawrence Berkeley National Laboratory
31 + *               (http://www.lbl.gov/)."
32 + *       Alternately, this acknowledgment may appear in the software itself,
33 + *       if and wherever such third-party acknowledgments normally appear.
34 + *
35 + * 4. The names "Radiance," "Lawrence Berkeley National Laboratory"
36 + *       and "The Regents of the University of California" must
37 + *       not be used to endorse or promote products derived from this
38 + *       software without prior written permission. For written
39 + *       permission, please contact [email protected].
40 + *
41 + * 5. Products derived from this software may not be called "Radiance",
42 + *       nor may "Radiance" appear in their name, without prior written
43 + *       permission of Lawrence Berkeley National Laboratory.
44 + *
45 + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
46 + * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
47 + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
48 + * DISCLAIMED.   IN NO EVENT SHALL Lawrence Berkeley National Laboratory OR
49 + * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
50 + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
51 + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
52 + * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
53 + * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
54 + * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
55 + * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
56 + * SUCH DAMAGE.
57 + * ====================================================================
58 + *
59 + * This software consists of voluntary contributions made by many
60 + * individuals on behalf of Lawrence Berkeley National Laboratory.   For more
61 + * information on Lawrence Berkeley National Laboratory, please see
62 + * <http://www.lbl.gov/>.
63 + */
64 +
65   #include "standard.h"
66  
67   #include "font.h"
# Line 15 | Line 69 | static char SCCSid[] = "$SunId$ LBL";
69   #define galloc(nv)      (GLYPH *)malloc(sizeof(GLYPH)+2*sizeof(GORD)*(nv))
70  
71  
72 < extern char  *libpath;                  /* list of library directories */
72 > int     retainfonts = 0;                /* retain loaded fonts? */
73  
20 extern char  *fgetword();
21
74   static FONT     *fontlist = NULL;       /* list of loaded fonts */
75  
76  
# Line 26 | Line 78 | FONT *
78   getfont(fname)                          /* return font fname */
79   char  *fname;
80   {
29        char  buf[16];
81          FILE  *fp;
82          char  *pathname, *err;
83          unsigned  wsum, hsum, ngly;
84 <        int  gn, ngv;
34 <        register int  gv;
84 >        int  gn, ngv, gv;
85          register GLYPH  *g;
86          GORD  *gp;
87          register FONT  *f;
88  
89          for (f = fontlist; f != NULL; f = f->next)
90 <                if (!strcmp(f->name, fname))
90 >                if (!strcmp(f->name, fname)) {
91 >                        f->nref++;
92                          return(f);
93 +                }
94                                                  /* load the font file */
95 <        if ((pathname = getpath(fname, libpath, R_OK)) == NULL) {
95 >        if ((pathname = getpath(fname, getlibpath(), R_OK)) == NULL) {
96                  sprintf(errmsg, "cannot find font file \"%s\"", fname);
97                  error(USER, errmsg);
98          }
# Line 48 | Line 100 | char  *fname;
100          if (f == NULL)
101                  goto memerr;
102          f->name = savestr(fname);
103 +        f->nref = 1;
104          if ((fp = fopen(pathname, "r")) == NULL) {
105                  sprintf(errmsg, "cannot open font file \"%s\"",
106                                  pathname);
107                  error(SYSTEM, errmsg);
108          }
109 <        wsum = hsum = ngly = 0;
110 <        while (fgetword(buf,sizeof(buf),fp) != NULL) {  /* get each glyph */
111 <                if (!isint(buf))
109 >        wsum = hsum = ngly = 0;                 /* get each glyph */
110 >        while ((ngv = fgetval(fp, 'i', (char *)&gn)) != EOF) {
111 >                if (ngv == 0)
112                          goto nonint;
60                gn = atoi(buf);
113                  if (gn < 1 || gn > 255) {
114                          err = "illegal";
115                          goto fonterr;
# Line 66 | Line 118 | char  *fname;
118                          err = "duplicate";
119                          goto fonterr;
120                  }
121 <                if (fgetword(buf,sizeof(buf),fp) == NULL || !isint(buf) ||
122 <                                (ngv = atoi(buf)) < 0 || ngv > 32000) {
121 >                if (fgetval(fp, 'i', (char *)&ngv) <= 0 ||
122 >                                ngv < 0 || ngv > 32000) {
123                          err = "bad # vertices for";
124                          goto fonterr;
125                  }
# Line 79 | Line 131 | char  *fname;
131                  ngv *= 2;
132                  gp = gvlist(g);
133                  while (ngv--) {
134 <                        if (fgetword(buf,sizeof(buf),fp) == NULL ||
135 <                                        !isint(buf) ||
84 <                                        (gv = atoi(buf)) < 0 || gv > 255) {
134 >                        if (fgetval(fp, 'i', (char *)&gv) <= 0 ||
135 >                                        gv < 0 || gv > 255) {
136                                  err = "bad vertex for";
137                                  goto fonterr;
138                          }
# Line 124 | Line 175 | memerr:
175   }
176  
177  
178 + void
179 + freefont(fnt)                   /* release a font (free all if NULL) */
180 + FONT *fnt;
181 + {
182 +        FONT  head;
183 +        register FONT  *fl, *f;
184 +        register int  i;
185 +                                        /* check reference count */
186 +        if (fnt != NULL && (fnt->nref-- > 1 | retainfonts))
187 +                return;
188 +        head.next = fontlist;
189 +        fl = &head;
190 +        while ((f = fl->next) != NULL)
191 +                if ((fnt == NULL | fnt == f)) {
192 +                        fl->next = f->next;
193 +                        for (i = 0; i < 256; i++)
194 +                                if (f->fg[i] != NULL)
195 +                                        free((void *)f->fg[i]);
196 +                        freestr(f->name);
197 +                        free((void *)f);
198 +                } else
199 +                        fl = f;
200 +        fontlist = head.next;
201 + }
202 +
203 +
204   int
205   uniftext(sp, tp, f)                     /* uniformly space text line */
206   register short  *sp;            /* returned character spacing */
# Line 137 | Line 214 | register FONT  *f;             /* font */
214                  if (f->fg[*tp++&0xff] == NULL)
215                          *sp++ = 0;
216                  else
217 <                        linelen += *sp++ = 256;
217 >                        linelen += *sp++ = 255;
218          return(linelen);
219   }
220  
# Line 152 | Line 229 | int  cis;                      /* intercharacter spacing */
229          int  linelen;
230          register GLYPH  *gp;
231  
232 +        linelen = 0;
233          gp = NULL;
234          while (*tp && (gp = f->fg[*tp++&0xff]) == NULL)
235                  *sp++ = 0;
236          cis /= 2;
237 <        linelen = *sp = cis;
237 >        *sp = cis;
238          while (gp != NULL) {
239                  if (gp->nverts) {               /* regular character */
240                          linelen += *sp++ += cis - gp->left;
# Line 191 | Line 269 | int  nsi;                      /* minimum number of spaces for indent */
269                                          /* start by squeezing it */
270          squeeztext(sp, tp, f, cis);
271                                          /* now, realign spacing */
272 <        len = 0;
195 <        width = alen = *sp++;
272 >        width = *sp++;
273          while (*tp) {
274 +                len = alen = 0;
275                  nsp = sp;
276                  for (end = tp; *end; end = tab) {
277                          tab = end + 1;
# Line 217 | Line 295 | int  nsi;                      /* minimum number of spaces for indent */
295                          *sp++ += alen;
296                          len -= alen;
297                  }
220                len = 0;
221                alen = 0;
298                  tp = tab;
299          }
300          return(width);

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines