comparison src/scroll.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 33c3c7c16e13
children 7900111db01c
comparison
equal deleted inserted replaced
82989:f3845715a5f6 82990:2ecd1f669db9
27 #include "termchar.h" 27 #include "termchar.h"
28 #include "dispextern.h" 28 #include "dispextern.h"
29 #include "keyboard.h" 29 #include "keyboard.h"
30 #include "frame.h" 30 #include "frame.h"
31 #include "window.h" 31 #include "window.h"
32 #include "termhooks.h"
32 33
33 /* All costs measured in characters. 34 /* All costs measured in characters.
34 So no cost can exceed the area of a frame, measured in characters. 35 So no cost can exceed the area of a frame, measured in characters.
35 Let's hope this is never more than 1000000 characters. */ 36 Let's hope this is never more than 1000000 characters. */
36 37
100 int frame_lines = FRAME_LINES (frame); 101 int frame_lines = FRAME_LINES (frame);
101 register struct matrix_elt *p, *p1; 102 register struct matrix_elt *p, *p1;
102 register int cost, cost1; 103 register int cost, cost1;
103 104
104 int lines_moved = window_size 105 int lines_moved = window_size
105 + (TTY_SCROLL_REGION_OK (FRAME_TTY (frame)) ? 0 : lines_below); 106 + (FRAME_SCROLL_REGION_OK (frame) ? 0 : lines_below);
106 /* first_insert_cost[I] is the cost of doing the first insert-line 107 /* first_insert_cost[I] is the cost of doing the first insert-line
107 at the i'th line of the lines we are considering, 108 at the i'th line of the lines we are considering,
108 where I is origin 1 (as it is below). */ 109 where I is origin 1 (as it is below). */
109 int *first_insert_cost 110 int *first_insert_cost
110 = &FRAME_INSERT_COST (frame)[frame_lines - 1 - lines_moved]; 111 = &FRAME_INSERT_COST (frame)[frame_lines - 1 - lines_moved];
467 468
468 /* Overhead of setting the scroll window, plus the extra cost 469 /* Overhead of setting the scroll window, plus the extra cost
469 cost of scrolling by a distance of one. The extra cost is 470 cost of scrolling by a distance of one. The extra cost is
470 added once for consistency with the cost vectors */ 471 added once for consistency with the cost vectors */
471 scroll_overhead 472 scroll_overhead
472 = TTY_SCROLL_REGION_COST (FRAME_TTY (frame)) + extra_cost; 473 = FRAME_SCROLL_REGION_COST (frame) + extra_cost;
473 474
474 /* initialize the top left corner of the matrix */ 475 /* initialize the top left corner of the matrix */
475 matrix->writecost = 0; 476 matrix->writecost = 0;
476 matrix->insertcost = INFINITY; 477 matrix->insertcost = INFINITY;
477 matrix->deletecost = INFINITY; 478 matrix->deletecost = INFINITY;
819 { 820 {
820 struct matrix_elt *matrix; 821 struct matrix_elt *matrix;
821 matrix = ((struct matrix_elt *) 822 matrix = ((struct matrix_elt *)
822 alloca ((window_size + 1) * (window_size + 1) * sizeof *matrix)); 823 alloca ((window_size + 1) * (window_size + 1) * sizeof *matrix));
823 824
824 if (TTY_SCROLL_REGION_OK (FRAME_TTY (frame))) 825 if (FRAME_SCROLL_REGION_OK (frame))
825 { 826 {
826 calculate_direct_scrolling (frame, matrix, window_size, 827 calculate_direct_scrolling (frame, matrix, window_size,
827 unchanged_at_bottom, 828 unchanged_at_bottom,
828 draw_cost, old_draw_cost, 829 draw_cost, old_draw_cost,
829 old_hash, new_hash, free_at_end); 830 old_hash, new_hash, free_at_end);
915 int height = FRAME_LINES (frame); 916 int height = FRAME_LINES (frame);
916 917
917 if (amount == 0) 918 if (amount == 0)
918 return 0; 919 return 0;
919 920
920 if (! TTY_SCROLL_REGION_OK (FRAME_TTY (frame))) 921 if (! FRAME_SCROLL_REGION_OK (frame))
921 limit = height; 922 limit = height;
922 else if (amount > 0) 923 else if (amount > 0)
923 limit += amount; 924 limit += amount;
924 925
925 if (amount < 0) 926 if (amount < 0)