diff lisp/term/README @ 2251:216f86e5891d

Initial revision
author Eric S. Raymond <esr@snark.thyrsus.com>
date Thu, 18 Mar 1993 22:31:30 +0000
parents
children 8d18b4730895
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/lisp/term/README	Thu Mar 18 22:31:30 1993 +0000
@@ -0,0 +1,207 @@
+   This directory contains files of elisp that customize Emacs for certain
+terminal types.  When Emacs starts, it checks the TERM environment variable to
+see what type of terminal the user is running on, checks for an elisp file
+named "term/${TERM}.el", and if one exists, loads it.
+
+   When writing terminal packages, there are some things it is good to keep in
+mind.
+
+   First, about keycap names.  Your terminal package can create any keycap
+cookies it likes, but there are good reasons to stick to the set recognized by
+the X-windows code whenever possible.  The X key symbols recognized by Emacs
+are listed in src/term.c; look for the string `keys' in that file.
+
+   For one thing, it means that you'll have the same Emacs key bindings on in
+terminal mode as on an X console.  If there are differences, you can bet
+they'll frustrate you after you've forgotten about them.
+
+   For another, the X keysms provide a standard set of names that Emacs knows
+about.  It tries to bind many of them to useful things at startup, before your
+.emacs is read (so you can override them).  In some ways, the X keysym standard
+is a admittedly poor one; it's incomplete, and not well matched to the set of
+`virtual keys' that UNIX terminfo(3) provides.  But, trust us, the alternatives
+were worse.
+
+   This doesn't mean that if your terminal has a "Cokebottle" key you shouldn't
+define a [cokebottle] keycap.  But if you must define cookies that aren't in
+that set, try to pattern them on the standard terminfo variable names for
+clarity; also, for a fighting chance that your binding may be useful to someone
+else someday.
+
+   For example, if your terminal has a `find' key, observe that terminfo
+supports a key_find capability and call your cookie [key-find].
+
+Here is a complete list, with corresponding X keysyms.
+
+-----------------------------------------------------------------------------
+Variable name	cap	X Keysym	Description
+--------------	---	------------	-------------------------------------
+key_down	kd	down		Sent by terminal down arrow key
+key_up		ku	up		Sent by terminal up arrow key
+key_left	kl	left		Sent by terminal left arrow key
+key_right	kr	right		Sent by terminal right arrow key
+key_home	kh	home		Sent by home key.
+key_backspace	kb			Sent by backspace key
+key_dl		kd	deleteline	Sent by delete line key.
+key_il		kA	insertline	Sent by insert line.
+key_dc		kD			Sent by delete character key.
+key_ic		kI	insertchar (1)	Sent by ins char/enter ins mode key.
+key_eic		KM			Sent by rmir or smir in insert mode.
+key_clear	kC			Sent by clear screen or erase key.
+key_eos		kS			Sent by clear-to-end-of-screen key.
+key_eol		kE			Sent by clear-to-end-of-line key.
+key_sf		kF			Sent by scroll-forward/down key
+key_sr		kR			Sent by scroll-backward/up key
+key_npage	kN	next (2)	Sent by next-page key
+key_ppage	kP	prior (2)	Sent by previous-page key
+key_stab	kT			Sent by set-tab key
+key_ctab	kt			Sent by clear-tab key
+key_catab	ka			Sent by clear-all-tabs key.
+key_enter	@8	kp-enter	Enter/send (unreliable)
+key_print	%9	print		print or copy
+key_ll		kH			Sent by home-down key
+key_a1		K1	kp-1		Upper left of keypad
+key_a3		K3	kp-3		Upper right of keypad
+key_b2		K2	kp-5		Center of keypad
+key_c1		K4	kp-7		Lower left of keypad
+key_c3		K5	kp-9		Lower right of keypad
+key_btab	kB	backtab		Back tab key
+key_beg		@1	begin		beg(inning) key
+key_cancel	@2	cancel		cancel key
+key_close	@3			close key
+key_command	@4	execute (3)	cmd (command) key
+key_copy	@5			copy key
+key_create	@6			create key
+key_end		@7	end		end key
+key_exit	@9			exit key
+key_find	@0			find key
+key_help	%1			help key
+key_mark	%2			mark key
+key_message	%3			message key
+key_move	%4			move key
+key_next	%5	next (2)	next object key
+key_open	%6			open key
+key_options	%7	menu (3)	options key
+key_previous	%8	previous (2)	previous object key
+key_redo	%0	redo		redo key
+key_reference	&1			ref(erence) key
+key_refresh	&2			refresh key
+key_replace	&3			replace key
+key_restart	&4	reset (3)	restart key
+key_resume	&5			resume key
+key_save	&6			save key
+key_sbeg	&9			shifted beginning key
+key_select	*6	select		select key
+key_suspend	&7			suspend key
+key_undo	&8	undo		undo key
+
+key_scancel	&0			shifted cancel key
+key_scommand	*1			shifted command key
+key_scopy	*2			shifted copy key
+key_screate	*3			shifted create key
+key_sdc		*4			shifted delete char key
+key_sdl		*5			shifted delete line key
+key_send	*7			shifted end key
+key_seol	*8			shifted clear line key
+key_sexit	*9			shifted exit key
+key_sf		kF			shifted find key
+key_shelp	#1			shifted help key
+key_shome	#2			shifted home key
+key_sic		#3			shifted input key
+key_sleft	#4			shifted left arrow key
+key_smessage	%a			shifted message key
+key_smove	%b			shifted move key
+key_snext	%c			shifted next key
+key_soptions	%d			shifted options key
+key_sprevious	%e			shifted prev key
+key_sprint	%f			shifted print key
+key_sredo	%g			shifted redo key
+key_sreplace	%h			shifted replace key
+key_sright	%i			shifted right arrow
+key_sresume	%j			shifted resume key
+key_ssave	!1			shifted save key
+key_suspend	!2			shifted suspend key
+key_sundo	!3			shifted undo key
+
+key_f0		k0	f0 (4)		function key 0
+key_f1		k1	f1		function key 1
+key_f2		k2	f2		function key 2
+key_f3		k3	f3		function key 3
+key_f4		k4	f4		function key 4
+key_f5		k5	f5		function key 5
+key_f6		k6	f6		function key 6
+key_f7		k7	f7		function key 7
+key_f8		k8	f8		function key 8
+key_f9		k9	f9		function key 9
+key_f10		k;	f10 (4)		function key 10
+key_f11		F1	f11		function key 11
+  :		:	   :			:
+key_f35		FP	f35		function key 35
+key_f36		FQ			function key 36
+  :		:	   :			:
+key_f64		k1			function key 64
+
+(1) The terminfo documentation says this may be the 'insert character' or
+    `enter insert mode' key.  Accordingly, key_ic is mapped to the `insertchar'
+    keysym if there is also a key_dc key; otherwise it's mapped to `insert'.
+    The presumption is that keyboards with `insert character' keys usually
+    have `delete character' keys paired with them.
+
+(2) If there is no key_next key but there is a key_npage key, key_npage
+    will be bound to the `next' keysym.  If there is no key_previous key but
+    there is a key_ppage key, key_ppage will be bound to the `previous' keysym.
+
+(3) Sorry, these are not exact but they're the best we can do.
+
+(4) The uses of the "k0" capability are inconsistent; sometimes it
+    describes F10, whereas othertimes it describes F0 and "k;" describes F10.
+    Emacs attempts to politely accomodate both systems by testing for
+    "k;", and if it is present, assuming that "k0" denotes F0, otherwise F10.
+-----------------------------------------------------------------------------
+
+   The following X keysyms do *not* have terminfo equivalents.   These are
+the cookies your terminal package will have to set up itself, if you want them:
+
+	break
+	system
+	user
+	kp-backtab
+	kp-space
+	kp-tab
+	kp-f1
+	kp-f2
+	kp-f3
+	kp-f4
+	kp-multiply
+	kp-add
+	kp-separator
+	kp-subtract
+	kp-decimal
+	kp-divide
+	kp-0
+	kp-2
+	kp-4
+	kp-6
+	kp-8
+	kp-equal
+
+   In general, you should not bind any of the standard keysym names to
+functions in a terminal package.  There's code in loaddefs.el that does that;
+the less people make exceptions to that, the more consistent an interface Emacs
+will have across different keyboards.  Those exceptions should go in your
+.emacs file.
+
+   Finally, if you're using a USL UNIX or a Sun box or anything else with the
+USL version of curses(3) on it, bear in mind that the original curses(3) had
+(and still has) a very much smaller set of keycaps.  In fact, the reliable
+ones were just the arrow keys and the first ten function keys.  If you care
+about making your package portable to older Berkeley machines, don't count on
+the setup code to bind anything else.
+
+   If your terminal's arrow key sequences are so funky that they conflict with
+normal Emacs key bindings, the package should set up a function called
+(enable-foo-arrow-keys), where `foo' becomes the terminal name, and leave
+it up to the user's .emacs file whether to call it.
+
+   Before writing a terminal-support package, it's a good idea to read the
+existing ones and learn the common conventions.