Mercurial > emacs
diff src/sysdep.c @ 53226:dd3018b4785b
Implemented multiple tty support.
README.multi-tty: New file.
src/termchar.h (struct terminal): Renamed to struct tty_output. Added name, type,
input, output, termscript, old_tty, term_initted, old_tty_valid,
background_pixel, foreground_pixel, next fields.
(TERMINAL_*): Renamed to TTY_* for brevity.
(CURRENT_TERMINAL): Renamed to CURTTY for brevity.
(tty_list): New variable.
(TERMINAL_PTR): Removed.
(FRAME_TTY): New function.
(TTY_NAME, TTY_TYPE): New macros.
src/term.c (current_terminal): Removed. (_current_terminal): Removed. (tty_list):
New variable. (OUTPUT, OUTPUT1, OUTPUTL, OUTPUT_IF, OUTPUT1_IF): Added tty
parameter. (set_terminal_modes): Added tty parameter. (reset_terminal_modes):
Added tty parameter. (cursor_to, raw_cursor_to): Updated cmgoto() calls.
(clear_end_of_line, write_glyphs): Add indirection to terminal output, updated
cmcheckmagic() calls. (get_named_tty): New function. (term_dummy_init): New
function. (term_init): Added name parameter, added tty_output return value.
Changed algorithm to update tty_list. Call init_sys_modes() to set up tty
mode on the newly opened terminal device.
(get_current_tty): New function, intended for debugging.
src/termhooks.h (termscript): Removed.
src/w32term.h (FRAME_FOREGROUND_PIXEL, FRAME_BACKGROUND_PIXEL): Removed redundant
definition.
src/macterm.h (FRAME_FOREGROUND_PIXEL, FRAME_BACKGROUND_PIXEL): Ditto.
src/window.c (init_window_once): Call make_terminal_frame with two zero parameters.
src/cm.h (emacs_tputs): New macro to set current_tty, and then call tputs().
(current_tty): New variable, for cmputc().
(cmcheckmagic, cmputc, cmgoto): Added prototypes.
src/cm.c (current_tty): New variable, for cmputc().
(cmputc): Use it.
(cmcheckmagic): Added tty parameter, look up terminal streams there.
(calccost): Added tty parameter. Use emacs_tputs() instead of tputs().
(cmgoto): Added tty parameter. Pass it on to calccost(). Use emacs_tputs()
instead of tputs().
src/dispextern.h (set_terminal_modes, reset_terminal_modes): Added tty parameter.
(term_init): Added name parameter (the filename of the terminal device). Added
return value (struct tty_output).
src/dispnew.c: Replace CURTTY() with local variables throughout the file (where applicable).
(termscript): Moved to struct tty_output.
(terminal_type): Removed.
src/emacs.c (main): Don't call init_sys_modes(), the new term_init() already does that
during init_display().
(shut_down_emacs): Call reset_all_sys_modes() instead of reset_sys_modes().
src/frame.c (Qtty, Qtty_type): New variables.
(syms_of_frame): Initialize them.
(tty_display): Removed.
(make_terminal_frame): New parameters (tty filename and type).
Initialize output_data.tty field instead of output_data.x. Use term_init() to
find the right tty_output. (Use term_dummy_init() during bootstrap.)
(Fmake_terminal_frame): Get device filename and type from frame parameters.
src/frame.h (FRAME_FOREGROUND_PIXEL, FRAME_BACKGROUND_PIXEL): Do the right thing
if the frame is a tty.
(struct frame): New member in output_data: tty.
(make_terminal_frame): Updated of prototype.
src/keyboard.c (Fset_input_mode): Call reset_all_sys_modes(), not
reset_sys_modes(). Ditto with init_sys_modes().
src/lisp.h (tty_output): Added forward declaration.
(init_sys_modes, reset_sys_modes): Updated prototype.
(init_all_sys_modes, reset_all_sys_modes): New prototypes.
src/scroll.c: Replace CURTTY() with local variables throughout the file (where applicable).
src/sysdep.c (old_tty, term_initted, old_tty_valid): Moved to struct tty_output.(
(init_all_sys_modes): New function.
(init_sys_modes): Added tty_output parameter. Use it.
(reset_all_sys_modes): New function.
(reset_sys_modes): Added tty_output parameter. Use it.
src/Makefile.in: Update dependencies.
git-archimport-id: lorentey@elte.hu--2004/emacs--multi-tty--0--patch-2
| author | Karoly Lorentey <lorentey@elte.hu> |
|---|---|
| date | Thu, 25 Dec 2003 06:59:31 +0000 |
| parents | 4250e7e26247 |
| children | 33c3c7c16e13 |
line wrap: on
line diff
--- a/src/sysdep.c Wed Dec 24 18:55:24 2003 +0000 +++ b/src/sysdep.c Thu Dec 25 06:59:31 2003 +0000 @@ -1255,14 +1255,6 @@ } -/* The initial tty mode bits */ -struct emacs_tty old_tty; - -/* 1 if we have been through init_sys_modes. */ -int term_initted; - -/* 1 if outer tty status has been recorded. */ -int old_tty_valid; #ifdef BSD4_1 /* BSD 4.1 needs to keep track of the lmode bits in order to start @@ -1298,7 +1290,18 @@ #endif void -init_sys_modes () +init_all_sys_modes (void) +{ + struct tty_output *tty = tty_list; + while (tty) { + init_sys_modes (tty); + tty = tty->next; + } +} + +void +init_sys_modes (otty) + struct tty_output *otty; { struct emacs_tty tty; @@ -1367,14 +1370,14 @@ if (!read_socket_hook && EQ (Vwindow_system, Qnil)) #endif { - EMACS_GET_TTY (input_fd, &old_tty); - - old_tty_valid = 1; - - tty = old_tty; + EMACS_GET_TTY (input_fd, &otty->old_tty); + + otty->old_tty_valid = 1; + + tty = otty->old_tty; #if defined (HAVE_TERMIO) || defined (HAVE_TERMIOS) - XSETINT (Vtty_erase_char, old_tty.main.c_cc[VERASE]); + XSETINT (Vtty_erase_char, otty->old_tty.main.c_cc[VERASE]); #ifdef DGUX /* This allows meta to be sent on 8th bit. */ @@ -1539,7 +1542,7 @@ tty.tchars.t_stopc = '\023'; } - tty.lmode = LDECCTQ | LLITOUT | LPASS8 | LNOFLSH | old_tty.lmode; + tty.lmode = LDECCTQ | LLITOUT | LPASS8 | LNOFLSH | otty->old_tty.lmode; #ifdef ultrix /* Under Ultrix 4.2a, leaving this out doesn't seem to hurt anything, and leaving it in breaks the meta key. Go figure. */ @@ -1557,7 +1560,7 @@ tty.ltchars = new_ltchars; #endif /* HAVE_LTCHARS */ #ifdef MSDOS /* Demacs 1.1.2 91/10/20 Manabu Higashida, MW Aug 1993 */ - if (!term_initted) + if (!otty->term_initted) internal_terminal_init (); dos_ttraw (); #endif @@ -1646,14 +1649,14 @@ #endif ) #endif - set_terminal_modes (); - - if (!term_initted + set_terminal_modes (otty); + + if (!otty->term_initted && FRAMEP (Vterminal_frame) && FRAME_TERMCAP_P (XFRAME (Vterminal_frame))) init_frame_faces (XFRAME (Vterminal_frame)); - if (term_initted && no_redraw_on_reenter) + if (otty->term_initted && no_redraw_on_reenter) { if (display_completed) direct_output_forward_char (0); @@ -1665,7 +1668,7 @@ FRAME_GARBAGED_P (XFRAME (Vterminal_frame)) = 1; } - term_initted = 1; + otty->term_initted = 1; } /* Return nonzero if safe to use tabs in output. @@ -1778,10 +1781,21 @@ } +void +reset_all_sys_modes (void) +{ + struct tty_output *tty = tty_list; + while (tty) { + reset_sys_modes (tty); + tty = tty->next; + } +} + /* Prepare the terminal for exiting Emacs; move the cursor to the bottom of the frame, turn off interrupt-driven I/O, etc. */ void -reset_sys_modes () +reset_sys_modes (otty) + struct tty_output *otty; { struct frame *sf; @@ -1790,7 +1804,7 @@ fflush (stdout); return; } - if (!term_initted) + if (!otty->term_initted) return; #ifdef HAVE_WINDOW_SYSTEM /* Emacs' window system on MSDOG uses the `internal terminal' and therefore @@ -1820,7 +1834,7 @@ } #endif - reset_terminal_modes (); + reset_terminal_modes (otty); fflush (stdout); #ifdef BSD_SYSTEM #ifndef BSD4_1 @@ -1848,8 +1862,8 @@ reset_sigio (); #endif /* BSD4_1 */ - if (old_tty_valid) - while (EMACS_SET_TTY (input_fd, &old_tty, 0) < 0 && errno == EINTR) + if (otty->old_tty_valid) + while (EMACS_SET_TTY (input_fd, &otty->old_tty, 0) < 0 && errno == EINTR) ; #ifdef MSDOS /* Demacs 1.1.2 91/10/20 Manabu Higashida */ @@ -1860,7 +1874,7 @@ /* Ultrix's termios *ignores* any line discipline except TERMIODISC. A different old line discipline is therefore not restored, yet. Restore the old line discipline by hand. */ - ioctl (0, TIOCSETD, &old_tty.main.c_line); + ioctl (0, TIOCSETD, &otty->old_tty.main.c_line); #endif #ifdef AIXHFT @@ -3470,7 +3484,7 @@ char *badfunc; { printf ("%s not yet implemented\r\n", badfunc); - reset_sys_modes (); + reset_all_sys_modes (); exit (1); } @@ -5056,7 +5070,7 @@ char *badfunc; { printf ("%s not yet implemented\r\n", badfunc); - reset_sys_modes (); + reset_all_sys_modes (); exit (1); } @@ -5126,8 +5140,8 @@ } /* The HFT system on AIX doesn't optimize for scrolling, so it's really ugly at times. */ - TERMINAL_LINE_INS_DEL_OK (CURRENT_TERMINAL ()) = 0; - TERMINAL_CHAR_INS_DEL_OK (CURRENT_TERMINAL ()) = 0; + TTY_LINE_INS_DEL_OK (CURTTY ()) = 0; + TTY_CHAR_INS_DEL_OK (CURTTY ()) = 0; } /* Reset the rubout key to backspace. */
