| 108 |
|
/* load RIF if any */ |
| 109 |
|
getradfile(); |
| 110 |
|
|
| 111 |
< |
if (hdlist[i] == NULL) { /* create new holodeck */ |
| 111 |
> |
if (hdlist[0] == NULL) { /* create new holodeck */ |
| 112 |
|
/* set defaults */ |
| 113 |
|
setdefaults(&hdg); |
| 114 |
|
/* holodeck exists? */ |
| 142 |
|
if (gotsig++) /* two signals and we're gone! */ |
| 143 |
|
_exit(signo); |
| 144 |
|
|
| 145 |
< |
alarm(30); /* allow 30 seconds to clean up */ |
| 145 |
> |
alarm(60); /* allow 60 seconds to clean up */ |
| 146 |
|
signal(SIGALRM, SIG_DFL); /* make certain we do die */ |
| 147 |
|
eputs("signal - "); |
| 148 |
|
eputs(sigerr[signo]); |
| 272 |
|
if (!disp_check(idle)) |
| 273 |
|
return(0); |
| 274 |
|
/* display only? */ |
| 275 |
< |
if (nprocs <= 0) |
| 275 |
> |
if (nprocs <= 0) { |
| 276 |
> |
idle = 1; |
| 277 |
|
return(outdev != NULL); |
| 278 |
+ |
} |
| 279 |
|
/* check file size */ |
| 280 |
|
if (maxdisk > 0 && hdfilen(hdlist[0]->fd) >= maxdisk) { |
| 281 |
|
error(WARNING, "file limit exceeded"); |
| 282 |
|
done_rtrace(); |
| 281 |
– |
idle = 1; |
| 283 |
|
return(1); /* comes back */ |
| 284 |
|
} |
| 285 |
|
/* check time */ |
| 288 |
|
if (endtime > 0 && t >= endtime) { |
| 289 |
|
error(WARNING, "time limit exceeded"); |
| 290 |
|
done_rtrace(); |
| 290 |
– |
idle = 1; |
| 291 |
|
return(1); /* comes back */ |
| 292 |
|
} |
| 293 |
|
if (reporttime > 0 && t >= reporttime) |
| 294 |
|
report(t); |
| 295 |
< |
/* get packets to process */ |
| 295 |
> |
idle = 0; /* get packets to process */ |
| 296 |
|
while (freepacks != NULL) { |
| 297 |
|
p = freepacks; freepacks = p->next; p->next = NULL; |
| 298 |
|
if (!next_packet(p)) { |
| 335 |
|
if (!vdef(VDIST)) { |
| 336 |
|
vval(VDIST) = "F"; |
| 337 |
|
vdef(VDIST)++; |
| 338 |
– |
} |
| 339 |
– |
if (!vdef(OCCUPANCY)) { |
| 340 |
– |
vval(OCCUPANCY) = "U"; |
| 341 |
– |
vdef(OCCUPANCY)++; |
| 338 |
|
} |
| 339 |
|
/* append rendering options */ |
| 340 |
|
if (vdef(RENDER)) |