Mercurial > emacs
comparison src/frame.c @ 82990:2ecd1f669db9
Fixed X support, preliminary support for X-tty combo sessions.
lib-src/emacsclient.c (copy_from_to, pty_conversation): Re-added SIGIO
hack. (Sigh.)
lisp/frame.el (make-frame-on-tty): Use make-terminal-frame, not
make-frame.
src/dispnew.c (line_hash_code, line_draw_cost): Updated to use
the new display_method parameters.
(Fredraw_frame): fflush the tty only if f is a termcap frame.
(direct_output_for_insert): Updated to use the new display_method
parameters. fflush the tty only if f is a termcap frame.
(direct_output_forward_char, update_frame_1, scrolling): Ditto.
(update_frame_line, Fding, bitch_at_user): Ditto.
(Fsend_string_to_terminal): Fail if current frame is not on a tty.
(init_display): Frame size change is safe here.
src/frame.c (Vterminal_frame): Restored previously deleted variable.
(syms_of_frame): Initialize it.
(make_terminal_frame): Copy the frame's display_method from tty_display_info.
(Fmake_terminal_frame): Enable simultaneous X and tty frames (buggy).
(Fredirect_frame_focus): Don't call frame_rehighlight_hook if frame
is on a termcap device.
src/frame.h (struct frame): Renamed display to display_method.
(Vterminal_frame): Re-added declaration.
src/keyboard.c (flow_control): Moved to struct tty_display_info.
(read_avail_input): Check ttys even if there is a read_socket_hook.
(Fset_input_mode): Call reset_sys_modes/init_sys_modes and set
flow_control or meta_key only when the frame is a termcap frame.
(Fcurrent_input_mode): Handle flow_control and meta_key right on
non-termcap frames.
src/scroll.c (calculate_scrolling, calculate_direct_scrolling): Update
to use the new display_method parameters.
(scrolling_1, scroll_cost): Ditto.
src/sysdep.c (init_sys_modes, reset_sys_modes): Always set the
terminal parameters if tty_out->input is not stdin. Updated to the
new location of flow_control.
(hft_init): Moved HFT init code to term_init, as it needs the frame.
src/term.c (tty_display_method_template): New variable.
(update_begin): Added rif hack.
(set_terminal_window, ins_del_lines, term_init): Updated to use the
new display_method parameters.
(insert_glyphs, ins_del_lines): Only call insert_glyphs_hook if the
current frame is not on a tty.
(calculate_costs): Don't calculate costs if not on a tty.
(term_dummy_init): Fixed tty->output initialization. Preallocate Wcm
and display_method.
(term_init): Allocate & initialize display_method. Blindly fixed
WINDOWSNT-specific parts. Added HFT-specific initialization
exception from hft_init.
(delete_tty): Only delete termcap frames. Free() the display_method.
src/termchar.h (struct tty_display_info): Moved high-level terminal
characteristics to struct display_method. Added flow_control and
display_method members.
src/termhooks.h (struct display_method): New struct (renamed from
struct device). Added accessor macros.
src/window.c (init_window_once): Initialize Vterminal_frame.
src/xdisp.c (init_iterator, expose_frame): Added rif hack.
(try_window_id): Updated to use the new display_method parameters.
src/xfaces.c (realize_basic_faces): Don't call
x_update_menu_appearance if the frame is a tty frame.
src/xfns.c (Fx_create_frame): Added rif hack. Initialize
display_method.
(x_create_tip_frame): Initialize display_method.
src/xterm.c (x_display_method): New variable.
(x_flush, x_frame_of_widget, XTmouse_position): Ignore non-X frames.
(x_window_to_scroll_bar, x_window_to_menu_bar): Ditto.
(xim_destroy_callback, xim_instantiate_callback): Ditto.
(frame_highlight, frame_unhighlight): Added rif hack.
(x_initialize): Don't initialize rif. Do initialize x_display_method.
src/xterm.h (x_display_method): New declaration.
git-archimport-id: lorentey@elte.hu--2004/emacs--multi-tty--0--patch-30
author | Karoly Lorentey <lorentey@elte.hu> |
---|---|
date | Fri, 02 Jan 2004 01:15:26 +0000 |
parents | f3845715a5f6 |
children | 2b26656ff804 |
comparison
equal
deleted
inserted
replaced
82989:f3845715a5f6 | 82990:2ecd1f669db9 |
---|---|
112 | 112 |
113 Lisp_Object Qfullscreen, Qfullwidth, Qfullheight, Qfullboth; | 113 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 Lisp_Object Vterminal_frame; | |
117 Lisp_Object Vdefault_frame_alist; | 118 Lisp_Object Vdefault_frame_alist; |
118 Lisp_Object Vdefault_frame_scroll_bars; | 119 Lisp_Object Vdefault_frame_scroll_bars; |
119 Lisp_Object Vmouse_position_function; | 120 Lisp_Object Vmouse_position_function; |
120 Lisp_Object Vmouse_highlight; | 121 Lisp_Object Vmouse_highlight; |
121 Lisp_Object Vdelete_frame_functions; | 122 Lisp_Object Vdelete_frame_functions; |
122 | 123 |
123 static void | 124 static void |
124 set_menu_bar_lines_1 (window, n) | 125 set_menu_bar_lines_1 (window, n) |
125 Lisp_Object window; | 126 Lisp_Object window; |
126 int n; | 127 int n; |
127 { | 128 { |
128 struct window *w = XWINDOW (window); | 129 struct window *w = XWINDOW (window); |
129 | 130 |
130 XSETFASTINT (w->last_modified, 0); | 131 XSETFASTINT (w->last_modified, 0); |
131 XSETFASTINT (w->top_line, XFASTINT (w->top_line) + n); | 132 XSETFASTINT (w->top_line, XFASTINT (w->top_line) + n); |
563 { | 564 { |
564 /* init_display() will reinitialize the terminal with correct values after dump. */ | 565 /* init_display() will reinitialize the terminal with correct values after dump. */ |
565 f->output_data.tty->display_info = term_dummy_init (); | 566 f->output_data.tty->display_info = term_dummy_init (); |
566 } | 567 } |
567 FRAME_TTY (f)->reference_count++; | 568 FRAME_TTY (f)->reference_count++; |
569 f->display_method = FRAME_TTY (f)->display_method; | |
568 } | 570 } |
569 | 571 |
570 #ifdef CANNOT_DUMP | 572 #ifdef CANNOT_DUMP |
571 FRAME_FOREGROUND_PIXEL(f) = FACE_TTY_DEFAULT_FG_COLOR; | 573 FRAME_FOREGROUND_PIXEL(f) = FACE_TTY_DEFAULT_FG_COLOR; |
572 FRAME_BACKGROUND_PIXEL(f) = FACE_TTY_DEFAULT_BG_COLOR; | 574 FRAME_BACKGROUND_PIXEL(f) = FACE_TTY_DEFAULT_BG_COLOR; |
612 | 614 |
613 #ifdef MAC_OS | 615 #ifdef MAC_OS |
614 if (sf->output_method != output_mac) | 616 if (sf->output_method != output_mac) |
615 error ("Not running on a Macintosh screen; cannot make a new Macintosh frame"); | 617 error ("Not running on a Macintosh screen; cannot make a new Macintosh frame"); |
616 #else | 618 #else |
619 #if 0 /* This should work now! */ | |
617 if (sf->output_method != output_termcap) | 620 if (sf->output_method != output_termcap) |
618 error ("Not using an ASCII terminal now; cannot make a new ASCII frame"); | 621 error ("Not using an ASCII terminal now; cannot make a new ASCII frame"); |
622 #endif | |
619 #endif | 623 #endif |
620 #endif /* not MSDOS */ | 624 #endif /* not MSDOS */ |
621 | 625 |
622 { | 626 { |
623 Lisp_Object tty, tty_type; | 627 Lisp_Object tty, tty_type; |
1907 if (! NILP (focus_frame)) | 1911 if (! NILP (focus_frame)) |
1908 CHECK_LIVE_FRAME (focus_frame); | 1912 CHECK_LIVE_FRAME (focus_frame); |
1909 | 1913 |
1910 XFRAME (frame)->focus_frame = focus_frame; | 1914 XFRAME (frame)->focus_frame = focus_frame; |
1911 | 1915 |
1912 if (frame_rehighlight_hook) | 1916 if (!FRAME_TERMCAP_P (XFRAME (frame)) && frame_rehighlight_hook) |
1913 (*frame_rehighlight_hook) (XFRAME (frame)); | 1917 (*frame_rehighlight_hook) (XFRAME (frame)); |
1914 | 1918 |
1915 return Qnil; | 1919 return Qnil; |
1916 } | 1920 } |
1917 | 1921 |
4135 | 4139 |
4136 Qinhibit_default_face_x_resources | 4140 Qinhibit_default_face_x_resources |
4137 = intern ("inhibit-default-face-x-resources"); | 4141 = intern ("inhibit-default-face-x-resources"); |
4138 staticpro (&Qinhibit_default_face_x_resources); | 4142 staticpro (&Qinhibit_default_face_x_resources); |
4139 | 4143 |
4144 DEFVAR_LISP ("terminal-frame", &Vterminal_frame, | |
4145 doc: /* The initial frame-object, which represents Emacs's stdout. */); | |
4146 | |
4140 DEFVAR_LISP ("emacs-iconified", &Vemacs_iconified, | 4147 DEFVAR_LISP ("emacs-iconified", &Vemacs_iconified, |
4141 doc: /* Non-nil if all of emacs is iconified and frame updates are not needed. */); | 4148 doc: /* Non-nil if all of emacs is iconified and frame updates are not needed. */); |
4142 Vemacs_iconified = Qnil; | 4149 Vemacs_iconified = Qnil; |
4143 | 4150 |
4144 DEFVAR_LISP ("mouse-position-function", &Vmouse_position_function, | 4151 DEFVAR_LISP ("mouse-position-function", &Vmouse_position_function, |