diff options
-rw-r--r-- | README.multi-tty | 13 | ||||
-rw-r--r-- | lisp/term/iris-ansi.el | 15 | ||||
-rw-r--r-- | lisp/term/lk201.el | 16 | ||||
-rw-r--r-- | lisp/term/rxvt.el | 99 |
4 files changed, 71 insertions, 72 deletions
diff --git a/README.multi-tty b/README.multi-tty index 7d0d420a0a7..b14f2a55157 100644 --- a/README.multi-tty +++ b/README.multi-tty @@ -386,19 +386,6 @@ is probably not very interesting for anyone else.) THINGS TO DO ------------ -** Go through lisp/term/*.el once more and protect terminal-local - initializations with '(when (eq 1 (length (frames-on-display-list)))' - as in xterm.el. This is to prevent resource allocation explosions - when C-x 5 2 is used repeatedly. - -** Dan Nicolaescu writes: - > The terminal initialization code still has some issues. - > This can be seen when using emacsclient -t on a 256 color xterm. The - > terminal frame is only created with 8 color. - > The reason is that terminal-init-xterm calls - > xterm-register-default-colors which calls (display-color-cells (selected-frame)) - > and probably `selected-frame' is not completely setup at that time. - ** emacsclient --no-wait and --eval is currently broken. ** xt-mouse.el needs to be adapted for multi-tty. It currently diff --git a/lisp/term/iris-ansi.el b/lisp/term/iris-ansi.el index 42f0912ed2f..d751ca69057 100644 --- a/lisp/term/iris-ansi.el +++ b/lisp/term/iris-ansi.el @@ -331,12 +331,15 @@ (defun terminal-init-iris-ansi () "Terminal initialization function for iris-ansi." - ;; Use inheritance to let the main keymap override these defaults. - ;; This way we don't override terminfo-derived settings or settings - ;; made in the .emacs file. - (let ((m (copy-keymap iris-function-map))) - (set-keymap-parent m (keymap-parent (terminal-local-value 'local-function-key-map nil))) - (set-keymap-parent (terminal-local-value 'local-function-key-map nil) m))) + ;; The terminal-local stuff only need to be set up on the first + ;; frame on that device. + (when (eq 1 (length (frames-on-display-list))) + ;; Use inheritance to let the main keymap override these defaults. + ;; This way we don't override terminfo-derived settings or settings + ;; made in the .emacs file. + (let ((m (copy-keymap iris-function-map))) + (set-keymap-parent m (keymap-parent (terminal-local-value 'local-function-key-map nil))) + (set-keymap-parent (terminal-local-value 'local-function-key-map nil) m)))) ;;; arch-tag: b1d0e73a-bb7d-47be-9fb2-6fb126469a1b ;;; iris-ansi.el ends here diff --git a/lisp/term/lk201.el b/lisp/term/lk201.el index 960793ce996..4eb84b65702 100644 --- a/lisp/term/lk201.el +++ b/lisp/term/lk201.el @@ -76,12 +76,16 @@ (define-key lk201-function-map "\eOy" [kp-9])) (defun terminal-init-lk201 () - ;; Use inheritance to let the main keymap override these defaults. - ;; This way we don't override terminfo-derived settings or settings - ;; made in the .emacs file. - (let ((m (copy-keymap lk201-function-map))) - (set-keymap-parent m (keymap-parent (terminal-local-value 'local-function-key-map nil))) - (set-keymap-parent (terminal-local-value 'local-function-key-map nil) m))) + ;; The terminal-local stuff only need to be set up on the first + ;; frame on that device. + (when (eq 1 (length (frames-on-display-list))) + + ;; Use inheritance to let the main keymap override these defaults. + ;; This way we don't override terminfo-derived settings or settings + ;; made in the .emacs file. + (let ((m (copy-keymap lk201-function-map))) + (set-keymap-parent m (keymap-parent (terminal-local-value 'local-function-key-map nil))) + (set-keymap-parent (terminal-local-value 'local-function-key-map nil) m)))) ;;; arch-tag: 7ffb4444-6a23-43e1-b457-43cf4f673c0d ;;; lk201.el ends here diff --git a/lisp/term/rxvt.el b/lisp/term/rxvt.el index 017dad2e7af..5729b670a16 100644 --- a/lisp/term/rxvt.el +++ b/lisp/term/rxvt.el @@ -119,53 +119,58 @@ (defun terminal-init-rxvt () "Terminal initialization function for rxvt." - ;; The terminal intialization C code file might have initialized - ;; function keys F11->F42 from the termcap/terminfo information. On - ;; a PC-style keyboard these keys correspond to - ;; MODIFIER-FUNCTION_KEY, where modifier is S-, C-, C-S-. The - ;; code here subsitutes the corresponding defintions in - ;; function-key-map. This substitution is needed because if a key - ;; definition if found in function-key-map, there are no further - ;; lookups in other keymaps. - (substitute-key-definition [f11] [S-f1] function-key-map) - (substitute-key-definition [f12] [S-f2] function-key-map) - (substitute-key-definition [f13] [S-f3] function-key-map) - (substitute-key-definition [f14] [S-f4] function-key-map) - (substitute-key-definition [f15] [S-f5] function-key-map) - (substitute-key-definition [f16] [S-f6] function-key-map) - (substitute-key-definition [f17] [S-f7] function-key-map) - (substitute-key-definition [f18] [S-f8] function-key-map) - (substitute-key-definition [f19] [S-f9] function-key-map) - (substitute-key-definition [f20] [S-f10] function-key-map) - - (substitute-key-definition [f23] [C-f1] function-key-map) - (substitute-key-definition [f24] [C-f2] function-key-map) - (substitute-key-definition [f25] [C-f3] function-key-map) - (substitute-key-definition [f26] [C-f4] function-key-map) - (substitute-key-definition [f27] [C-f5] function-key-map) - (substitute-key-definition [f28] [C-f6] function-key-map) - (substitute-key-definition [f29] [C-f7] function-key-map) - (substitute-key-definition [f30] [C-f8] function-key-map) - (substitute-key-definition [f31] [C-f9] function-key-map) - (substitute-key-definition [f32] [C-f10] function-key-map) - - (substitute-key-definition [f33] [C-S-f1] function-key-map) - (substitute-key-definition [f34] [C-S-f2] function-key-map) - (substitute-key-definition [f35] [C-S-f3] function-key-map) - (substitute-key-definition [f36] [C-S-f4] function-key-map) - (substitute-key-definition [f37] [C-S-f5] function-key-map) - (substitute-key-definition [f38] [C-S-f6] function-key-map) - (substitute-key-definition [f39] [C-S-f7] function-key-map) - (substitute-key-definition [f40] [C-S-f8] function-key-map) - (substitute-key-definition [f41] [C-S-f9] function-key-map) - (substitute-key-definition [f42] [C-S-f10] function-key-map) - - ;; Use inheritance to let the main keymap override those defaults. - ;; This way we don't override terminfo-derived settings or settings - ;; made in the .emacs file. - (let ((m (copy-keymap rxvt-function-map))) - (set-keymap-parent m (keymap-parent (terminal-local-value 'local-function-key-map nil))) - (set-keymap-parent (terminal-local-value 'local-function-key-map nil) m)) + + ;; The terminal-local stuff only need to be set up on the first + ;; frame on that device. + (when (eq 1 (length (frames-on-display-list))) + ;; The terminal intialization C code file might have initialized + ;; function keys F11->F42 from the termcap/terminfo information. On + ;; a PC-style keyboard these keys correspond to + ;; MODIFIER-FUNCTION_KEY, where modifier is S-, C-, C-S-. The + ;; code here subsitutes the corresponding defintions in + ;; function-key-map. This substitution is needed because if a key + ;; definition if found in function-key-map, there are no further + ;; lookups in other keymaps. + (let ((m (terminal-local-value 'local-function-key-map nil))) + (substitute-key-definition [f11] [S-f1] m) + (substitute-key-definition [f12] [S-f2] m) + (substitute-key-definition [f13] [S-f3] m) + (substitute-key-definition [f14] [S-f4] m) + (substitute-key-definition [f15] [S-f5] m) + (substitute-key-definition [f16] [S-f6] m) + (substitute-key-definition [f17] [S-f7] m) + (substitute-key-definition [f18] [S-f8] m) + (substitute-key-definition [f19] [S-f9] m) + (substitute-key-definition [f20] [S-f10] m) + + (substitute-key-definition [f23] [C-f1] m) + (substitute-key-definition [f24] [C-f2] m) + (substitute-key-definition [f25] [C-f3] m) + (substitute-key-definition [f26] [C-f4] m) + (substitute-key-definition [f27] [C-f5] m) + (substitute-key-definition [f28] [C-f6] m) + (substitute-key-definition [f29] [C-f7] m) + (substitute-key-definition [f30] [C-f8] m) + (substitute-key-definition [f31] [C-f9] m) + (substitute-key-definition [f32] [C-f10] m) + + (substitute-key-definition [f33] [C-S-f1] m) + (substitute-key-definition [f34] [C-S-f2] m) + (substitute-key-definition [f35] [C-S-f3] m) + (substitute-key-definition [f36] [C-S-f4] m) + (substitute-key-definition [f37] [C-S-f5] m) + (substitute-key-definition [f38] [C-S-f6] m) + (substitute-key-definition [f39] [C-S-f7] m) + (substitute-key-definition [f40] [C-S-f8] m) + (substitute-key-definition [f41] [C-S-f9] m) + (substitute-key-definition [f42] [C-S-f10] m)) + + ;; Use inheritance to let the main keymap override those defaults. + ;; This way we don't override terminfo-derived settings or settings + ;; made in the .emacs file. + (let ((m (copy-keymap rxvt-function-map))) + (set-keymap-parent m (keymap-parent (terminal-local-value 'local-function-key-map nil))) + (set-keymap-parent (terminal-local-value 'local-function-key-map nil) m))) ;; Initialize colors and background mode. (rxvt-register-default-colors) |