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

Comparing ray/src/common/calfunc.c (file contents):
Revision 2.26 by greg, Thu Sep 16 23:48:47 2021 UTC vs.
Revision 2.29 by greg, Sun Feb 25 18:36:27 2024 UTC

# Line 22 | Line 22 | static const char      RCSid[] = "$Id$";
22  
23                                  /* bits in argument flag (better be right!) */
24   #define  AFLAGSIZ       (8*sizeof(unsigned long))
25 < #define  ALISTSIZ       8       /* maximum saved argument list */
25 > #define  ALISTSIZ       10      /* maximum saved argument list */
26  
27   typedef struct activation {
28      char  *name;                /* function name */
# Line 203 | Line 203 | argument(int n)                        /* return nth argument for active fu
203      EPNODE  *ep = NULL;
204      double  aval;
205  
206    if (!n)                                     /* asking for # arguments? */
207        return((double)nargum());
208
206      if (!actp | (--n < 0)) {
207          eputs("Bad call to argument!\n");
208          quit(1);
# Line 358 | Line 355 | libfunc(                               /* execute library function */
355              errno = ERANGE;
356      }
357   #endif
358 <    if (errno == EDOM || errno == ERANGE) {
358 >    if ((errno == EDOM) | (errno == ERANGE)) {
359          wputs(fname);
360          if (errno == EDOM)
361                  wputs(": domain error\n");
# Line 396 | Line 393 | l_select(char *nm)     /* return argument #(A1+1) */
393          double  a1 = argument(1);
394          int  n = (int)(a1 + .5);
395  
396 <        if (a1 < -.5 || n >= narg) {
396 >        if ((a1 < -.5) | (n >= narg)) {
397                  errno = EDOM;
398                  return(0.0);
399          }
# Line 412 | Line 409 | l_max(char *nm)                /* general maximum function */
409          int  n = nargum();
410          double  vmax = argument(1);
411  
412 <        while (--n) {
413 <                double  v = argument(n);
412 >        while (n > 1) {
413 >                double  v = argument(n--);
414                  if (vmax < v)
415                          vmax = v;
416          }
# Line 427 | Line 424 | l_min(char *nm)                /* general minimum function */
424          int  n = nargum();
425          double  vmin = argument(1);
426  
427 <        while (--n) {
428 <                double  v = argument(n);
427 >        while (n > 1) {
428 >                double  v = argument(n--);
429                  if (vmin > v)
430                          vmin = v;
431          }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines