Mercurial > emacs
annotate lisp/term/tvi970.el @ 112304:9539682ee916
Use gnulib's ftoastr module.
author | Paul Eggert <eggert@cs.ucla.edu> |
---|---|
date | Sat, 08 Jan 2011 17:18:39 -0800 |
parents | dc6153a5f4f7 |
children | 417b1e4d63cd |
rev | line source |
---|---|
2141
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
1 ;;; tvi970.el --- terminal support for the Televideo 970 |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
2 |
74509 | 3 ;; Copyright (C) 1992, 2001, 2002, 2003, 2004, 2005, |
106815 | 4 ;; 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. |
74509 | 5 |
100544 | 6 ;; Author: Jim Blandy <jimb@occs.cs.oberlin.edu> |
2141
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
7 ;; Keywords: terminals |
100544 | 8 ;; Created: January 1992 |
2141
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
9 |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
10 ;; This file is part of GNU Emacs. |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
11 |
94671
f3ab0c2464f5
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
12 ;; GNU Emacs is free software: you can redistribute it and/or modify |
2141
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
13 ;; it under the terms of the GNU General Public License as published by |
94671
f3ab0c2464f5
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
14 ;; the Free Software Foundation, either version 3 of the License, or |
f3ab0c2464f5
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
15 ;; (at your option) any later version. |
530 | 16 |
2141
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
17 ;; GNU Emacs is distributed in the hope that it will be useful, |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
20 ;; GNU General Public License for more details. |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
21 |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
22 ;; You should have received a copy of the GNU General Public License |
94671
f3ab0c2464f5
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
23 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. |
2141
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
24 |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
25 ;;; Commentary: |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
26 |
14170 | 27 ;; Uses the Emacs 19 terminal initialization features --- won't work with 18. |
2141
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
28 |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
29 ;;; Code: |
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
30 |
108242
dc6153a5f4f7
Use define-minor-mode in more cases.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106815
diff
changeset
|
31 (eval-when-compile (require 'cl)) |
dc6153a5f4f7
Use define-minor-mode in more cases.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106815
diff
changeset
|
32 |
85549
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
33 (defvar tvi970-terminal-map |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
34 (let ((map (make-sparse-keymap))) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
35 |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
36 ;; Miscellaneous keys |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
37 (dolist (key-binding |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
38 '(;; These are set up by termcap or terminfo |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
39 ;; ("\eOP" [kp-f1]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
40 ;; ("\eOQ" [kp-f2]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
41 ;; ("\eOR" [kp-f3]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
42 ;; ("\eOS" [kp-f4]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
43 |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
44 ;; These might bre set by terminfo. |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
45 ("\e[H" [home]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
46 ("\e[Z" [backtab]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
47 ("\e[i" [print]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
48 ("\e[@" [insert]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
49 ("\e[L" [insertline]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
50 ("\e[M" [deleteline]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
51 ("\e[U" [next]) ;; actually the `page' key |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
52 |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
53 ;; These won't be set up by either |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
54 ("\eOm" [kp-subtract]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
55 ("\eOl" [kp-separator]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
56 ("\eOn" [kp-decimal]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
57 ("\eOM" [kp-enter]) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
58 |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
59 ;; These won't be set up by either either |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
60 ("\e[K" [key_eol]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
61 ("\e[J" [key_eos]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
62 ("\e[2J" [key_clear]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
63 ("\e[P" [key_dc]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
64 ("\e[g" [S-tab]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
65 ("\e[2N" [clearentry]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
66 ("\e[2K" [S-clearentry]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
67 ("\e[E" [?\C-j]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
68 ("\e[g" [S-backtab]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
69 ("\e[?1i" [key_sprint]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
70 ("\e[4h" [key_sic]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
71 ("\e[4l" [S-delete]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
72 ("\e[Q" [S-insertline]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
73 ("\e[1Q" [key_sdl]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
74 ("\e[19l" [key_seol]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
75 ("\e[19h" [S-erasepage]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
76 ("\e[V" [S-page]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
77 ("\eS" [send]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
78 ("\e5" [S-send]) ;; Not an X keysym |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
79 )) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
80 (define-key map (car key-binding) (nth 1 key-binding))) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
81 |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
82 |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
83 ;; The numeric keypad keys. |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
84 (dotimes (i 10) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
85 (define-key map (format "\eO%c" (+ i ?p)) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
86 (vector (intern (format "kp-%d" i))))) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
87 ;; The numbered function keys. |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
88 (dotimes (i 16) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
89 (define-key map (format "\e?%c" (+ i ?a)) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
90 (vector (intern (format "f%d" (1+ i))))) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
91 (define-key map (format "\e?%c" (+ i ?A)) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
92 (vector (intern (format "S-f%d" (1+ i)))))) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
93 map)) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
94 |
64651
af1c58687bdd
* term/apollo.el (terminal-init-apollo): New function containing
Dan Nicolaescu <dann@ics.uci.edu>
parents:
64084
diff
changeset
|
95 (defun terminal-init-tvi970 () |
af1c58687bdd
* term/apollo.el (terminal-init-apollo): New function containing
Dan Nicolaescu <dann@ics.uci.edu>
parents:
64084
diff
changeset
|
96 "Terminal initialization function for tvi970." |
85549
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
97 ;; Use inheritance to let the main keymap override these defaults. |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
98 ;; This way we don't override terminfo-derived settings or settings |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
99 ;; made in the .emacs file. |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
100 (let ((m (copy-keymap tvi970-terminal-map))) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
101 (set-keymap-parent m (keymap-parent input-decode-map)) |
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
102 (set-keymap-parent input-decode-map m)) |
64651
af1c58687bdd
* term/apollo.el (terminal-init-apollo): New function containing
Dan Nicolaescu <dann@ics.uci.edu>
parents:
64084
diff
changeset
|
103 (tvi970-set-keypad-mode 1)) |
2141
9bc89a98c002
Added headers, changes some keycap names.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
530
diff
changeset
|
104 |
530 | 105 |
85549
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
106 ;; Should keypad numbers send ordinary digits or distinct escape sequences? |
108242
dc6153a5f4f7
Use define-minor-mode in more cases.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106815
diff
changeset
|
107 (define-minor-mode tvi970-set-keypad-mode |
530 | 108 "Set the current mode of the TVI 970 numeric keypad. |
109 In ``numeric keypad mode'', the number keys on the keypad act as | |
110 ordinary digits. In ``alternate keypad mode'', the keys send distinct | |
111 escape sequences, meaning that they can have their own bindings, | |
112 independent of the normal number keys. | |
113 With no argument, toggle between the two possible modes. | |
114 With a positive argument, select alternate keypad mode. | |
115 With a negative argument, select numeric keypad mode." | |
108242
dc6153a5f4f7
Use define-minor-mode in more cases.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106815
diff
changeset
|
116 :variable (terminal-parameter nil 'tvi970-keypad-numeric) |
dc6153a5f4f7
Use define-minor-mode in more cases.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106815
diff
changeset
|
117 (send-string-to-terminal |
dc6153a5f4f7
Use define-minor-mode in more cases.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106815
diff
changeset
|
118 (if (terminal-parameter nil 'tvi970-keypad-numeric) "\e=" "\e>"))) |
530 | 119 |
85549
efbb484c3a9d
(tvi970-terminal-map): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
84795
diff
changeset
|
120 ;; arch-tag: c1334cf0-1462-41c3-a963-c077d175f8f0 |
38436
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
14170
diff
changeset
|
121 ;;; tvi970.el ends here |