diff options
| author | Karoly Lorentey | 2003-12-26 04:24:54 +0000 |
|---|---|---|
| committer | Karoly Lorentey | 2003-12-26 04:24:54 +0000 |
| commit | 9628b8878f46b2b7eeeb4f272d20f2e64de19f4a (patch) | |
| tree | cfccb4da4a6b898780d3bc9856b377fd5d85e4e6 /src/frame.c | |
| parent | 4f0359deff8eb9ec9ed95e75d77a0dd59f39428c (diff) | |
| download | emacs-9628b8878f46b2b7eeeb4f272d20f2e64de19f4a.tar.gz emacs-9628b8878f46b2b7eeeb4f272d20f2e64de19f4a.zip | |
lib-src/emacsclient.c: Implemented --here option (open a new Emacs tty). Needs more work.
(here): New variable.
(decode_options): Use it.
(ec_get_tty, ec_set_tty, init_tty, window_change, hang_up_signal): New functions.
(window_change_signal, init_signals, reset_tty, init_pty, copy_from_to): Ditto.
(pty_conversation): Ditto.
(main): Use them.
(master, pty_name, old_tty, tty, old_tty_valid, tty_erase_char): New variables.
(flow_control, meta_key, _sobuf, in_conversation, quit_conversation): Ditto.
lisp/server.el (server-process-filter): Added support for opening a new terminal frame.
dispextern.h (get_frame_size): Renamed to get_tty_size, added tty_output parameter.
dispnew.c (Fredraw_frame): fflush the current terminal instead of stdout.
(direct_output_for_insert, direct_output_forward_char, update_frame_1): Ditto.
(Fding, bitch_at_user): Ditto.
(update_frame_1): Count pending output for current terminal instead of stdout.
(window_change_signal): Resize all terminals.
(change_frame_size): Don't resize all terminals to the same size.
frame.c (Vterminal_frame): Removed.
(syms_of_frame): Removed declaration of Vterminal_frame.
(make_terminal_frame): Set the top frame of the terminal to the new frame.
(Fmake_terminal_frame): Get a new frame size from get_tty_size, don't copy it.
(do_switch_frame): Handle terminal frame visibility.
(next_frame, prev_frame): Skip over frames on different terminals.
frame.h (Vterminal_frame): Removed.
keyboard.c (input_fd): Removed.
(read_avail_input): Removed first argument from read_socket_hook.
Try to read from each available tty, until one succeeds.
(Fsuspend_emacs): Don't suspend if there are multiple terminals.
lisp.h (get_frame_size): Removed superflous declaration.
xterm.c (Xtread_socket): Removed first parameter.
macterm.h (XTread_socket): Ditto.
w32inevt.c (w32_console_read_socket): Ditto.
w32term.c (w32_read_socket): Ditto.
sysdep.c (input_fd): Removed.
(change_input_fd): Removed.
(discard_tty_input): Discard pending input on _all_ input descriptors.
(stuff_char, tabs_safe_p): Use current terminal instead of input_fd.
(init_baud_rate, request_sigio, unrequest_sigio): Ditto.
(init_sys_modes, reset_sys_modes): Ditto.
(narrow_foreground_group, widen_foreground_group): Use stdin.
(init_sys_modes, reset_sys_modes): otty parameter renamed to tty_out.
(get_frame_size): Renamed to get_tty_size, added tty_out parameter.
term.c (read_socket_hook): Removed first parameter.
(clear_end_of_line): Use updating_frame, if possible.
(write_glyphs, insert_glyphs, ins_del_lines): Ditto.
(term_init): Renamed get_frame_size to get_tty_size.
termchar.h (struct tty_output): New entries: top_frame,
previous_terminal_frame.
termhooks.h (read_socket_hook): Removed first parameter.
window.c (init_window_once): Removed reference to Vterminal_frame.
xdisp.c (previous_terminal_frame): Moved to struct tty_output.
(redisplay_internal): Updated to use previous_terminal_frame in tty_output.
Allow for simultaneous refresh of multiple ttys.
git-archimport-id: lorentey@elte.hu--2004/emacs--multi-tty--0--patch-5
Diffstat (limited to 'src/frame.c')
| -rw-r--r-- | src/frame.c | 34 |
1 files changed, 24 insertions, 10 deletions
diff --git a/src/frame.c b/src/frame.c index 4a97befaf0e..7945ba0454b 100644 --- a/src/frame.c +++ b/src/frame.c | |||
| @@ -114,8 +114,6 @@ Lisp_Object Qfullscreen, Qfullwidth, Qfullheight, Qfullboth; | |||
| 114 | 114 | ||
| 115 | Lisp_Object Qface_set_after_frame_default; | 115 | Lisp_Object Qface_set_after_frame_default; |
| 116 | 116 | ||
| 117 | |||
| 118 | Lisp_Object Vterminal_frame; | ||
| 119 | Lisp_Object Vdefault_frame_alist; | 117 | Lisp_Object Vdefault_frame_alist; |
| 120 | Lisp_Object Vdefault_frame_scroll_bars; | 118 | Lisp_Object Vdefault_frame_scroll_bars; |
| 121 | Lisp_Object Vmouse_position_function; | 119 | Lisp_Object Vmouse_position_function; |
| @@ -550,6 +548,7 @@ make_terminal_frame (tty, tty_type) | |||
| 550 | f->output_data.tty = term_init (tty, tty_type); | 548 | f->output_data.tty = term_init (tty, tty_type); |
| 551 | else | 549 | else |
| 552 | f->output_data.tty = term_dummy_init (); | 550 | f->output_data.tty = term_dummy_init (); |
| 551 | f->output_data.tty->top_frame = frame; | ||
| 553 | #ifdef CANNOT_DUMP | 552 | #ifdef CANNOT_DUMP |
| 554 | FRAME_FOREGROUND_PIXEL(f) = FACE_TTY_DEFAULT_FG_COLOR; | 553 | FRAME_FOREGROUND_PIXEL(f) = FACE_TTY_DEFAULT_FG_COLOR; |
| 555 | FRAME_BACKGROUND_PIXEL(f) = FACE_TTY_DEFAULT_BG_COLOR; | 554 | FRAME_BACKGROUND_PIXEL(f) = FACE_TTY_DEFAULT_BG_COLOR; |
| @@ -637,12 +636,15 @@ Note that changing the size of one terminal frame automatically affects all. */ | |||
| 637 | type[SBYTES (tty_type)] = 0; | 636 | type[SBYTES (tty_type)] = 0; |
| 638 | } | 637 | } |
| 639 | 638 | ||
| 640 | |||
| 641 | f = make_terminal_frame (name, type); | 639 | f = make_terminal_frame (name, type); |
| 642 | } | 640 | } |
| 643 | 641 | ||
| 644 | change_frame_size (f, FRAME_LINES (sf), | 642 | { |
| 645 | FRAME_COLS (sf), 0, 0, 0); | 643 | int width, height; |
| 644 | get_tty_size (FRAME_TTY (f), &width, &height); | ||
| 645 | change_frame_size (f, height, width, 0, 0, 0); | ||
| 646 | } | ||
| 647 | |||
| 646 | adjust_glyphs (f); | 648 | adjust_glyphs (f); |
| 647 | calculate_costs (f); | 649 | calculate_costs (f); |
| 648 | XSETFRAME (frame, f); | 650 | XSETFRAME (frame, f); |
| @@ -746,6 +748,15 @@ do_switch_frame (frame, track, for_deletion) | |||
| 746 | if (!for_deletion && FRAME_HAS_MINIBUF_P (sf)) | 748 | if (!for_deletion && FRAME_HAS_MINIBUF_P (sf)) |
| 747 | resize_mini_window (XWINDOW (FRAME_MINIBUF_WINDOW (sf)), 1); | 749 | resize_mini_window (XWINDOW (FRAME_MINIBUF_WINDOW (sf)), 1); |
| 748 | 750 | ||
| 751 | if (FRAME_TERMCAP_P (XFRAME (selected_frame)) | ||
| 752 | && FRAME_TERMCAP_P (XFRAME (frame)) | ||
| 753 | && FRAME_TTY (XFRAME (selected_frame)) == FRAME_TTY (XFRAME (frame))) | ||
| 754 | { | ||
| 755 | XFRAME (selected_frame)->async_visible = 0; | ||
| 756 | XFRAME (frame)->async_visible = 1; | ||
| 757 | FRAME_TTY (XFRAME (frame))->top_frame = frame; | ||
| 758 | } | ||
| 759 | |||
| 749 | selected_frame = frame; | 760 | selected_frame = frame; |
| 750 | if (! FRAME_MINIBUF_ONLY_P (XFRAME (selected_frame))) | 761 | if (! FRAME_MINIBUF_ONLY_P (XFRAME (selected_frame))) |
| 751 | last_nonminibuf_frame = XFRAME (selected_frame); | 762 | last_nonminibuf_frame = XFRAME (selected_frame); |
| @@ -979,7 +990,10 @@ next_frame (frame, minibuf) | |||
| 979 | f = XCAR (tail); | 990 | f = XCAR (tail); |
| 980 | 991 | ||
| 981 | if (passed | 992 | if (passed |
| 982 | && FRAME_KBOARD (XFRAME (f)) == FRAME_KBOARD (XFRAME (frame))) | 993 | && ((!FRAME_TERMCAP_P (XFRAME (f)) && !FRAME_TERMCAP_P (XFRAME (frame)) |
| 994 | && FRAME_KBOARD (XFRAME (f)) == FRAME_KBOARD (XFRAME (frame))) | ||
| 995 | || (FRAME_TERMCAP_P (XFRAME (f)) && FRAME_TERMCAP_P (XFRAME (frame)) | ||
| 996 | && FRAME_TTY (XFRAME (f)) == FRAME_TTY (XFRAME (frame))))) | ||
| 983 | { | 997 | { |
| 984 | /* Decide whether this frame is eligible to be returned. */ | 998 | /* Decide whether this frame is eligible to be returned. */ |
| 985 | 999 | ||
| @@ -1056,7 +1070,10 @@ prev_frame (frame, minibuf) | |||
| 1056 | if (EQ (frame, f) && !NILP (prev)) | 1070 | if (EQ (frame, f) && !NILP (prev)) |
| 1057 | return prev; | 1071 | return prev; |
| 1058 | 1072 | ||
| 1059 | if (FRAME_KBOARD (XFRAME (f)) == FRAME_KBOARD (XFRAME (frame))) | 1073 | if ((!FRAME_TERMCAP_P (XFRAME (f)) && !FRAME_TERMCAP_P (XFRAME (frame)) |
| 1074 | && FRAME_KBOARD (XFRAME (f)) == FRAME_KBOARD (XFRAME (frame))) | ||
| 1075 | || (FRAME_TERMCAP_P (XFRAME (f)) && FRAME_TERMCAP_P (XFRAME (frame)) | ||
| 1076 | && FRAME_TTY (XFRAME (f)) == FRAME_TTY (XFRAME (frame)))) | ||
| 1060 | { | 1077 | { |
| 1061 | /* Decide whether this frame is eligible to be returned, | 1078 | /* Decide whether this frame is eligible to be returned, |
| 1062 | according to minibuf. */ | 1079 | according to minibuf. */ |
| @@ -4081,9 +4098,6 @@ Setting this variable does not affect existing frames, only new ones. */); | |||
| 4081 | = intern ("inhibit-default-face-x-resources"); | 4098 | = intern ("inhibit-default-face-x-resources"); |
| 4082 | staticpro (&Qinhibit_default_face_x_resources); | 4099 | staticpro (&Qinhibit_default_face_x_resources); |
| 4083 | 4100 | ||
| 4084 | DEFVAR_LISP ("terminal-frame", &Vterminal_frame, | ||
| 4085 | doc: /* The initial frame-object, which represents Emacs's stdout. */); | ||
| 4086 | |||
| 4087 | DEFVAR_LISP ("emacs-iconified", &Vemacs_iconified, | 4101 | DEFVAR_LISP ("emacs-iconified", &Vemacs_iconified, |
| 4088 | doc: /* Non-nil if all of emacs is iconified and frame updates are not needed. */); | 4102 | doc: /* Non-nil if all of emacs is iconified and frame updates are not needed. */); |
| 4089 | Vemacs_iconified = Qnil; | 4103 | Vemacs_iconified = Qnil; |