aboutsummaryrefslogtreecommitdiffstats
path: root/src/scroll.c
diff options
context:
space:
mode:
authorKaroly Lorentey2003-12-25 06:59:31 +0000
committerKaroly Lorentey2003-12-25 06:59:31 +0000
commit28d440abfe46139dff7278a444e0a35896038ff8 (patch)
tree89805f4ff23e9d9b8c73dc0fdb43669d4f142d2f /src/scroll.c
parent8a56675df17bbd27cf45bd60a2d6e94c8f2c2281 (diff)
downloademacs-28d440abfe46139dff7278a444e0a35896038ff8.tar.gz
emacs-28d440abfe46139dff7278a444e0a35896038ff8.zip
Implemented multiple tty support.
README.multi-tty: New file. src/termchar.h (struct terminal): Renamed to struct tty_output. Added name, type, input, output, termscript, old_tty, term_initted, old_tty_valid, background_pixel, foreground_pixel, next fields. (TERMINAL_*): Renamed to TTY_* for brevity. (CURRENT_TERMINAL): Renamed to CURTTY for brevity. (tty_list): New variable. (TERMINAL_PTR): Removed. (FRAME_TTY): New function. (TTY_NAME, TTY_TYPE): New macros. src/term.c (current_terminal): Removed. (_current_terminal): Removed. (tty_list): New variable. (OUTPUT, OUTPUT1, OUTPUTL, OUTPUT_IF, OUTPUT1_IF): Added tty parameter. (set_terminal_modes): Added tty parameter. (reset_terminal_modes): Added tty parameter. (cursor_to, raw_cursor_to): Updated cmgoto() calls. (clear_end_of_line, write_glyphs): Add indirection to terminal output, updated cmcheckmagic() calls. (get_named_tty): New function. (term_dummy_init): New function. (term_init): Added name parameter, added tty_output return value. Changed algorithm to update tty_list. Call init_sys_modes() to set up tty mode on the newly opened terminal device. (get_current_tty): New function, intended for debugging. src/termhooks.h (termscript): Removed. src/w32term.h (FRAME_FOREGROUND_PIXEL, FRAME_BACKGROUND_PIXEL): Removed redundant definition. src/macterm.h (FRAME_FOREGROUND_PIXEL, FRAME_BACKGROUND_PIXEL): Ditto. src/window.c (init_window_once): Call make_terminal_frame with two zero parameters. src/cm.h (emacs_tputs): New macro to set current_tty, and then call tputs(). (current_tty): New variable, for cmputc(). (cmcheckmagic, cmputc, cmgoto): Added prototypes. src/cm.c (current_tty): New variable, for cmputc(). (cmputc): Use it. (cmcheckmagic): Added tty parameter, look up terminal streams there. (calccost): Added tty parameter. Use emacs_tputs() instead of tputs(). (cmgoto): Added tty parameter. Pass it on to calccost(). Use emacs_tputs() instead of tputs(). src/dispextern.h (set_terminal_modes, reset_terminal_modes): Added tty parameter. (term_init): Added name parameter (the filename of the terminal device). Added return value (struct tty_output). src/dispnew.c: Replace CURTTY() with local variables throughout the file (where applicable). (termscript): Moved to struct tty_output. (terminal_type): Removed. src/emacs.c (main): Don't call init_sys_modes(), the new term_init() already does that during init_display(). (shut_down_emacs): Call reset_all_sys_modes() instead of reset_sys_modes(). src/frame.c (Qtty, Qtty_type): New variables. (syms_of_frame): Initialize them. (tty_display): Removed. (make_terminal_frame): New parameters (tty filename and type). Initialize output_data.tty field instead of output_data.x. Use term_init() to find the right tty_output. (Use term_dummy_init() during bootstrap.) (Fmake_terminal_frame): Get device filename and type from frame parameters. src/frame.h (FRAME_FOREGROUND_PIXEL, FRAME_BACKGROUND_PIXEL): Do the right thing if the frame is a tty. (struct frame): New member in output_data: tty. (make_terminal_frame): Updated of prototype. src/keyboard.c (Fset_input_mode): Call reset_all_sys_modes(), not reset_sys_modes(). Ditto with init_sys_modes(). src/lisp.h (tty_output): Added forward declaration. (init_sys_modes, reset_sys_modes): Updated prototype. (init_all_sys_modes, reset_all_sys_modes): New prototypes. src/scroll.c: Replace CURTTY() with local variables throughout the file (where applicable). src/sysdep.c (old_tty, term_initted, old_tty_valid): Moved to struct tty_output.( (init_all_sys_modes): New function. (init_sys_modes): Added tty_output parameter. Use it. (reset_all_sys_modes): New function. (reset_sys_modes): Added tty_output parameter. Use it. src/Makefile.in: Update dependencies. git-archimport-id: lorentey@elte.hu--2004/emacs--multi-tty--0--patch-2
Diffstat (limited to 'src/scroll.c')
-rw-r--r--src/scroll.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/scroll.c b/src/scroll.c
index a786d3c2cf4..f4faca2fad8 100644
--- a/src/scroll.c
+++ b/src/scroll.c
@@ -22,6 +22,7 @@ Boston, MA 02111-1307, USA. */
22#include <config.h> 22#include <config.h>
23#include <stdio.h> 23#include <stdio.h>
24#include <string.h> 24#include <string.h>
25#include "systty.h" /* For emacs_tty in termchar.h */
25#include "termchar.h" 26#include "termchar.h"
26#include "lisp.h" 27#include "lisp.h"
27#include "dispextern.h" 28#include "dispextern.h"
@@ -101,7 +102,7 @@ calculate_scrolling (frame, matrix, window_size, lines_below,
101 register int cost, cost1; 102 register int cost, cost1;
102 103
103 int lines_moved = window_size 104 int lines_moved = window_size
104 + (TERMINAL_SCROLL_REGION_OK (CURRENT_TERMINAL ()) ? 0 : lines_below); 105 + (TTY_SCROLL_REGION_OK (FRAME_TTY (frame)) ? 0 : lines_below);
105 /* first_insert_cost[I] is the cost of doing the first insert-line 106 /* first_insert_cost[I] is the cost of doing the first insert-line
106 at the i'th line of the lines we are considering, 107 at the i'th line of the lines we are considering,
107 where I is origin 1 (as it is below). */ 108 where I is origin 1 (as it is below). */
@@ -468,7 +469,7 @@ calculate_direct_scrolling (frame, matrix, window_size, lines_below,
468 cost of scrolling by a distance of one. The extra cost is 469 cost of scrolling by a distance of one. The extra cost is
469 added once for consistency with the cost vectors */ 470 added once for consistency with the cost vectors */
470 scroll_overhead 471 scroll_overhead
471 = TERMINAL_SCROLL_REGION_COST (CURRENT_TERMINAL ()) + extra_cost; 472 = TTY_SCROLL_REGION_COST (FRAME_TTY (frame)) + extra_cost;
472 473
473 /* initialize the top left corner of the matrix */ 474 /* initialize the top left corner of the matrix */
474 matrix->writecost = 0; 475 matrix->writecost = 0;
@@ -820,7 +821,7 @@ scrolling_1 (frame, window_size, unchanged_at_top, unchanged_at_bottom,
820 matrix = ((struct matrix_elt *) 821 matrix = ((struct matrix_elt *)
821 alloca ((window_size + 1) * (window_size + 1) * sizeof *matrix)); 822 alloca ((window_size + 1) * (window_size + 1) * sizeof *matrix));
822 823
823 if (TERMINAL_SCROLL_REGION_OK (CURRENT_TERMINAL ())) 824 if (TTY_SCROLL_REGION_OK (FRAME_TTY (frame)))
824 { 825 {
825 calculate_direct_scrolling (frame, matrix, window_size, 826 calculate_direct_scrolling (frame, matrix, window_size,
826 unchanged_at_bottom, 827 unchanged_at_bottom,
@@ -916,7 +917,7 @@ scroll_cost (frame, from, to, amount)
916 if (amount == 0) 917 if (amount == 0)
917 return 0; 918 return 0;
918 919
919 if (! TERMINAL_SCROLL_REGION_OK (CURRENT_TERMINAL ())) 920 if (! TTY_SCROLL_REGION_OK (FRAME_TTY (frame)))
920 limit = height; 921 limit = height;
921 else if (amount > 0) 922 else if (amount > 0)
922 limit += amount; 923 limit += amount;