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.4 by greg, Wed Apr 23 02:28:06 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 55 | Line 54 | register OBJREC        *o;
54                          goto memerr;
55                  strcpy(lup->key, o->oname);
56          } else if (lup->data != NULL)
57 <                freemtl(lup->data);
57 >                freemtl((MATREC *)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 78 | Line 87 | char   *nam;
87                          goto memerr;
88                  strcpy(lup->key, nam);
89          } else if (lup->data != NULL)
90 <                freemtl(lup->data);
90 >                freemtl((MATREC *)lup->data);
91          lup->data = (char *)malloc(sizeof(MATREC));
92          if (lup->data == NULL)
93                  goto memerr;
# Line 89 | Line 98 | memerr:
98   }
99  
100  
101 + void
102   freemtl(mp)                     /* free a material */
103   register MATREC *mp;
104   {
105          if (!--mp->nlinks)
106 <                free((char *)mp);
106 >                free((void *)mp);
107   }
108  
109  
110 + int
111   m_normal(o)                     /* compute normal material parameters */
112   register OBJREC *o;
113   {
# Line 125 | Line 136 | register OBJREC        *o;
136                  m->u.m.specexp = 2./(o->oargs.farg[4]*o->oargs.farg[4]);
137          if (m->u.m.specexp > MAXSPECEXP)
138                  m->u.m.specexp = MAXSPECEXP;
139 +        return(0);
140   }
141  
142  
143 + int
144   m_aniso(o)                      /* anisotropic material */
145   register OBJREC *o;
146   {
# Line 156 | Line 169 | register OBJREC        *o;
169                  m->u.m.specexp = 2./(o->oargs.farg[4]*o->oargs.farg[5]);
170          if (m->u.m.specexp > MAXSPECEXP)
171                  m->u.m.specexp = MAXSPECEXP;
172 +        return(0);
173   }
174  
175  
176 + int
177   m_glass(o)                      /* glass material (hopeless) */
178   OBJREC  *o;
179   {
# Line 169 | Line 184 | OBJREC *o;
184          setcolor(m->u.m.ambdiff, 0., 0., 0.);
185          setcolor(m->u.m.specular, .08, .08, .08);
186          m->u.m.specexp = MAXSPECEXP;
187 +        return(0);
188   }
189  
190  
191 + int
192   m_brdf(o)                       /* convert functional material */
193   register OBJREC *o;
194   {
# Line 195 | Line 212 | register OBJREC        *o;
212                  scalecolor(m->u.m.ambdiff, 1.-o->oargs.farg[4]);
213          }
214          m->u.m.specexp = UNKSPECEXP;
215 +        return(0);
216   }
217  
218  
219 + int
220   m_brdf2(o)                      /* convert advanced functional material */
221   register OBJREC *o;
222   {
# Line 214 | Line 233 | register OBJREC        *o;
233                                          /* guess the rest */
234          setcolor(m->u.m.specular, .1, .1, .1);
235          m->u.m.specexp = UNKSPECEXP;
236 +        return(0);
237   }
238  
239  
240 + int
241   m_light(o)                      /* convert light type */
242   register OBJREC *o;
243   {
# Line 242 | Line 263 | register OBJREC        *o;
263                  m->u.l.spotdir[0] = m->u.l.spotdir[1] = 0.;
264                  m->u.l.spotdir[2] = -1.;
265          }
266 +        return(0);
267   }
268  
269  
270 + int
271   m_mirror(o)                     /* convert mirror type */
272   register OBJREC *o;
273   {
# Line 258 | Line 281 | register OBJREC        *o;
281          setcolor(m->u.m.specular, o->oargs.farg[0],
282                          o->oargs.farg[1], o->oargs.farg[2]);
283          m->u.m.specexp = MAXSPECEXP;
284 +        return(0);
285   }
286  
287  
288 + int
289   m_prism(o)                      /* convert prism type */
290   register OBJREC *o;
291   {
# Line 271 | Line 296 | register OBJREC        *o;
296          setcolor(m->u.m.ambdiff, 0.2, 0.2, 0.2);
297          setcolor(m->u.m.specular, 0.1, 0.1, 0.1);
298          m->u.m.specexp = UNKSPECEXP;
299 +        return(0);
300   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines