13 |
|
#include "rtprocess.h" /* getpid() */ |
14 |
|
#include "platform.h" |
15 |
|
#include "RpictSimulManager.h" |
16 |
+ |
#include "func.h" |
17 |
|
|
18 |
|
extern char *progname; /* argv[0] */ |
19 |
|
const char *sigerr[NSIG]; /* signal error messages */ |
58 |
|
"AdaptiveShadowTesting\nOutputs=v,l\n" \ |
59 |
|
"OutputCS=RGB,XYZ,prims,spec\n" |
60 |
|
|
60 |
– |
|
61 |
|
void |
62 |
< |
quit(int code) /* quit program -- called from ray_done() */ |
62 |
> |
quit(int code) /* quit program */ |
63 |
|
{ |
64 |
< |
if (ray_pnprocs < 0) |
65 |
< |
_exit(code); /* avoid flush in child */ |
64 |
> |
exit(code); // don't bother about freeing anything |
65 |
> |
} |
66 |
|
|
67 |
< |
int ec = myRPmanager.Cleanup(); |
68 |
< |
|
69 |
< |
if (ec) code = ec; |
70 |
< |
|
71 |
< |
exit(code); |
67 |
> |
/* Set default options */ |
68 |
> |
static void |
69 |
> |
default_options(void) |
70 |
> |
{ |
71 |
> |
shadthresh = .05; |
72 |
> |
shadcert = .5; |
73 |
> |
srcsizerat = .25; |
74 |
> |
directrelay = 1; |
75 |
> |
ambacc = 0.2; |
76 |
> |
ambres = 64; |
77 |
> |
ambdiv = 512; |
78 |
> |
ambssamp = 128; |
79 |
> |
maxdepth = 7; |
80 |
|
} |
81 |
|
|
74 |
– |
|
82 |
|
int |
83 |
|
main(int argc, char *argv[]) |
84 |
|
{ |
108 |
|
strcat(RFeatureList, RXPICT_FEATURES); |
109 |
|
if (argc > 1 && !strcmp(argv[1], "-features")) |
110 |
|
return feature_status(argc-2, argv+2); |
111 |
+ |
/* initialize calcomp routines */ |
112 |
+ |
initfunc(); |
113 |
+ |
/* set defaults */ |
114 |
+ |
default_options(); |
115 |
|
/* option city */ |
116 |
|
for (i = 1; i < argc; i++) { |
117 |
|
/* expand arguments */ |
510 |
|
static time_t lastReportTime = 0; |
511 |
|
time_t tnow = time(NULL); |
512 |
|
|
513 |
< |
if (tnow - lastReportTime < ralrm) |
513 |
> |
if (pct < 100.-FTINY && tnow - lastReportTime < ralrm) |
514 |
|
return; // too soon, my Precious... |
515 |
|
|
516 |
|
sprintf(errmsg, "%7.3f%% done after %7.3f hours\n", pct, (tnow-tstart)/3600.); |
524 |
|
void |
525 |
|
rpict(int seq, char *pout, char *zout, char *prvr) |
526 |
|
/* |
527 |
< |
* If seq is greater than zero, then we will render a sequence of |
527 |
> |
* If seq is greater than zero, we will render a sequence of |
528 |
|
* images based on view parameter strings read from the standard input. |
529 |
|
* If pout is NULL, then all images will be sent to the standard ouput. |
530 |
|
* If seq is greater than zero and prvr is an integer, then it is the |
570 |
|
if (!dtype) |
571 |
|
error(USER, "ResumeFrame() failed"); |
572 |
|
if (!seq) |
573 |
< |
return; // all done if we're running a sequence |
573 |
> |
return; // all done if not a sequence |
574 |
|
} |
575 |
|
do { |
576 |
|
if (prvr) // have view from sequence recovery? |
622 |
|
zout ? dbuf : zout) |
623 |
|
&& !seq | (errno != EEXIST)) |
624 |
|
error(USER, "RenderFrame() failed"); |
625 |
< |
} while (seq++); // all done if we're running a sequence |
625 |
> |
} while (seq++); // all done if not a sequence |
626 |
|
} |