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

Comparing ray/src/rt/devcomm.c (file contents):
Revision 1.16 by greg, Mon Mar 12 11:08:44 1990 UTC vs.
Revision 2.2 by greg, Thu Mar 19 09:34:02 1992 UTC

# Line 16 | Line 16 | static char SCCSid[] = "$SunId$ LBL";
16  
17   #include "driver.h"
18  
19 + #include "vfork.h"
20 +
21   #ifndef DEVPATH
22   #define DEVPATH         getenv("PATH")  /* device search path */
23   #endif
# Line 24 | Line 26 | static char SCCSid[] = "$SunId$ LBL";
26   #define DELAY           20              /* seconds to wait for response */
27   #endif
28  
27 #ifndef BSD
28 #define vfork           fork
29 #endif
30
31 extern char     *getpath(), *getenv();
32
29   static int      comm_close(), comm_clear(), comm_paintr(), comm_errout(),
30                  comm_getcur(), comm_comout(), comm_comin(), comm_flush();
31  
# Line 51 | Line 47 | char   *dname, *id;
47          int     p1[2], p2[2];
48          char    pin[16], pout[16];
49                                                  /* find driver program */
50 <        if ((devname = getpath(dname, DEVPATH, 1)) == NULL) {
50 >        if ((devname = getpath(dname, DEVPATH, X_OK)) == NULL) {
51                  stderr_v(dname);
52                  stderr_v(": not found\n");
53                  return(NULL);
# Line 82 | Line 78 | char   *dname, *id;
78          if (getw(devin) != COM_RECVM)
79                  return(NULL);
80                                                  /* get driver parameters */
81 <        comm_flush();
81 >        getstate();
82                                                  /* set error vectors */
83          cmdvec = comm_comout;
84          if (wrnvec != NULL)
# Line 141 | Line 137 | comm_flush()                           /* flush output to driver */
137          fflush(devout);
138          if (getc(devin) != COM_FLUSH)
139                  reply_error("flush");
140 <        fread((char *)&comm_driver.pixaspect,
145 <                        sizeof(comm_driver.pixaspect), 1, devin);
146 <        comm_driver.xsiz = getw(devin);
147 <        comm_driver.ysiz = getw(devin);
148 <        comm_driver.inpready = getw(devin);
140 >        getstate();
141   }
142  
143  
# Line 172 | Line 164 | char   *str;
164   {
165          putc(COM_COMOUT, devout);
166          myputs(str, devout);
167 +        if (str[strlen(str)-1] == '\n')
168 +                fflush(devout);
169   }
170  
171  
# Line 191 | Line 185 | char   *prompt;
185          if (getc(devin) != COM_COMIN)
186                  reply_error("comin");
187          mygets(buf, devin);
188 <        comm_driver.inpready = getw(devin);
188 >        getstate();
189   }
190  
191  
# Line 236 | Line 230 | char   *routine;
230          stderr_v(routine);
231          stderr_v(": driver reply error\n");
232          quit(1);
233 + }
234 +
235 +
236 + static
237 + getstate()                              /* get driver state variables */
238 + {
239 +        fread((char *)&comm_driver.pixaspect,
240 +                        sizeof(comm_driver.pixaspect), 1, devin);
241 +        comm_driver.xsiz = getw(devin);
242 +        comm_driver.ysiz = getw(devin);
243 +        comm_driver.inpready = getw(devin);
244   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines