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

Comparing ray/src/rt/rtmain.c (file contents):
Revision 2.2 by greg, Tue Feb 25 02:47:23 2003 UTC vs.
Revision 2.8 by schorsch, Tue Oct 21 19:19:28 2003 UTC

# Line 7 | Line 7 | static const char      RCSid[] = "$Id$";
7  
8   #include "copyright.h"
9  
10 < #include  "ray.h"
10 > #include  <sys/types.h>
11 > #include  <signal.h>
12  
13 + #include  "platform.h"
14 + #include  "rtprocess.h" /* getpid() */
15 + #include  "ray.h"
16   #include  "source.h"
13
17   #include  "ambient.h"
15
18   #include  "random.h"
17
19   #include  "paths.h"
20  
20 #include  <sys/types.h>
21
22 #include  <signal.h>
21                                          /* persistent processes define */
22   #ifdef  F_SETLKW
23   #define  PERSIST        1               /* normal persist */
# Line 51 | Line 49 | extern int  lim_dist;                  /* limit distance? */
49   extern char  *tralist[];                /* list of modifers to trace (or no) */
50   extern int  traincl;                    /* include == 1, exclude == 0 */
51  
52 < void    onsig();
53 < void    sigdie();
54 < void    printdefaults();
52 > void    onsig(int);
53 > void    sigdie(int, char*);
54 > void    printdefaults(void);
55  
56  
57   int
# Line 176 | Line 174 | char  *argv[];
174                                  }
175                                  if (argv[i][2] == 'I') {        /* file */
176                                          rval = wordfile(tralp,
177 <                                        getpath(argv[++i],getlibpath(),R_OK));
177 >                                        getpath(argv[++i],getrlibpath(),R_OK));
178                                          if (rval < 0) {
179                                                  sprintf(errmsg,
180                                  "cannot open trace include file \"%s\"",
# Line 198 | Line 196 | char  *argv[];
196                                  }
197                                  if (argv[i][2] == 'E') {        /* file */
198                                          rval = wordfile(tralp,
199 <                                        getpath(argv[++i],getlibpath(),R_OK));
199 >                                        getpath(argv[++i],getrlibpath(),R_OK));
200                                          if (rval < 0) {
201                                                  sprintf(errmsg,
202                                  "cannot open trace exclude file \"%s\"",
# Line 237 | Line 235 | char  *argv[];
235          initurand(2048);
236                                          /* set up signal handling */
237          sigdie(SIGINT, "Interrupt");
238 + #ifdef SIGHUP
239          sigdie(SIGHUP, "Hangup");
240 + #endif
241          sigdie(SIGTERM, "Terminate");
242 + #ifdef SIGPIPE
243          sigdie(SIGPIPE, "Broken pipe");
244 + #endif
245 + #ifdef SIGALRM
246          sigdie(SIGALRM, "Alarm clock");
247 + #endif
248   #ifdef  SIGXCPU
249          sigdie(SIGXCPU, "CPU limit exceeded");
250          sigdie(SIGXFSZ, "File size exceeded");
# Line 274 | Line 278 | char  *argv[];
278                  openheader();
279          }
280   #endif
281 < #ifdef  MSDOS
281 > #ifdef  _WIN32
282          if (outform != 'a')
283 <                setmode(fileno(stdout), O_BINARY);
283 >                SET_FILE_BINARY(stdout);
284          if (octname == NULL)
285 <                setmode(fileno(stdin), O_BINARY);
285 >                SET_FILE_BINARY(stdin);
286   #endif
287          readoct(octname, loadflags, &thescene, NULL);
288          nsceneobjs = nobjects;
# Line 390 | Line 394 | int  signo;
394          if (gotsig++)                   /* two signals and we're gone! */
395                  _exit(signo);
396  
397 + #ifdef SIGALRM
398          alarm(15);                      /* allow 15 seconds to clean up */
399          signal(SIGALRM, SIG_DFL);       /* make certain we do die */
400 + #endif
401          eputs("signal - ");
402          eputs(sigerr[signo]);
403          eputs("\n");
# Line 411 | Line 417 | char  *msg;
417  
418  
419   void
420 < printdefaults()                 /* print default values to stdout */
420 > printdefaults(void)                     /* print default values to stdout */
421   {
422          register char  *cp;
423  

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines