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

Comparing ray/src/rt/m_alias.c (file contents):
Revision 2.1 by greg, Tue Mar 11 19:29:05 2003 UTC vs.
Revision 2.6 by greg, Wed Jul 12 05:47:05 2006 UTC

# Line 6 | Line 6 | static const char RCSid[] = "$Id$";
6   */
7  
8   #include "copyright.h"
9 +
10   #include "ray.h"
11   #include "otypes.h"
12 + #include "rtotypes.h"
13   #include "otspecial.h"
14  
15   /*
# Line 21 | Line 23 | static const char RCSid[] = "$Id$";
23   *  chain at all.
24   */
25  
26 < int
27 < m_alias(m, r)                   /* transfer shading to alias target */
28 < OBJREC  *m;
29 < RAY     *r;
26 > extern int
27 > m_alias(                        /* transfer shading to alias target */
28 >        OBJREC  *m,
29 >        RAY     *r
30 > )
31   {
32          OBJECT  aobj;
33 +        OBJREC  *aop;
34          OBJREC  arec;
35 +        int     rval;
36                                          /* straight replacement? */
37          if (!m->oargs.nsargs)
38                  return(rayshade(r, m->omod));
39                                          /* else replace alias */
40          if (m->oargs.nsargs != 1)
41                  objerror(m, INTERNAL, "bad # string arguments");
42 <        aobj = lastmod(objndx(m), m->oargs.sarg[0]);
43 <        if (aobj < 0)
44 <                objerror(m, USER, "bad reference");
45 <        copystruct(&arec, objptr(aobj));
42 >        aop = m;
43 >        aobj = objndx(aop);
44 >        do {                            /* follow alias trail */
45 >                if (aop->oargs.nsargs == 1)
46 >                        aobj = lastmod(aobj, aop->oargs.sarg[0]);
47 >                else
48 >                        aobj = aop->omod;
49 >                if (aobj < 0)
50 >                        objerror(aop, USER, "bad reference");
51 >                aop = objptr(aobj);
52 >        } while (aop->otype == MOD_ALIAS);
53 >                                        /* copy struct */
54 >        arec = *aop;
55                                          /* irradiance hack */
56          if (do_irrad && !(r->crtype & ~(PRIMARY|TRANS)) &&
57 +                        m->otype != MAT_CLIP &&
58                          (ofun[arec.otype].flags & (T_M|T_X))) {
59                  if (irr_ignore(arec.otype)) {
60                          raytrans(r);
# Line 51 | Line 66 | RAY    *r;
66                                          /* substitute modifier */
67          arec.omod = m->omod;
68                                          /* replacement shader */
69 <        return((*ofun[arec.otype].funp)(&arec, r));
69 >        rval = (*ofun[arec.otype].funp)(&arec, r);
70 >                                        /* save allocated struct */
71 >        if (arec.os != aop->os) {
72 >                if (aop->os != NULL)    /* should never happen */
73 >                        free_os(aop);
74 >                aop->os = arec.os;
75 >        }
76 >        return(rval);
77   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines