diff options
| author | Karoly Lorentey | 2003-12-25 06:59:31 +0000 |
|---|---|---|
| committer | Karoly Lorentey | 2003-12-25 06:59:31 +0000 |
| commit | 28d440abfe46139dff7278a444e0a35896038ff8 (patch) | |
| tree | 89805f4ff23e9d9b8c73dc0fdb43669d4f142d2f /src/scroll.c | |
| parent | 8a56675df17bbd27cf45bd60a2d6e94c8f2c2281 (diff) | |
| download | emacs-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.c | 9 |
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; |