| 10 |
|
#include "rhdisp.h" |
| 11 |
|
#include "rhdriver.h" |
| 12 |
|
#include "rhdobj.h" |
| 13 |
+ |
#include "rtprocess.h" |
| 14 |
|
|
| 15 |
|
extern FILE *sstdout; /* user standard output */ |
| 16 |
|
|
| 51 |
|
struct dobject *next; /* next object in list */ |
| 52 |
|
char name[64]; /* object name */ |
| 53 |
|
FVECT center; /* orig. object center */ |
| 54 |
< |
FLOAT radius; /* orig. object radius */ |
| 54 |
> |
RREAL radius; /* orig. object radius */ |
| 55 |
|
int listid; /* GL display list identifier */ |
| 56 |
|
int nlists; /* number of lists allocated */ |
| 57 |
< |
int rtp[3]; /* associated rtrace process */ |
| 57 |
> |
SUBPROC rtp; /* associated rtrace process */ |
| 58 |
|
DLIGHTS *ol; /* object lights */ |
| 59 |
|
FULLXF xfb; /* coordinate transform */ |
| 60 |
|
short drawcode; /* drawing code */ |
| 119 |
|
dobjects = ohead.next; |
| 120 |
|
if (!foundlink) { |
| 121 |
|
glDeleteLists(op->listid, op->nlists); |
| 122 |
< |
close_process(op->rtp); |
| 122 |
> |
close_process(&(op->rtp)); |
| 123 |
|
} |
| 124 |
|
while (op->xfac) |
| 125 |
|
freestr(op->xfav[--op->xfac]); |
| 579 |
|
/* start rtrace */ |
| 580 |
|
rtargv[RTARGC-1] = fpath; |
| 581 |
|
rtargv[RTARGC] = NULL; |
| 582 |
< |
open_process(op->rtp, rtargv); |
| 582 |
> |
open_process(&(op->rtp), rtargv); |
| 583 |
|
/* insert into main list */ |
| 584 |
|
op->next = dobjects; |
| 585 |
|
curobj = dobjects = op; |
| 860 |
|
VCOPY(darr, rorg); VCOPY(darr+3, rdir); |
| 861 |
|
} |
| 862 |
|
/* trace it */ |
| 863 |
< |
if (process(op->rtp, (char *)darr, (char *)darr, sizeof(double), |
| 863 |
> |
if (process(&(op->rtp), (char *)darr, (char *)darr, sizeof(double), |
| 864 |
|
6*sizeof(double)) != sizeof(double)) |
| 865 |
|
error(SYSTEM, "rtrace communication error"); |
| 866 |
|
/* return distance */ |