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,