comparison src/event-unixoid.c @ 802:19dfb459d51a

[xemacs-hg @ 2002-04-03 10:47:37 by ben] fix tty problem et al internals/internals.texi: Add section on correctly merging a branch back into the trunk. console-tty.c, eval.c, event-unixoid.c, file-coding.c, file-coding.h, lisp.h, print.c, sysdep.c: Fix data corruption error in print.c from print_depth becoming negative. Borrow primitives internal_bind_int, internal_bind_lisp_object from my stderr-proc ws, soon to be integrated; use them to properly bind print_depth et al. First fix for TTY problem. The basic problem is I switched things so that the TTY I/O is filtered through a coding system, for the support of kterm and such, that speak JIS or similar encodings. (#### I ***swear*** I had this working way back in 19.12.) Anyway, this introduced buffering issues, in which instead of one char being read, it tried to read 1024 chars. I tried setting the stdin descriptor non-blocking, but it doesn't appear to work on Cygwin. (#### Andy, do you know anything about this?) So I fixed it elsewhere. If you get weirdness on the TTY, look in console-tty.c and see how it gets the coding system; maybe there's a way to change it (and if not, there should be!). Also fix warning in sysdep.c.
author ben
date Wed, 03 Apr 2002 10:47:52 +0000
parents 2b676dc88c66
children 2b6fa2618f76
comparison
equal deleted inserted replaced
801:2b676dc88c66 802:19dfb459d51a
73 int 73 int
74 read_event_from_tty_or_stream_desc (Lisp_Event *event, struct console *con) 74 read_event_from_tty_or_stream_desc (Lisp_Event *event, struct console *con)
75 { 75 {
76 Emchar ch; 76 Emchar ch;
77 Lisp_Object console = wrap_console (con); 77 Lisp_Object console = wrap_console (con);
78
79 78
80 if (CONSOLE_TTY_P (con)) 79 if (CONSOLE_TTY_P (con))
81 ch = Lstream_get_emchar (XLSTREAM (CONSOLE_TTY_DATA (con)->instream)); 80 ch = Lstream_get_emchar (XLSTREAM (CONSOLE_TTY_DATA (con)->instream));
82 else 81 else
83 { 82 {