13 |
|
#include <stdio.h> |
14 |
|
#include <math.h> |
15 |
|
#include <sys/ioctl.h> |
16 |
+ |
#include <fcntl.h> |
17 |
|
|
18 |
|
#include <X11/Xlib.h> |
19 |
|
#include <X11/cursorfont.h> |
70 |
|
|
71 |
|
static Colormap ourmap = 0; /* our color map */ |
72 |
|
|
73 |
< |
extern char *malloc(), *getcombuf(); |
73 |
> |
#define IC_X11 0 |
74 |
> |
#define IC_IOCTL 1 |
75 |
> |
#define IC_READ 2 |
76 |
|
|
77 |
+ |
static int inpcheck; /* whence to check input */ |
78 |
+ |
|
79 |
+ |
extern char *malloc(); |
80 |
+ |
|
81 |
|
static int x11_close(), x11_clear(), x11_paintr(), x11_errout(), |
82 |
|
x11_getcur(), x11_comout(), x11_comin(), x11_flush(); |
83 |
|
|
189 |
|
cmdvec = x11_comout; |
190 |
|
if (wrnvec != NULL) |
191 |
|
wrnvec = x11_errout; |
192 |
+ |
inpcheck = IC_X11; |
193 |
|
} else { |
194 |
|
x11_driver.comin = std_comin; |
195 |
|
x11_driver.comout = std_comout; |
196 |
|
cmdvec = std_comout; |
197 |
+ |
inpcheck = IC_IOCTL; |
198 |
|
} |
199 |
|
return(&x11_driver); |
200 |
|
} |
291 |
|
static |
292 |
|
x11_flush() /* flush output */ |
293 |
|
{ |
294 |
+ |
char buf[256]; |
295 |
|
int n; |
296 |
|
/* check for input */ |
297 |
|
XNoOp(ourdisplay); |
298 |
|
n = XPending(ourdisplay); /* from X server */ |
299 |
|
while (n-- > 0) |
300 |
|
getevent(); |
301 |
< |
if (x11_driver.comin == std_comin) { /* from stdin */ |
301 |
> |
#ifdef FNDELAY |
302 |
> |
if (inpcheck == IC_IOCTL) { /* from stdin */ |
303 |
> |
#ifdef FIONREAD |
304 |
|
if (ioctl(fileno(stdin), FIONREAD, &n) < 0) { |
305 |
< |
stderr_v("ioctl error on stdin\n"); |
306 |
< |
quit(1); |
305 |
> |
#else |
306 |
> |
if (1) { |
307 |
> |
#endif |
308 |
> |
if (fcntl(fileno(stdin), F_SETFL, FNDELAY) < 0) { |
309 |
> |
stderr_v("Cannot change input mode\n"); |
310 |
> |
quit(1); |
311 |
> |
} |
312 |
> |
inpcheck = IC_READ; |
313 |
> |
} else |
314 |
> |
x11_driver.inpready += n; |
315 |
> |
} |
316 |
> |
if (inpcheck == IC_READ) { |
317 |
> |
n = read(fileno(stdin), buf, sizeof(buf)-1); |
318 |
> |
if (n > 0) { |
319 |
> |
buf[n] = '\0'; |
320 |
> |
tocombuf(buf, &x11_driver); |
321 |
|
} |
296 |
– |
x11_driver.inpready += n; |
322 |
|
} |
323 |
+ |
#endif |
324 |
|
} |
325 |
|
|
326 |
|
|
388 |
|
char *outp; |
389 |
|
{ |
390 |
|
fputs(outp, stdout); |
391 |
+ |
fflush(stdout); |
392 |
|
} |
393 |
|
|
394 |
|
|
582 |
|
fixwindow(eexp) /* repair damage to window */ |
583 |
|
register XExposeEvent *eexp; |
584 |
|
{ |
585 |
+ |
char buf[80]; |
586 |
+ |
|
587 |
|
if (eexp->window == gwind) { |
588 |
< |
sprintf(getcombuf(&x11_driver), "repaint %d %d %d %d\n", |
588 |
> |
sprintf(buf, "repaint %d %d %d %d\n", |
589 |
|
eexp->x, gheight - eexp->y - eexp->height, |
590 |
|
eexp->x + eexp->width, gheight - eexp->y); |
591 |
+ |
tocombuf(buf, &x11_driver); |
592 |
|
} else if (eexp->window == comline->w) { |
593 |
|
if (eexp->count == 0) |
594 |
|
xt_redraw(comline); |
608 |
|
x11_driver.xsiz = gwidth < MINWIDTH ? MINWIDTH : gwidth; |
609 |
|
x11_driver.ysiz = gheight < MINHEIGHT ? MINHEIGHT : gheight; |
610 |
|
|
611 |
< |
strcpy(getcombuf(&x11_driver), "new\n"); |
611 |
> |
tocombuf("new\n", &x11_driver); |
612 |
|
} |