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

Comparing ray/src/common/color.c (file contents):
Revision 2.10 by greg, Tue Feb 25 02:47:21 2003 UTC vs.
Revision 2.15 by greg, Tue Sep 14 02:53:50 2004 UTC

# Line 17 | Line 17 | static const char      RCSid[] = "$Id$";
17  
18   #include  "color.h"
19  
20 + #ifdef getc_unlocked            /* avoid horrendous overhead of flockfile */
21 + #undef getc
22 + #undef putc
23 + #define getc    getc_unlocked
24 + #define putc    putc_unlocked
25 + #endif
26 +
27   #define  MINELEN        8       /* minimum scanline length for encoding */
28   #define  MAXELEN        0x7fff  /* maximum scanline length for encoding */
29   #define  MINRUN         4       /* minimum run length */
# Line 31 | Line 38 | unsigned int  len;
38  
39          if (len > tempbuflen) {
40                  if (tempbuflen > 0)
41 <                        tempbuf = (char *)realloc(tempbuf, len);
41 >                        tempbuf = (char *)realloc((void *)tempbuf, len);
42                  else
43                          tempbuf = (char *)malloc(len);
44                  tempbuflen = tempbuf==NULL ? 0 : len;
# Line 49 | Line 56 | register FILE  *fp;
56          register int  i, j, beg, cnt = 1;
57          int  c2;
58          
59 <        if (len < MINELEN | len > MAXELEN)      /* OOBs, write out flat */
59 >        if ((len < MINELEN) | (len > MAXELEN))  /* OOBs, write out flat */
60                  return(fwrite((char *)scanline,sizeof(COLR),len,fp) - len);
61                                          /* put magic header */
62          putc(2, fp);
# Line 139 | Line 146 | register FILE  *fp;
146          register int  i, j;
147          int  code, val;
148                                          /* determine scanline type */
149 <        if (len < MINELEN | len > MAXELEN)
149 >        if ((len < MINELEN) | (len > MAXELEN))
150                  return(oldreadcolrs(scanline, len, fp));
151          if ((i = getc(fp)) == EOF)
152                  return(-1);
# Line 253 | Line 260 | double  r, g, b;
260  
261          d = frexp(d, &e) * 255.9999 / d;
262  
263 <        clr[RED] = r * d;
264 <        clr[GRN] = g * d;
265 <        clr[BLU] = b * d;
263 >        if (r > 0.0)
264 >                clr[RED] = r * d;
265 >        else
266 >                clr[RED] = 0;
267 >        if (g > 0.0)
268 >                clr[GRN] = g * d;
269 >        else
270 >                clr[GRN] = 0;
271 >        if (b > 0.0)
272 >                clr[BLU] = b * d;
273 >        else
274 >                clr[BLU] = 0;
275 >
276          clr[EXP] = e + COLXS;
277   }
278  

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines