aboutsummaryrefslogtreecommitdiffstats
path: root/src/frame.c
diff options
context:
space:
mode:
authorKaroly Lorentey2003-12-26 04:24:54 +0000
committerKaroly Lorentey2003-12-26 04:24:54 +0000
commit9628b8878f46b2b7eeeb4f272d20f2e64de19f4a (patch)
treecfccb4da4a6b898780d3bc9856b377fd5d85e4e6 /src/frame.c
parent4f0359deff8eb9ec9ed95e75d77a0dd59f39428c (diff)
downloademacs-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.c34
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
115Lisp_Object Qface_set_after_frame_default; 115Lisp_Object Qface_set_after_frame_default;
116 116
117
118Lisp_Object Vterminal_frame;
119Lisp_Object Vdefault_frame_alist; 117Lisp_Object Vdefault_frame_alist;
120Lisp_Object Vdefault_frame_scroll_bars; 118Lisp_Object Vdefault_frame_scroll_bars;
121Lisp_Object Vmouse_position_function; 119Lisp_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;