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

Comparing ray/src/common/rglmat.c (file contents):
Revision 3.1 by gwlarson, Tue Jun 9 11:18:35 1998 UTC vs.
Revision 3.5 by greg, Tue Sep 16 06:31:48 2003 UTC

# Line 1 | Line 1
1 /* Copyright (c) 1998 Silicon Graphics, Inc. */
2
1   #ifndef lint
2 < static char SCCSid[] = "$SunId$ SGI";
2 > static const char       RCSid[] = "$Id$";
3   #endif
6
4   /*
5   * Routines for Radiance -> OpenGL materials.
6   */
7  
8 + #include "copyright.h"
9 +
10   #include "radogl.h"
11  
13 extern int      free(), freemtl();
14
12   int     domats = 1;                     /* are we doing materials? */
13  
14   LUTAB   mtab = LU_SINIT(free,freemtl);
15  
16  
17 + void
18   rgl_matclear()                  /* clean up materials */
19   {
20          lu_done(&mtab);
# Line 38 | Line 36 | char   *nam;
36   }
37  
38  
39 + int
40   o_default(o)                    /* default object is non-material modifier */
41   register OBJREC *o;
42   {
# Line 58 | Line 57 | register OBJREC        *o;
57                  freemtl(lup->data);
58          if ((lup->data = o->os) != NULL)        /* make material reference */
59                  ((MATREC *)lup->data)->nlinks++;
60 <        return;
60 >        return(0);
61   memerr:
62          error(SYSTEM, "out of memory in o_default");
63 +        return(0);
64   }
65  
66  
67 + int
68 + o_unsupported(o)                /* unsupported object primitive */
69 + OBJREC  *o;
70 + {
71 +        objerror(o, WARNING, "unsupported type");
72 +        return(0);
73 + }
74 +
75 +
76   MATREC *
77   newmaterial(nam)                /* get an entry for a new material */
78   char    *nam;
# Line 89 | Line 98 | memerr:
98   }
99  
100  
101 < freemtl(mp)                     /* free a material */
102 < register MATREC *mp;
101 > void
102 > freemtl(p)                      /* free a material */
103 > void    *p;
104   {
105 +        register MATREC *mp = (MATREC *)p;
106 +
107          if (!--mp->nlinks)
108 <                free((char *)mp);
108 >                free((void *)mp);
109   }
110  
111  
112 + int
113   m_normal(o)                     /* compute normal material parameters */
114   register OBJREC *o;
115   {
# Line 125 | Line 138 | register OBJREC        *o;
138                  m->u.m.specexp = 2./(o->oargs.farg[4]*o->oargs.farg[4]);
139          if (m->u.m.specexp > MAXSPECEXP)
140                  m->u.m.specexp = MAXSPECEXP;
141 +        return(0);
142   }
143  
144  
145 + int
146   m_aniso(o)                      /* anisotropic material */
147   register OBJREC *o;
148   {
# Line 156 | Line 171 | register OBJREC        *o;
171                  m->u.m.specexp = 2./(o->oargs.farg[4]*o->oargs.farg[5]);
172          if (m->u.m.specexp > MAXSPECEXP)
173                  m->u.m.specexp = MAXSPECEXP;
174 +        return(0);
175   }
176  
177  
178 + int
179   m_glass(o)                      /* glass material (hopeless) */
180   OBJREC  *o;
181   {
# Line 169 | Line 186 | OBJREC *o;
186          setcolor(m->u.m.ambdiff, 0., 0., 0.);
187          setcolor(m->u.m.specular, .08, .08, .08);
188          m->u.m.specexp = MAXSPECEXP;
189 +        return(0);
190   }
191  
192  
193 + int
194   m_brdf(o)                       /* convert functional material */
195   register OBJREC *o;
196   {
# Line 195 | Line 214 | register OBJREC        *o;
214                  scalecolor(m->u.m.ambdiff, 1.-o->oargs.farg[4]);
215          }
216          m->u.m.specexp = UNKSPECEXP;
217 +        return(0);
218   }
219  
220  
221 + int
222   m_brdf2(o)                      /* convert advanced functional material */
223   register OBJREC *o;
224   {
# Line 214 | Line 235 | register OBJREC        *o;
235                                          /* guess the rest */
236          setcolor(m->u.m.specular, .1, .1, .1);
237          m->u.m.specexp = UNKSPECEXP;
238 +        return(0);
239   }
240  
241  
242 + int
243   m_light(o)                      /* convert light type */
244   register OBJREC *o;
245   {
# Line 242 | Line 265 | register OBJREC        *o;
265                  m->u.l.spotdir[0] = m->u.l.spotdir[1] = 0.;
266                  m->u.l.spotdir[2] = -1.;
267          }
268 +        return(0);
269   }
270  
271  
272 + int
273   m_mirror(o)                     /* convert mirror type */
274   register OBJREC *o;
275   {
# Line 258 | Line 283 | register OBJREC        *o;
283          setcolor(m->u.m.specular, o->oargs.farg[0],
284                          o->oargs.farg[1], o->oargs.farg[2]);
285          m->u.m.specexp = MAXSPECEXP;
286 +        return(0);
287   }
288  
289  
290 + int
291   m_prism(o)                      /* convert prism type */
292   register OBJREC *o;
293   {
# Line 271 | Line 298 | register OBJREC        *o;
298          setcolor(m->u.m.ambdiff, 0.2, 0.2, 0.2);
299          setcolor(m->u.m.specular, 0.1, 0.1, 0.1);
300          m->u.m.specexp = UNKSPECEXP;
301 +        return(0);
302   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines