--- ray/src/rt/devmain.c 1989/11/01 16:12:22 1.3 +++ ray/src/rt/devmain.c 1990/01/19 00:00:33 1.6 @@ -32,18 +32,14 @@ int notified = 0; /* notified parent of input? */ char *progname; /* driver name */ -int r_clear(), r_paintr(), r_getcur(), r_comout(), r_comin(), r_mycomin(); +int r_clear(), r_paintr(), r_getcur(), r_comout(), r_comin(); int (*dev_func[NREQUESTS])() = { /* request handlers */ r_clear, r_paintr, r_getcur, r_comout, r_comin }; -char mybuf[512] = ""; -char *mybufp(); - - main(argc, argv) /* set up communications and main loop */ int argc; char *argv[]; @@ -66,6 +62,7 @@ char *argv[]; if ((dev = dinit(argv[0], argv[3])) == NULL) quit(1); putw(COM_RECVM, devout); /* verify initialization */ + fwrite((char *)&dev->pixaspect, sizeof(dev->pixaspect), 1, devout); putw(dev->xsiz, devout); putw(dev->ysiz, devout); fflush(devout); @@ -106,7 +103,7 @@ r_paintr() /* paint a rectangle */ int xmin, ymin, xmax, ymax; nrays += 5; /* pretend */ - fread(col, sizeof(COLOR), 1, devin); + fread((char *)col, sizeof(COLOR), 1, devin); xmin = getw(devin); ymin = getw(devin); xmax = getw(devin); ymax = getw(devin); (*dev->paintr)(col, xmin, ymin, xmax, ymax); @@ -183,28 +180,6 @@ register FILE *fp; } -r_mycomin() /* get command from my buffer */ -{ - register char *cp; - /* get next command */ - for (cp = mybuf; *cp != '\n'; cp++) - ; - *cp++ = '\0'; - (*dev->comout)(mybuf); /* echo my command */ - /* send it as reply */ - putc(COM_COMIN, devout); - myputs(mybuf, devout); - fflush(devout); - /* get next command */ - (*dev->comout)("\n"); - strcpy(mybuf, cp); - if (mybuf[0]) - kill(getppid(), SIGIO); /* signal more */ - else - dev_func[COM_COMIN] = r_comin; /* else reset */ -} - - stderr_v(s) /* put string to stderr */ register char *s; { @@ -219,23 +194,4 @@ register char *s; fflush(stderr); inline = 0; } -} - - -char * -mybufp() /* return buffer for my command */ -{ - if (dev_func[COM_COMIN] != r_mycomin) { - dev_func[COM_COMIN] = r_mycomin; - kill(getppid(), SIGIO); - } - return(mybuf+strlen(mybuf)); -} - - -repaint(xmin, ymin, xmax, ymax) /* repaint section of display */ -int xmin, ymin, xmax, ymax; -{ - sprintf(mybufp(), "repaint %d %d %d %d\n", - xmin, ymin, xmax, ymax); }