0
+ − 1 ;;; wyse50.el --- terminal support code for Wyse 50
+ − 2
+ − 3 ;; Copyright (C) 1989, 1993, 1994 Free Software Foundation, Inc.
+ − 4
+ − 5 ;; Author: Daniel Pfieffer <pfieffer@cix.cict.fr> January 1991
+ − 6 ;; Jim Blandy <jimb@occs.cs.oberlin.edu>
+ − 7 ;; Keywords: terminals
+ − 8
+ − 9 ;;; This file is part of GNU Emacs.
+ − 10 ;;;
+ − 11 ;;; GNU Emacs is free software; you can redistribute it and/or modify
+ − 12 ;;; it under the terms of the GNU General Public License as published by
+ − 13 ;;; the Free Software Foundation; either version 2, or (at your option)
+ − 14 ;;; any later version.
+ − 15 ;;;
+ − 16 ;;; GNU Emacs is distributed in the hope that it will be useful,
+ − 17 ;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+ − 18 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ − 19 ;;; GNU General Public License for more details.
+ − 20 ;;;
+ − 21 ;;; You should have received a copy of the GNU General Public License
+ − 22 ;;; along with GNU Emacs; see the file COPYING. If not, write to
+ − 23 ;;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
+ − 24
+ − 25 ;;; Commentary:
+ − 26
+ − 27 ;; Uses the Emacs 19 terminal initialization features --- won't work with 18.
+ − 28 ;; Rewritten for Emacs 19 by jimb, January 1992
+ − 29 ;; Cleaned up for new terminal package conventions by esr, March 1993
+ − 30 ;; Should work well for Televideo TVI 925 although it's overkill.
+ − 31 ;;
+ − 32 ;; The Wyse50 is ergonomically wonderful, but its escape-sequence design sucks
+ − 33 ;; rocks. The left-arrow key emits a backspace (!) and the down-arrow a line
+ − 34 ;; feed (!!). Thus, you have to unbind some commonly-used Emacs keys to
+ − 35 ;; enable the arrows.
+ − 36
+ − 37 ;;; Code:
+ − 38
+ − 39 (define-key function-key-map "\C-a" (make-keymap))
+ − 40 (mapcar (function (lambda (key-definition)
+ − 41 (define-key function-key-map
+ − 42 (car key-definition) (nth 1 key-definition))))
+ − 43 '(
+ − 44 ;; These might be set up by termcap and terminfo
+ − 45 ("\C-k" [up])
+ − 46 ("\C-j" [down])
+ − 47 ("\C-l" [right])
+ − 48 ("\C-h" [left])
+ − 49 ("\^a@\^m" [f1])
+ − 50 ("\^aA\^m" [f2])
+ − 51 ("\^aB\^m" [f3])
+ − 52 ("\^aC\^m" [f4])
+ − 53 ("\^aD\^m" [f5])
+ − 54 ("\^aE\^m" [f6])
+ − 55 ("\^aF\^m" [f7])
+ − 56 ("\^aG\^m" [f8])
+ − 57 ("\^aH\^m" [f9])
+ − 58
+ − 59 ;; These might be set up by terminfo
+ − 60 ("\eK" [next])
+ − 61 ("\eT" [clearline])
+ − 62 ("\^^" [home])
+ − 63 ("\e\^^" [end])
+ − 64 ("\eQ" [insert])
+ − 65 ("\eE" [insertline])
+ − 66 ("\eR" [deleteline])
+ − 67 ("\eP" [print])
+ − 68 ("\er" [replace])
+ − 69 ("\^aI\^m" [f10])
+ − 70 ("\^aJ\^m" [f11])
+ − 71 ("\^aK\^m" [f12])
+ − 72 ("\^aL\^m" [f13])
+ − 73 ("\^aM\^m" [f14])
+ − 74 ("\^aN\^m" [f15])
+ − 75 ("\^aO\^m" [f16])
+ − 76 ("\^a`\^m" [f17])
+ − 77 ("\^aa\^m" [f18])
+ − 78 ("\^ab\^m" [f19])
+ − 79 ("\^ac\^m" [f20])
+ − 80 ("\^ad\^m" [f21])
+ − 81 ("\^ae\^m" [f22])
+ − 82 ("\^af\^m" [f23])
+ − 83 ("\^ag\^m" [f24])
+ − 84 ("\^ah\^m" [f25])
+ − 85 ("\^ai\^m" [f26])
+ − 86 ("\^aj\^m" [f27])
+ − 87 ("\^ak\^m" [f28])
+ − 88 ("\^al\^m" [f29])
+ − 89 ("\^am\^m" [f30])
+ − 90 ("\^an\^m" [f31])
+ − 91 ("\^ao\^m" [f32])
+ − 92
+ − 93 ;; Terminfo may know about these, but X won't
+ − 94 ("\eI" [key-stab]) ;; Not an X keysym
+ − 95 ("\eJ" [key-snext]) ;; Not an X keysym
+ − 96 ("\eY" [key-clear]) ;; Not an X keysym
+ − 97
+ − 98 ;; These are totally strange :-)
+ − 99 ("\eW" [?\C-?]) ;; Not an X keysym
+ − 100 ("\^a\^k\^m" [funct-up]) ;; Not an X keysym
+ − 101 ("\^a\^j\^m" [funct-down]) ;; Not an X keysym
+ − 102 ("\^a\^l\^m" [funct-right]) ;; Not an X keysym
+ − 103 ("\^a\^h\^m" [funct-left]) ;; Not an X keysym
+ − 104 ("\^a\^m\^m" [funct-return]) ;; Not an X keysym
+ − 105 ("\^a\^i\^m" [funct-tab]) ;; Not an X keysym
+ − 106 ))
+ − 107
+ − 108 (defun enable-arrow-keys ()
+ − 109 "To be called by term-setup-hook. Overrides 6 Emacs standard keys
+ − 110 whose functions are then typed as follows:
+ − 111 C-a Funct Left-arrow
+ − 112 C-h M-?
+ − 113 LFD Funct Return, some modes override down-arrow via LFD
+ − 114 C-k CLR Line
+ − 115 C-l Scrn CLR
+ − 116 M-r M-x move-to-window-line, Funct up-arrow or down-arrow are similar
+ − 117 "
+ − 118 (interactive)
+ − 119 (mapcar (function (lambda (key-definition)
+ − 120 (global-set-key (car key-definition)
+ − 121 (nth 1 key-definition))))
+ − 122 ;; By unsetting C-a and then binding it to a prefix, we
+ − 123 ;; allow the rest of the function keys which start with C-a
+ − 124 ;; to be recognized.
+ − 125 '(("\C-a" nil)
+ − 126 ("\C-k" nil)
+ − 127 ("\C-j" nil)
+ − 128 ("\C-l" nil)
+ − 129 ("\C-h" nil)
+ − 130 ("\er" nil)))
+ − 131 (fset 'enable-arrow-keys nil))
+ − 132
+ − 133
+ − 134 ;;; Miscellaneous hacks
+ − 135
+ − 136 ;;; This is an ugly hack for a nasty problem:
+ − 137 ;;; Wyse 50 takes one character cell to store video attributes (which seems to
+ − 138 ;;; explain width 79 rather than 80, column 1 is not used!!!).
+ − 139 ;;; On killing (C-x C-c) the end inverse code (on column 1 of line 24)
+ − 140 ;;; of the mode line is overwritten AFTER all the y-or-n questions.
+ − 141 ;;; This causes the attribute to remain in effect until the mode line has
+ − 142 ;;; scrolled of the screen. Suspending (C-z) does not cause this problem.
+ − 143 ;;; On such terminals, Emacs should sacrifice the first and last character of
+ − 144 ;;; each mode line, rather than a whole screen column!
+ − 145 (add-hook 'kill-emacs-hook
+ − 146 (function (lambda () (interactive)
+ − 147 (send-string-to-terminal
+ − 148 (concat "\ea23R" (1+ (frame-width)) "C\eG0")))))
+ − 149
+ − 150 ;;; wyse50.el ends here