summaryrefslogtreecommitdiff
path: root/lib/libcurses/Caps
diff options
context:
space:
mode:
authorTodd C. Miller <millert@cvs.openbsd.org>1998-07-23 21:20:13 +0000
committerTodd C. Miller <millert@cvs.openbsd.org>1998-07-23 21:20:13 +0000
commita8d3a59992970b350c84b6330592df657f919080 (patch)
treeecdb217d8210502c80484fb89fdaa25775a54fb1 /lib/libcurses/Caps
parent65d74b2bc105ada6c49c16682e6ee5bb92b84b03 (diff)
ncurses-4.2-980718
Diffstat (limited to 'lib/libcurses/Caps')
-rw-r--r--lib/libcurses/Caps1314
1 files changed, 1314 insertions, 0 deletions
diff --git a/lib/libcurses/Caps b/lib/libcurses/Caps
new file mode 100644
index 00000000000..f50372e987f
--- /dev/null
+++ b/lib/libcurses/Caps
@@ -0,0 +1,1314 @@
+##############################################################################
+# Copyright (c) 1998 Free Software Foundation, Inc. #
+# #
+# Permission is hereby granted, free of charge, to any person obtaining a #
+# copy of this software and associated documentation files (the "Software"), #
+# to deal in the Software without restriction, including without limitation #
+# the rights to use, copy, modify, merge, publish, distribute, distribute #
+# with modifications, sublicense, and/or sell copies of the Software, and to #
+# permit persons to whom the Software is furnished to do so, subject to the #
+# following conditions: #
+# #
+# The above copyright notice and this permission notice shall be included in #
+# all copies or substantial portions of the Software. #
+# #
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR #
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, #
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL #
+# THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER #
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING #
+# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER #
+# DEALINGS IN THE SOFTWARE. #
+# #
+# Except as contained in this notice, the name(s) of the above copyright #
+# holders shall not be used in advertising or otherwise to promote the sale, #
+# use or other dealings in this Software without prior written #
+# authorization. #
+##############################################################################
+#
+# Author: Zeyd M. Ben-Halim <zmbenhal@netcom.com> 1992,1995
+# and: Eric S. Raymond <esr@snark.thyrsus.com>
+#
+# $OpenBSD: Caps,v 1.1 1998/07/23 21:17:19 millert Exp $
+# $From: Caps,v 1.21 1998/06/30 01:07:56 tom Exp $
+#
+# This is the master termcap/terminfo capability table.
+#
+# This table is used to generate initializers for tables that drive tic,
+# infocmp, and the library compilation code used to support the termcap
+# compatibility hack. It is also used to generate the tabular portion of the
+# terminfo(5) man page; lines beginning with `#%' are passed through to become
+# the terminfo table.
+#
+# This file has three major sections; a standard-capabilities table, two
+# extension-capability tables, and a section of aliases declarations.
+# The first two have the same format, as follows:
+#
+# FILE FORMAT
+#
+# Column 1: terminfo variable name
+# Column 2: terminfo capability name
+# Column 3: capability type (boolean, numeric, or string)
+# Column 4: termcap capability name
+# Column 5: Lead with `Y' if capability should be emitted in termcap
+# translations, `-' otherwise
+# Column 6: capability description
+#
+# The codes following [Y-] in column 5 describe the versions of termcap which
+# use the given capability. This information is not used by the curses library
+# proper; rather, it's there to help the terminfo maintainer avoid emitting
+# termcap entry translations that are more than 1023 bytes long (and tank a
+# lot of old termcap-using programs). The codes read as follows:
+# B = mentioned in the BSD man page for 4.4BSD curses
+# C = used by the 4.4BSD curses library
+# G = mentioned in the documentation for GNU termcap
+# E = used by GNU Emacs
+# K = remove this terminfo capability when translating to standard format
+# The important codes are C and E. A cap with C or E should be preserved in
+# translation if possible. The problem is that preserving all such caps may
+# lead to some termcap translations being too long. The termcap maintainer
+# has a bit of a juggling act to do...potential problem cases are marked with
+# a * or **.
+#
+# The aliases section has the following format:
+#
+# Column 1: either `capalias' or `infoalias'
+# Column 2: name to be aliased
+# Column 3: what name it should translate to. The name IGNORE means it
+# should be discarded with a warning message.
+# Column 4: name of the extension set (used for compiler warning messages)
+# Column 5: capability description (usually an associated terminfo variable)
+#
+# HANDLING TERMCAP AND TERMINFO EXTENSIONS
+#
+# There are basically five different ways to handle termcap and terminfo
+# extensions:
+#
+# 1. Don't list the capname here, or list it but comment it out (the latter
+# is preferable; someone might want to handle it in the future). If you do
+# this, the capability will be treated as unknown and raise a warning from
+# the compiler.
+#
+# 2. Alias it. This is appropriate if the capability has the same meaning
+# as an already-supported one. The compiler will handle aliasing, emitting
+# an appropriate informational message whenever an alias fires.
+#
+# 3. List it in the standard table. You almost certainly do *not* want
+# to do this -- the capabilities in that one, and their order, have been
+# carefully chosen to be SVr4-binary-compatible when they're written out
+# as a terminfo object, and breaking this would be bad. It's up the ncurses
+# library what to do with the terminfo data after it's read in.
+#
+# 4. List it in the aliases table with an IGNORE target field. If you
+# do this, the capability will be ignored on input (though the user will
+# get a warning message about it).
+#
+# 5. List it in the extensions table. If you do this, the compiler will
+# silently accept the capability, but the curses library proper will never
+# see it (because it won't be written out as part of the terminfo object
+# format). It's up to you what you have the compiler do with it.
+#
+# There are two opposite reasons to choose option 5. One is when you want
+# to eat the capability silently and discard it when doing translations
+# to terminfo with tic -I. Some very old obsolete BSD caps like :kn: are
+# in this class. Nothing will ever use them again.
+#
+# More usually, you want the compiler to try to deduce something from the
+# capability value that it can use to translate it into your output format.
+# You'll need to write custom code, probably in postprocess_termcap() or
+# postprocess_terminfo(), to handle the translation.
+#
+# CONTROLLING ENTRY LENGTH
+#
+# Notes on specific elisions made to fit translations within 1023 bytes:
+#
+# Machines with IBM PC-like keyboards want to be able to define the following
+# keys: key_npage, key_ppage, key_home, key_ll (which is used for in termcap-
+# only environments for End or Home-Down), key_dc, and key_ic. This is also
+# the set of keys the `joe' editor will be upset if it can't see. So don't
+# trim those out of the set to be translated to termcap, or various users of
+# the termcap file will become irate.
+#
+# It might look tempting to leave those long init strings out of translations.
+# We can't do it (yet); 4.4BSD tput and tset use them.
+#
+# We retain the sgr capability in translation in spite of the fact that neither
+# 4.4BSD nor GNU Emacs uses it, because (a) some entry naming distinctions are
+# hard to understand without it, and (b) the entries in which it is long tend
+# to be older types that don't use up a lot of string space on function keys.
+# The tic(1) translation code will complain and elide it if it makes a critical
+# difference (there is special code in tic to recognize this situation).
+#
+# Yes, BSD tset(1) uses hpa. We elide hpa/vpa anyway because the motion
+# optimizer in BSD curses didn't use them. This omission seems to be the
+# single most effective one, it shortened the resolved length of all thirteen
+# problem entries in the 9.9.0 version of the terminfo master below critical.
+#
+# It would be nice to keep f11 and f12 for Emacs use, but a couple of termcap
+# translations go back over critical if we do this. As 4.4BSD curses fades
+# into history and GNU termcap's application base shrinks towards being GNU
+# Emacs only, we'll probably elide out some BSD-only capabilities in order
+# to buy space for non-essentials Emacs is still using. Capabilities high
+# on that hit list: rc, sc, uc.
+#
+#############################################################################
+#
+# STANDARD CAPABILITIES
+#
+#%The following is a complete table of the capabilities included in a
+#%terminfo description block and available to terminfo-using code. In each
+#%line of the table,
+#%
+#%The \fBvariable\fR is the name by which the programmer (at the terminfo level)
+#%accesses the capability.
+#%
+#%The \fBcapname\fR is the short name used in the text of the database,
+#%and is used by a person updating the database.
+#%Whenever possible, capnames are chosen to be the same as or similar to
+#%the ANSI X3.64-1979 standard (now superseded by ECMA-48, which uses
+#%identical or very similar names). Semantics are also intended to match
+#%those of the specification.
+#%
+#%The termcap code is the old
+#%.B termcap
+#%capability name (some capabilities are new, and have names which termcap
+#%did not originate).
+#%.P
+#%Capability names have no hard length limit, but an informal limit of 5
+#%characters has been adopted to keep them short and to allow the tabs in
+#%the source file
+#%.B Caps
+#%to line up nicely.
+#%
+#%Finally, the description field attempts to convey the semantics of the
+#%capability. You may find some codes in the description field:
+#%.TP
+#%(P)
+#%indicates that padding may be specified
+#%.TP
+#%#[1-9]
+#%in the description field indicates that the string is passed through tparm with
+#%parms as given (#\fIi\fP).
+#%.TP
+#%(P*)
+#%indicates that padding may vary in proportion to the number of
+#%lines affected
+#%.TP
+#%(#\d\fIi\fP\u)
+#%indicates the \fIi\fP\uth\d parameter.
+#%
+#%.PP
+#% These are the boolean capabilities:
+#%
+#%.na
+#%.TS H
+#%center expand;
+#%c l l c
+#%c l l c
+#%lw25 lw6 lw2 lw20.
+#%\fBVariable Cap- TCap Description\fR
+#%\fBBooleans name Code\fR
+auto_left_margin bw bool bw YB-G- cub1 wraps from column 0 to last column
+auto_right_margin am bool am YBCGE terminal has automatic margins
+no_esc_ctlc xsb bool xb YBCG- beehive (f1=escape, f2=ctrl C)
+ceol_standout_glitch xhp bool xs YBCGE standout not erased by overwriting (hp)
+eat_newline_glitch xenl bool xn YBCGE newline ignored after 80 cols (concept)
+erase_overstrike eo bool eo YBCG- can erase overstrikes with a blank
+generic_type gn bool gn YB-G- generic line type
+hard_copy hc bool hc YBCG- hardcopy terminal
+has_meta_key km bool km YB-GE Has a meta key, sets msb high
+has_status_line hs bool hs YB-G- has extra status line
+insert_null_glitch in bool in YBCGE insert mode distinguishes nulls
+memory_above da bool da YBCG- display may be retained above the screen
+memory_below db bool db YB-GE display may be retained below the screen
+move_insert_mode mir bool mi YBCGE safe to move while in insert mode
+move_standout_mode msgr bool ms YBCGE safe to move while in standout mode
+over_strike os bool os YBCG- terminal can overstrike
+status_line_esc_ok eslok bool es YB-G- escape can be used on the status line
+dest_tabs_magic_smso xt bool xt YBCGE tabs destructive, magic so char (t1061)
+tilde_glitch hz bool hz YB-GE can't print ~'s (hazeltine)
+transparent_underline ul bool ul YBCGE underline character overstrikes
+xon_xoff xon bool xo YB--- terminal uses xon/xoff handshaking
+needs_xon_xoff nxon bool nx ----- padding won't work, xon/xoff required
+prtr_silent mc5i bool 5i ----- printer won't echo on screen
+hard_cursor chts bool HC ----- cursor is hard to see
+non_rev_rmcup nrrmc bool NR ----- smcup does not reverse rmcup
+no_pad_char npc bool NP ----- pad character does not exist
+non_dest_scroll_region ndscr bool ND ----- scrolling region is non-destructive
+can_change ccc bool cc ----- terminal can re-define existing colors
+back_color_erase bce bool ut ----- screen erased with background color
+hue_lightness_saturation hls bool hl ----- terminal uses only HLS color notation (tektronix)
+col_addr_glitch xhpa bool YA ----- only positive motion for hpa/mhpa caps
+cr_cancels_micro_mode crxm bool YB ----- using cr turns off micro mode
+has_print_wheel daisy bool YC ----- printer needs operator to change character set
+row_addr_glitch xvpa bool YD ----- only positive motion for vpa/mvpa caps
+semi_auto_right_margin sam bool YE ----- printing in last column causes cr
+cpi_changes_res cpix bool YF ----- changing character pitch changes resolution
+lpi_changes_res lpix bool YG ----- changing line pitch changes resolution
+#%.TE
+#%.ad
+#%
+#%These are the numeric capabilities:
+#%
+#%.na
+#%.TS H
+#%center expand;
+#%c l l c
+#%c l l c
+#%lw25 lw6 lw2 lw20.
+#%\fBVariable Cap- TCap Description\fR
+#%\fBNumeric name Code\fR
+columns cols num co YBCGE number of columns in a line
+init_tabs it num it YB-G- tabs initially every # spaces
+lines lines num li YBCGE number of lines on screen or page
+lines_of_memory lm num lm YB-G- lines of memory if > line. 0 => varies
+magic_cookie_glitch xmc num sg YBCGE number of blank characters left by smso or rmso
+padding_baud_rate pb num pb YB-GE lowest baud rate where padding needed
+virtual_terminal vt num vt YB--- virtual terminal number (CB/unix)
+width_status_line wsl num ws YB-G- columns in status line
+num_labels nlab num Nl ----- number of labels on screen
+label_height lh num lh ----- rows in each label
+label_width lw num lw ----- columns in each label
+max_attributes ma num ma YBC-- maximum combined attributes terminal can handle
+maximum_windows wnum num MW ----- maximum number of defineable windows
+# These came in with SVr4's color support
+max_colors colors num Co ----- maximum number of colors on screen
+max_pairs pairs num pa ----- maximum number of color-pairs on the screen
+no_color_video ncv num NC ----- video attributes that can't be used with colors
+#%.TE
+#%.ad
+#%
+#%The following numeric capabilities are present in the SVr4.0 term structure,
+#%but are not yet documented in the man page. They came in with SVr4's
+#%printer support.
+#%
+#%.na
+#%.TS H
+#%center expand;
+#%c l l c
+#%c l l c
+#%lw25 lw6 lw2 lw20.
+#%\fBVariable Cap- TCap Description\fR
+#%\fBNumeric name Code\fR
+buffer_capacity bufsz num Ya ----- numbers of bytes buffered before printing
+dot_vert_spacing spinv num Yb ----- spacing of pins vertically in pins per inch
+dot_horz_spacing spinh num Yc ----- spacing of dots horizontally in dots per inch
+max_micro_address maddr num Yd ----- maximum value in micro_..._address
+max_micro_jump mjump num Ye ----- maximum value in parm_..._micro
+micro_char_size mcs num Yf ----- character size when in micro mode
+micro_line_size mls num Yg ----- line size when in micro mode
+number_of_pins npins num Yh ----- numbers of pins in print-head
+output_res_char orc num Yi ----- horizontal resolution in units per line
+output_res_line orl num Yj ----- vertical resolution in units per line
+output_res_horz_inch orhi num Yk ----- horizontal resolution in units per inch
+output_res_vert_inch orvi num Yl ----- vertical resolution in units per inch
+print_rate cps num Ym ----- print rate in characters per second
+wide_char_size widcs num Yn ----- character step size when in double wide mode
+buttons btns num BT ----- number of buttons on mouse
+bit_image_entwining bitwin num Yo ----- number of passes for each bit-image row
+bit_image_type bitype num Yp ----- type of bit-image device
+#%.TE
+#%.ad
+#%
+#%These are the string capabilities:
+#%
+#%.na
+#%.TS H
+#%center expand;
+#%c l l c
+#%c l l c
+#%lw25 lw6 lw2 lw20.
+#%\fBVariable Cap- TCap Description\fR
+#%\fBString name Code\fR
+back_tab cbt str bt YBCGE back tab (P)
+bell bel str bl YB-GE audible signal (bell) (P)
+carriage_return cr str cr YBCGE carriage return (P*) (P*)
+change_scroll_region csr str cs YBCGE change region to line #1 to line #2 (P)
+clear_all_tabs tbc str ct YB-G- clear all tab stops (P)
+clear_screen clear str cl YBCGE clear screen and home cursor (P*)
+clr_eol el str ce YBCGE clear to end of line (P)
+clr_eos ed str cd YBCGE clear to end of screen (P*)
+column_address hpa str ch -B-GE** horizontal position #1, absolute (P)
+command_character cmdch str CC YB-G- terminal settable cmd character in prototype !?
+cursor_address cup str cm YBCGE move to row #1 columns #2
+cursor_down cud1 str do YBCGE down one line
+cursor_home home str ho YBCGE home cursor (if no cup)
+cursor_invisible civis str vi YB-G- make cursor invisible
+cursor_left cub1 str le YBCGE move left one space
+cursor_mem_address mrcup str CM YB-G- memory relative cursor addressing
+cursor_normal cnorm str ve YBCGE make cursor appear normal (undo civis/cvvis)
+cursor_right cuf1 str nd YBCGE move right one space
+cursor_to_ll ll str ll YBCGE last line, first column (if no cup)
+cursor_up cuu1 str up YBCGE up one line
+cursor_visible cvvis str vs YBCGE make cursor very visible
+delete_character dch1 str dc YBCGE delete character (P*)
+delete_line dl1 str dl YBCGE delete line (P*)
+dis_status_line dsl str ds YB-G- disable status line
+down_half_line hd str hd YB-G- half a line down
+enter_alt_charset_mode smacs str as YB-G- start alternate character set (P)
+enter_blink_mode blink str mb YB-G- turn on blinking
+enter_bold_mode bold str md YB-G- turn on bold (extra bright) mode
+enter_ca_mode smcup str ti YBCGE string to start programs using cup
+enter_delete_mode smdc str dm YBCGE enter delete mode
+enter_dim_mode dim str mh YB-G- turn on half-bright mode
+enter_insert_mode smir str im YBCGE enter insert mode
+enter_secure_mode invis str mk -B-G-* turn on blank mode (characters invisible)
+enter_protected_mode prot str mp -B-G-* turn on protected mode
+enter_reverse_mode rev str mr YB-G- turn on reverse video mode
+enter_standout_mode smso str so YBCGE begin standout mode
+enter_underline_mode smul str us YBCGE begin underline mode
+erase_chars ech str ec YB-G- erase #1 characters (P)
+exit_alt_charset_mode rmacs str ae YB-G- end alternate character set (P)
+exit_attribute_mode sgr0 str me YB-GE turn off all attributes
+exit_ca_mode rmcup str te YBCGE strings to end programs using cup
+exit_delete_mode rmdc str ed YBCGE end delete mode
+exit_insert_mode rmir str ei YBCGE exit insert mode
+exit_standout_mode rmso str se YBCGE exit standout mode
+exit_underline_mode rmul str ue YBCGE exit underline mode
+flash_screen flash str vb YBCGE visible bell (may not move cursor)
+form_feed ff str ff YB-G- hardcopy terminal page eject (P*)
+from_status_line fsl str fs YB-G- return from status line
+init_1string is1 str i1 YB-G- initialization string
+init_2string is2 str is YB-G- initialization string
+init_3string is3 str i3 YB-G- initialization string
+init_file if str if YB-G- name of initialization file
+insert_character ich1 str ic YBCGE insert character (P)
+insert_line il1 str al YBCGE insert line (P*)
+insert_padding ip str ip YBCGE insert padding after inserted character
+key_backspace kbs str kb YB-G- backspace key
+key_catab ktbc str ka -B-G-* clear-all-tabs key
+key_clear kclr str kC -B-G-* clear-screen or erase key
+key_ctab kctab str kt -B-G-* clear-tab key
+key_dc kdch1 str kD YB-G- delete-character key
+key_dl kdl1 str kL -B-G-* delete-line key
+key_down kcud1 str kd YBCGE down-arrow key
+key_eic krmir str kM -B-G-* sent by rmir or smir in insert mode
+key_eol kel str kE -B-G-* clear-to-end-of-line key
+key_eos ked str kS -B-G-* clear-to-end-of-screen key
+key_f0 kf0 str k0 YBCGE F0 function key
+key_f1 kf1 str k1 YBCGE F1 function key
+key_f10 kf10 str k; ----E F10 function key
+key_f2 kf2 str k2 YBCGE F2 function key
+key_f3 kf3 str k3 YBCGE F3 function key
+key_f4 kf4 str k4 YBCGE F4 function key
+key_f5 kf5 str k5 YBCGE F5 function key
+key_f6 kf6 str k6 YBCGE F6 function key
+key_f7 kf7 str k7 YBCGE F7 function key
+key_f8 kf8 str k8 YBCGE F8 function key
+key_f9 kf9 str k9 YBCGE F9 function key
+key_home khome str kh YBCGE home key
+key_ic kich1 str kI YB-GE insert-character key
+key_il kil1 str kA -B-G-* insert-line key
+key_left kcub1 str kl YBCGE left-arrow key
+key_ll kll str kH YB-G- lower-left key (home down)
+key_npage knp str kN YB-GE next-page key
+key_ppage kpp str kP YB-GE previous-page key
+key_right kcuf1 str kr YBCGE right-arrow key
+key_sf kind str kF -B-G-* scroll-forward key
+key_sr kri str kR -B-G-* scroll-backward key
+key_stab khts str kT -B-G-* set-tab key
+key_up kcuu1 str ku YBCGE up-arrow key
+keypad_local rmkx str ke YBCGE leave 'keyboard_transmit' mode
+keypad_xmit smkx str ks YBCGE enter 'keyboard_transmit' mode
+lab_f0 lf0 str l0 -B-G-* label on function key f0 if not f0
+lab_f1 lf1 str l1 -B-G-* label on function key f1 if not f1
+lab_f10 lf10 str la ----- label on function key f10 if not f10
+lab_f2 lf2 str l2 -B-G-* label on function key f2 if not f2
+lab_f3 lf3 str l3 -B-G-* label on function key f3 if not f3
+lab_f4 lf4 str l4 -B-G-* label on function key f4 if not f4
+lab_f5 lf5 str l5 -B-G-* label on function key f5 if not f5
+lab_f6 lf6 str l6 -B-G-* label on function key f6 if not f6
+lab_f7 lf7 str l7 -B-G-* label on function key f7 if not f7
+lab_f8 lf8 str l8 -B-G-* label on function key f8 if not f8
+lab_f9 lf9 str l9 -B-G-* label on function key f9 if not f9
+meta_off rmm str mo YB-G-* turn off meta mode
+meta_on smm str mm YB-G-* turn on meta mode (8th-bit on)
+newline nel str nw YB-G-* newline (behave like cr followed by lf)
+pad_char pad str pc YBCGE padding char (instead of null)
+parm_dch dch str DC YB-GE delete #1 characters (P*)
+parm_delete_line dl str DL YBCGE delete #1 lines (P*)
+parm_down_cursor cud str DO YBCGE down #1 lines (P*)
+parm_ich ich str IC YB-GE insert #1 characters (P*)
+parm_index indn str SF YBCG- scroll forward #1 lines (P)
+parm_insert_line il str AL YBCGE insert #1 lines (P*)
+parm_left_cursor cub str LE YBCGE move #1 characters to the left (P)
+parm_right_cursor cuf str RI YBCGE move #1 characters to the right (P*)
+parm_rindex rin str SR YBCG- scroll back #1 lines (P)
+parm_up_cursor cuu str UP YBCGE up #1 lines (P*)
+pkey_key pfkey str pk -B--- program function key #1 to type string #2
+pkey_local pfloc str pl -B--- program function key #1 to execute string #2
+pkey_xmit pfx str px -B--- program function key #1 to transmit string #2
+print_screen mc0 str ps -B-G-* print contents of screen
+prtr_off mc4 str pf -B-G-* turn off printer
+prtr_on mc5 str po -B-G-* turn on printer
+repeat_char rep str rp YB-GE repeat char #1 #2 times (P*)
+reset_1string rs1 str r1 -B--- reset string
+reset_2string rs2 str r2 -B--- reset string
+reset_3string rs3 str r3 -B--- reset string
+reset_file rf str rf -B--- name of reset file
+restore_cursor rc str rc YBCG- restore cursor to position of last save_cursor
+row_address vpa str cv -B-GE** vertical position #1 absolute (P)
+save_cursor sc str sc YBCG- save current cursor position (P)
+scroll_forward ind str sf YBCGE scroll text up (P)
+scroll_reverse ri str sr YBCGE scroll text down (P)
+set_attributes sgr str sa YB-G- define video attributes #1-#9 (PG9)
+set_tab hts str st YB-G- set a tab in every row, current columns
+set_window wind str wi -B-GE current window is lines #1-#2 cols #3-#4
+tab ht str ta YBCGE tab to next 8-space hardware tab stop
+to_status_line tsl str ts YB-G- move to status line
+underline_char uc str uc YBCG- underline char and move past it
+up_half_line hu str hu YB-G- half a line up
+init_prog iprog str iP -B--- path name of program for initialization
+key_a1 ka1 str K1 YB-GE upper left of keypad
+key_a3 ka3 str K3 YB-GE upper right of keypad
+key_b2 kb2 str K2 YB-GE center of keypad
+key_c1 kc1 str K4 YB-GE lower left of keypad
+key_c3 kc3 str K5 YB-GE lower right of keypad
+prtr_non mc5p str pO -B-G-* turn on printer for #1 bytes
+#
+# SVr1 capabilities stop here. IBM's version of terminfo is the same as
+# SVr4 up to this point, but has a different set afterwards.
+#
+char_padding rmp str rP ----- like ip but when in insert mode
+acs_chars acsc str ac ----- graphics charset pairs, based on vt100
+plab_norm pln str pn ----- program label #1 to show string #2
+key_btab kcbt str kB ----- back-tab key
+enter_xon_mode smxon str SX ----- turn on xon/xoff handshaking
+exit_xon_mode rmxon str RX ----- turn off xon/xoff handshaking
+enter_am_mode smam str SA ----- turn on automatic margins
+exit_am_mode rmam str RA ----- turn off automatic margins
+xon_character xonc str XN ----- XON character
+xoff_character xoffc str XF ----- XOFF character
+ena_acs enacs str eA ----- enable alternate char set
+label_on smln str LO ----- turn on soft labels
+label_off rmln str LF ----- turn off soft labels
+key_beg kbeg str @1 ----- begin key
+key_cancel kcan str @2 ----- cancel key
+key_close kclo str @3 ----- close key
+key_command kcmd str @4 ----- command key
+key_copy kcpy str @5 ----- copy key
+key_create kcrt str @6 ----- create key
+key_end kend str @7 ----- end key
+key_enter kent str @8 ----- enter/send key
+key_exit kext str @9 ----- exit key
+key_find kfnd str @0 ----- find key
+key_help khlp str %1 ----- help key
+key_mark kmrk str %2 ----- mark key
+key_message kmsg str %3 ----- message key
+key_move kmov str %4 ----- move key
+key_next knxt str %5 ----- next key
+key_open kopn str %6 ----- open key
+key_options kopt str %7 ----- options key
+key_previous kprv str %8 ----- previous key
+key_print kprt str %9 ----- print key
+key_redo krdo str %0 ----- redo key
+key_reference kref str &1 ----- reference key
+key_refresh krfr str &2 ----- refresh key
+key_replace krpl str &3 ----- replace key
+key_restart krst str &4 ----- restart key
+key_resume kres str &5 ----- resume key
+key_save ksav str &6 ----- save key
+key_suspend kspd str &7 ----- suspend key
+key_undo kund str &8 ----- undo key
+key_sbeg kBEG str &9 ----- shifted begin key
+key_scancel kCAN str &0 ----- shifted cancel key
+key_scommand kCMD str *1 ----- shifted command key
+key_scopy kCPY str *2 ----- shifted copy key
+key_screate kCRT str *3 ----- shifted create key
+key_sdc kDC str *4 ----- shifted delete-character key
+key_sdl kDL str *5 ----- shifted delete-line key
+key_select kslt str *6 ----- select key
+key_send kEND str *7 ----- shifted end key
+key_seol kEOL str *8 ----- shifted clear-to-end-of-line key
+key_sexit kEXT str *9 ----- shifted exit key
+key_sfind kFND str *0 ----- shifted find key
+key_shelp kHLP str #1 ----- shifted help key
+key_shome kHOM str #2 ----- shifted home key
+key_sic kIC str #3 ----- shifted insert-character key
+key_sleft kLFT str #4 ----- shifted left-arrow key
+key_smessage kMSG str %a ----- shifted message key
+key_smove kMOV str %b ----- shifted move key
+key_snext kNXT str %c ----- shifted next key
+key_soptions kOPT str %d ----- shifted options key
+key_sprevious kPRV str %e ----- shifted previous key
+key_sprint kPRT str %f ----- shifted print key
+key_sredo kRDO str %g ----- shifted redo key
+key_sreplace kRPL str %h ----- shifted replace key
+key_sright kRIT str %i ----- shifted right-arrow key
+key_srsume kRES str %j ----- shifted resume key
+key_ssave kSAV str !1 ----- shifted save key
+key_ssuspend kSPD str !2 ----- shifted suspend key
+key_sundo kUND str !3 ----- shifted undo key
+req_for_input rfi str RF ----- send next input char (for ptys)
+key_f11 kf11 str F1 ----E F11 function key
+key_f12 kf12 str F2 ----E F12 function key
+key_f13 kf13 str F3 ----E F13 function key
+key_f14 kf14 str F4 ----E F14 function key
+key_f15 kf15 str F5 ----E F15 function key
+key_f16 kf16 str F6 ----E F16 function key
+key_f17 kf17 str F7 ----E F17 function key
+key_f18 kf18 str F8 ----E F18 function key
+key_f19 kf19 str F9 ----E F19 function key
+key_f20 kf20 str FA ----E F20 function key
+key_f21 kf21 str FB ----E F21 function key
+key_f22 kf22 str FC ----E F22 function key
+key_f23 kf23 str FD ----E F23 function key
+key_f24 kf24 str FE ----E F24 function key
+key_f25 kf25 str FF ----E F25 function key
+key_f26 kf26 str FG ----E F26 function key
+key_f27 kf27 str FH ----E F27 function key
+key_f28 kf28 str FI ----E F28 function key
+key_f29 kf29 str FJ ----E F29 function key
+key_f30 kf30 str FK ----E F30 function key
+key_f31 kf31 str FL ----E F31 function key
+key_f32 kf32 str FM ----E F32 function key
+key_f33 kf33 str FN ----E F33 function key
+key_f34 kf34 str FO ----E F34 function key
+key_f35 kf35 str FP ----E F35 function key
+key_f36 kf36 str FQ ----E F36 function key
+key_f37 kf37 str FR ----E F37 function key
+key_f38 kf38 str FS ----E F38 function key
+key_f39 kf39 str FT ----E F39 function key
+key_f40 kf40 str FU ----E F40 function key
+key_f41 kf41 str FV ----E F41 function key
+key_f42 kf42 str FW ----E F42 function key
+key_f43 kf43 str FX ----E F43 function key
+key_f44 kf44 str FY ----E F44 function key
+key_f45 kf45 str FZ ----E F45 function key
+key_f46 kf46 str Fa ----E F46 function key
+key_f47 kf47 str Fb ----E F47 function key
+key_f48 kf48 str Fc ----E F48 function key
+key_f49 kf49 str Fd ----E F49 function key
+key_f50 kf50 str Fe ----E F50 function key
+key_f51 kf51 str Ff ----E F51 function key
+key_f52 kf52 str Fg ----E F52 function key
+key_f53 kf53 str Fh ----E F53 function key
+key_f54 kf54 str Fi ----E F54 function key
+key_f55 kf55 str Fj ----E F55 function key
+key_f56 kf56 str Fk ----E F56 function key
+key_f57 kf57 str Fl ----E F57 function key
+key_f58 kf58 str Fm ----E F58 function key
+key_f59 kf59 str Fn ----E F59 function key
+key_f60 kf60 str Fo ----E F60 function key
+key_f61 kf61 str Fp ----E F61 function key
+key_f62 kf62 str Fq ----E F62 function key
+key_f63 kf63 str Fr ----E F63 function key
+clr_bol el1 str cb ----- Clear to beginning of line
+clear_margins mgc str MC ----- clear right and left soft margins
+set_left_margin smgl str ML ----- set left soft margin at current column
+set_right_margin smgr str MR ----- set right soft margin at current column
+label_format fln str Lf ----- label format
+set_clock sclk str SC ----- set clock, #1 hrs #2 mins #3 secs
+display_clock dclk str DK ----- display clock at (#1,#2)
+remove_clock rmclk str RC ----- remove clock
+create_window cwin str CW ----- define a window #1 from #2,#3 to #4,#5
+goto_window wingo str WG ----- go to window #1
+hangup hup str HU ----- hang-up phone
+dial_phone dial str DI ----- dial number #1
+quick_dial qdial str QD ----- dial number #1 without checking
+tone tone str TO ----- select touch tone dialing
+pulse pulse str PU ----- select pulse dialing
+flash_hook hook str fh ----- flash switch hook
+fixed_pause pause str PA ----- pause for 2-3 seconds
+wait_tone wait str WA ----- wait for dial-tone
+user0 u0 str u0 ----- User string #0
+user1 u1 str u1 ----- User string #1
+user2 u2 str u2 ----- User string #2
+user3 u3 str u3 ----- User string #3
+user4 u4 str u4 ----- User string #4
+user5 u5 str u5 ----- User string #5
+user6 u6 str u6 ----- User string #6
+user7 u7 str u7 ----- User string #7
+user8 u8 str u8 ----- User string #8
+user9 u9 str u9 ----- User string #9
+#
+# SVr4 added these capabilities to support color
+#
+orig_pair op str op ----- Set default pair to its original value
+orig_colors oc str oc ----- Set all color pairs to the original ones
+initialize_color initc str Ic ----- initialize color #1 to (#2,#3,#4)
+initialize_pair initp str Ip ----- Initialize color pair #1 to fg=(#2,#3,#4), bg=(#5,#6,#7)
+set_color_pair scp str sp ----- Set current color pair to #1
+set_foreground setf str Sf ----- Set foreground color #1
+set_background setb str Sb ----- Set background color #1
+#
+# SVr4 added these capabilities to support printers
+#
+change_char_pitch cpi str ZA ----- Change number of characters per inch
+change_line_pitch lpi str ZB ----- Change number of lines per inch
+change_res_horz chr str ZC ----- Change horizontal resolution
+change_res_vert cvr str ZD ----- Change vertical resolution
+define_char defc str ZE ----- Define a character
+enter_doublewide_mode swidm str ZF ----- Enter double-wide mode
+enter_draft_quality sdrfq str ZG ----- Enter draft-quality mode
+enter_italics_mode sitm str ZH ----- Enter italic mode
+enter_leftward_mode slm str ZI ----- Start leftward carriage motion
+enter_micro_mode smicm str ZJ ----- Start micro-motion mode
+enter_near_letter_quality snlq str ZK ----- Enter NLQ mode
+enter_normal_quality snrmq str ZL ----- Enter normal-quality mode
+enter_shadow_mode sshm str ZM ----- Enter shadow-print mode
+enter_subscript_mode ssubm str ZN ----- Enter subscript mode
+enter_superscript_mode ssupm str ZO ----- Enter superscript mode
+enter_upward_mode sum str ZP ----- Start upward carriage motion
+exit_doublewide_mode rwidm str ZQ ----- End double-wide mode
+exit_italics_mode ritm str ZR ----- End italic mode
+exit_leftward_mode rlm str ZS ----- End left-motion mode
+exit_micro_mode rmicm str ZT ----- End micro-motion mode
+exit_shadow_mode rshm str ZU ----- End shadow-print mode
+exit_subscript_mode rsubm str ZV ----- End subscript mode
+exit_superscript_mode rsupm str ZW ----- End superscript mode
+exit_upward_mode rum str ZX ----- End reverse character motion
+micro_column_address mhpa str ZY ----- Like column_address in micro mode
+micro_down mcud1 str ZZ ----- Like cursor_down in micro mode
+micro_left mcub1 str Za ----- Like cursor_left in micro mode
+micro_right mcuf1 str Zb ----- Like cursor_right in micro mode
+micro_row_address mvpa str Zc ----- Like row_address in micro mode
+micro_up mcuu1 str Zd ----- Like cursor_up in micro mode
+order_of_pins porder str Ze ----- Match software bits to print-head pins
+parm_down_micro mcud str Zf ----- Like parm_down_cursor in micro mode
+parm_left_micro mcub str Zg ----- Like parm_left_cursor in micro mode
+parm_right_micro mcuf str Zh ----- Like parm_right_cursor in micro mode
+parm_up_micro mcuu str Zi ----- Like parm_up_cursor in micro mode
+select_char_set scs str Zj ----- Select character set
+set_bottom_margin smgb str Zk ----- Set bottom margin at current line
+set_bottom_margin_parm smgbp str Zl ----- Set bottom margin at line #1 or #2 lines from bottom
+set_left_margin_parm smglp str Zm ----- Set left (right) margin at column #1 (#2)
+set_right_margin_parm smgrp str Zn ----- Set right margin at column #1
+set_top_margin smgt str Zo ----- Set top margin at current line
+set_top_margin_parm smgtp str Zp ----- Set top (bottom) margin at row #1 (#2)
+start_bit_image sbim str Zq ----- Start printing bit image graphics
+start_char_set_def scsd str Zr ----- Start character set definition
+stop_bit_image rbim str Zs ----- Stop printing bit image graphics
+stop_char_set_def rcsd str Zt ----- End definition of character set
+subscript_characters subcs str Zu ----- List of subscriptable characters
+superscript_characters supcs str Zv ----- List of superscriptable characters
+these_cause_cr docr str Zw ----- Printing any of these characters causes CR
+zero_motion zerom str Zx ----- No motion for subsequent character
+#%.TE
+#%.ad
+#%
+#%The following string capabilities are present in the SVr4.0 term structure,
+#%but were originally not documented in the man page.
+#%
+#%.na
+#%.TS H
+#%center expand;
+#%c l l c
+#%c l l c
+#%lw25 lw6 lw2 lw18.
+#%\fBVariable Cap- TCap Description\fR
+#%\fBString name Code\fR
+char_set_names csnm str Zy ----- List of character set names
+key_mouse kmous str Km ----- Mouse event has occurred
+mouse_info minfo str Mi ----- Mouse status information
+req_mouse_pos reqmp str RQ ----- Request mouse position
+get_mouse getm str Gm ----- Curses should get button events
+set_a_foreground setaf str AF ----- Set foreground color using ANSI escape
+set_a_background setab str AB ----- Set background color using ANSI escape
+pkey_plab pfxl str xl ----- Program function key #1 to type string #2 and show string #3
+device_type devt str dv ----- Indicate language/codeset support
+code_set_init csin str ci ----- Init sequence for multiple codesets
+set0_des_seq s0ds str s0 ----- Shift to code set 0 (EUC set 0, ASCII)
+set1_des_seq s1ds str s1 ----- Shift to code set 1
+set2_des_seq s2ds str s2 ----- Shift to code set 2
+set3_des_seq s3ds str s3 ----- Shift to code set 3
+set_lr_margin smglr str ML ----- Set both left and right margins to #1, #2
+set_tb_margin smgtb str MT ----- Sets both top and bottom margins to #1, #2
+bit_image_repeat birep str Xy ----- Repeat bit image cell #1 #2 times
+bit_image_newline binel str Zz ----- Move to next row of the bit image
+bit_image_carriage_return bicr str Yv ----- Move to beginning of same row
+color_names colornm str Yw ----- Give name for color #1
+define_bit_image_region defbi str Yx ----- Define rectangualar bit image region
+end_bit_image_region endbi str Yy ----- End a bit-image region
+set_color_band setcolor str Yz ----- Change to ribbon color #1
+set_page_length slines str YZ ----- Set page length to #1 lines
+#
+# SVr4 added these capabilities for direct PC-clone support
+#
+display_pc_char dispc str S1 ----- Display PC character
+enter_pc_charset_mode smpch str S2 ----- Enter PC character display mode
+exit_pc_charset_mode rmpch str S3 ----- Exit PC character display mode
+enter_scancode_mode smsc str S4 ----- Enter PC scancode mode
+exit_scancode_mode rmsc str S5 ----- Exit PC scancode mode
+pc_term_options pctrm str S6 ----- PC terminal options
+scancode_escape scesc str S7 ----- Escape for scancode emulation
+alt_scancode_esc scesa str S8 ----- Alternate escape for scancode emulation
+#%.TE
+#%.ad
+#%
+#%.in .8i
+#%The XSI Curses standard added these. They are probably in some post-4.1
+#%version of System V curses as well, but because XSI Curses lists them in
+#%strict alphabetical order we don't know if this is the right binary order.
+#%The \fBncurses\fR termcap names for them are invented; according to the
+#%XSI Curses standard, they have no termcap names. If your compiled terminfo
+#%entries use these, they may not be binary-compatible with System V terminfo
+#%entries after SVr4.1; beware!
+#%
+#%.na
+#%.TS H
+#%center expand;
+#%c l l c
+#%c l l c
+#%lw25 lw6 lw2 lw20.
+#%\fBVariable Cap- TCap Description\fR
+#%\fBString name Code\fR
+enter_horizontal_hl_mode ehhlm str Xh ----- Enter horizontal highlight mode
+enter_left_hl_mode elhlm str Xl ----- Enter left highlight mode
+enter_low_hl_mode elohlm str Xo ----- Enter low highlight mode
+enter_right_hl_mode erhlm str Xr ----- Enter right highlight mode
+enter_top_hl_mode ethlm str Xt ----- Enter top highlight mode
+enter_vertical_hl_mode evhlm str Xv ----- Enter vertical highlight mode
+#%.TE
+#%.ad
+#
+# The magic token below tells the tic compiler-generator code that all the caps
+# past it should be ignored (not written out) when dumping terminfo objects. It
+# also tells the man page table generator not to pass through following lines
+# This means we can have obsolete capabilities and pseudo-capabilities that are
+# recognized for termcap or terminfo compilation, but not output.
+#
+# %%-STOP-HERE-%%
+#
+# Don't move this casually! In fact, don't move it at all unless you're
+# either doing it to add System V or XPG4 extensions, or have decided you
+# don't care about SVr4 binary compatibility.
+#
+#############################################################################
+#
+# TERMCAP EXTENSION CAPABILITIES
+#
+# The capabilities below are either obsolete or extensions on certain systems.
+# They are not used by SVR4 terminfo. Some are used by captoinfo to translate
+# termcap sources; the rest are listed for completeness, and in case somebody
+# cares about them enough to hack in code that will translate them into
+# terminfo capabilities.
+#
+# The first part of the list is from Ross Ridge's `mytinfo' package
+# (comp.sources.unix, volume 26); the variable names and terminfo names (as
+# well as the termcap codes) match his list.
+#
+# This group of codes is not marked obsolete in 4.4BSD, but have no direct
+# terminfo equivalents. The rs capability is specially translated to terminfo
+# r2, and vice versa, if an entry does not already have an r2. Similarly,
+# i2 is translated to r3 if there is no r3 (because SV terminfo maps is to i2).
+# The ug capability is thrown away, but assumed to be whatever sg is if the
+# latter is nonzero and we're dumping in termcap format.
+#
+termcap_init2 OTi2 str i2 YB--- secondary initialization string
+termcap_reset OTrs str rs YB-G- terminal reset string
+magic_cookie_glitch_ul OTug num ug YBCGE number of blanks left by ul
+#
+# Obsolete termcap capabilities. Some are used for termcap translation. The
+# code uses the 'OT' prefix we put on obsolete capabilities to suppress
+# printing them in terminfo source dumps of compiled entries.
+#
+backspaces_with_bs OTbs bool bs YBCGE uses ^H to move left
+crt_no_scrolling OTns bool ns YBCG- crt cannot scroll
+no_correctly_working_cr OTnc bool nc YBCG- no way to go to start of line
+carriage_return_delay OTdC num dC YB-G- pad needed for CR
+new_line_delay OTdN num dN YB-G- pad needed for LF
+linefeed_if_not_lf OTnl str nl YBCGE use to move down
+backspace_if_not_bs OTbc str bc YBCGE move left, if not ^H
+#
+# GNU termcap library extensions. The GNU termcap file distributed with
+# Emacs no longer uses these, but MT showed up in pre-9.0 versions of the
+# BSD termcap file. The name clash with terminfo MT is resolved by type
+# info; MT is converted to km.
+#
+gnu_has_meta_key OTMT bool MT ----E has meta key
+# gnu_tab_width OTtw num tw ----E tab width in spaces
+#
+# GNU termcap *does* include the following extended capability, Only the
+# now-obsolete Ann Arbor terminals used it.
+#
+# gnu_change_scroll_region OTcS str cS ---GE alternate set scrolling region
+#
+# The following comments describe capnames so ancient that I believe no
+# software uses them any longer. Some of these have to go because they
+# clash with terminfo names in ways that cannot be resolved by type
+# information.
+#
+# These mytinfo codes are not used in the 4.4BSD curses code. They are
+# marked obsolete in the 4.4BSD manual pages.
+#
+# There is one conflict with terminfo; ma is in both. This conflict is
+# resolved by type information.
+#
+# The `ko' capability is translated by special code. It should contain a
+# comma-separated list of capabilities for which there are corresponding keys.
+# The `kn' code is accepted but ignored.
+#
+# The `ma' capability seems to have been designed to map between the rogue(2)
+# motion keys (including jkhl) and characters emitted by arrow keys on some
+# primitive pre-ANSI terminals. It's so obsolete it's fossilized...
+#
+# Here is a description of memory_lock_above and memory_unlock:
+# "You can 'freeze' data on the screen by turning on Memory Lock in a line of
+# text. All lines above the cursor's current line become locked in place on
+# the screen. Then enter data normally. When the screen fills up, any
+# further data entered forces the first line of unfrozen line text to scroll
+# under the frozen data. Lines scrolled off the screen are inserted into
+# memory immediately preceding the first frozen line." (from the HP 700/96
+# User's manual). VT100/ANSI memory lock set is \E[>2h, reset is \E[>2l.
+#
+# Applications that use terminfo are supposed to behave as though xr is
+# always true.
+#
+linefeed_is_newline OTNL bool NL YB--- move down with \n
+# even_parity OTEP bool EP -B--- terminal requires even parity
+# odd_parity OTOP bool OP -B--- terminal requires odd parity
+# half_duplex OTHD bool HD -B--- terminal is half-duplex
+# lower_case_only OTLC bool LC -B--- terminal has only lower case
+# upper_case_only OTUC bool UC -B--- terminal has only upper case
+backspace_delay OTdB num dB YB-G- padding required for ^H
+# form_feed_delay OTdF num dF -B-G- padding required for ^L
+horizontal_tab_delay OTdT num dT YB-G- padding required for ^I
+# vertical_tab_delay OTdV num dV -B--- padding required for ^V
+number_of_function_keys OTkn num kn -B-G- count of function keys
+other_non_function_keys OTko str ko -B-G- list of self-mapped keycaps
+arrow_key_map OTma str ma YBC-- map arrow keys rogue(1) motion keys
+# memory_lock_above OTml str ml -B--- lock visible screen memory above the current line
+# memory_unlock OTmu str mu -B--- unlock visible screen memory above the current line
+has_hardware_tabs OTpt bool pt YB--- has 8-char tabs invoked with ^I
+return_does_clr_eol OTxr bool xr YB--- return clears the line
+# tek_4025_insert_line OTxx bool xx -BC-- Tektronix 4025 insert-line glitch
+#
+# mytinfo described this as a termcap capability, but it's not listed in the
+# 4.4BSD man pages, and not found in the 4.4BSD termcap file. The ncurses
+# package, like System V, behaves as though it is always true.
+#
+# rind_only_at_top OTxq bool xq ----- reverse index only works from top line
+#
+# University of Waterloo termcap extensions (as described in mytinfo).
+# The `xl' termcap file clashes with a terminfo name; this ambiguity cannot
+# be resolved by a type check. The descriptions are guesses from what was
+# in the mytinfo tables.
+#
+# key_interrupt_char OTki str ki ----- string set by interrupt key (?)
+# key_kill_char OTkk str kk ----- string set by kill key (?)
+# key_suspend_char OTkz str kz ----- string set by suspend key (?)
+# initialization_messy OTxc bool xc ----- initialization leaves garbage on the screen (?)
+# ind_at_bottom_does_cr OTxl bool xl ----- index does a carriage return
+#
+# Nonstandard capabilities unique to Ross Ridge's `mytinfo' package.
+# SR clashes with a terminfo name; this ambiguity cannot be resolved by a type
+# check.
+#
+# scroll_left OTsl1 str Sl ----- scroll screen leftward
+# scroll_right OTsr1 str Sr ----- scroll screen rightward
+# parm_scroll_left OTsl str SL ----- scroll screen leftward #1 characters
+# parm_scroll_right OTsr str SR ----- scroll screen rightward #1 characters
+#
+# The mytinfo capabilities end here.
+#
+# XENIX extensions:
+#
+# Xenix defined its own set of forms-drawing capabilities:
+#
+# cap IBM ASCII description ACS ASCII
+# --- ----------- -------------------- ------------- ------
+# G1 191 \277 M-? single upper right ACS_URCORNER
+# G2 218 \332 M-Z single upper left ACS_ULCORNER
+# G3 192 \300 M-@ single lower left ACS_LLCORNER
+# G4 217 \331 M-Y single lower right ACS_LRCORNER
+# G5 187 \273 M-; double upper right
+# G6 201 \311 M-I double upper left
+# G7 200 \310 M-H double lower left
+# G8 188 \274 M-< double lower right
+# GC 197 \305 M-E single intersection ACS_PLUS _ _
+# GD 194 \302 M-B single down-tick ACS_TTEE |
+# GH 196 \304 M-D single horizontal line ACS_HLINE
+# GL 180 \264 M-4 single left tick ACS_RTEE -|
+# GR 195 \303 M-C single right tick ACS_LTEE |-
+# GU 193 \301 M-A single up tick ACS_BTEE _|_
+# GV 179 \263 M-3 single vertical line ACS_VLINE
+# Gc 206 \316 M-N double intersection
+# Gd 203 \313 M-K double down tick
+# Gh 205 \315 M-M double horizontal line
+# Gl 204 \204 M-L double left tick
+# Gr 185 \271 M-9 double right tick
+# Gu 202 \312 M-J double up tick
+# Gv 186 \272 M-: double vertical line
+#
+# The compiler will translate the single-line caps and discard the others
+# (via IGNORE aliases further down). We don't want to do normal pad
+# translation on these, they're often single-character printable ASCII
+# strings that happen to be numerics. There's awk code in parametrized.sh
+# that detects the acs_ prefix and uses it to suppress pad translation.
+# These terminfo names are invented.
+#
+acs_ulcorner OTG2 str G2 ----- single upper left
+acs_llcorner OTG3 str G3 ----- single lower left
+acs_urcorner OTG1 str G1 ----- single upper right
+acs_lrcorner OTG4 str G4 ----- single lower right
+acs_ltee OTGR str GR ----- tee pointing right
+acs_rtee OTGL str GL ----- tee pointing left
+acs_btee OTGU str GU ----- tee pointing up
+acs_ttee OTGD str GD ----- tee pointing down
+acs_hline OTGH str GH ----- single horizontal line
+acs_vline OTGV str GV ----- single vertical line
+acs_plus OTGC str GC ----- single intersection
+#
+#############################################################################
+#
+# TERMINFO EXTENSION CAPABILITIES
+#
+# This section is almost all comments. What it's mainly for is to describe
+# what capabilities need to be squeezed out to get down to the XSI Curses
+# standard set. They are flagged with K.
+#
+# HP extensions
+#
+# These extensions follow ptr_non (replacing everything after it) in HP
+# terminfo files. Except for memory_lock and memory_unlock, they are
+# functionally identical to SVr4 extensions, but they make the binary format
+# different. Grrr....
+#
+memory_lock meml str ml ----K memory lock above
+memory_unlock memu str mu ----K memory unlock
+#plab_norm pln str pn ----- program label #1 to show string #2
+#label_on smln str LO ----- turn on soft labels
+#label_off rmln str LF ----- turn off soft labels
+#key_f11 kf11 str F1 ----- F11 function key
+#key_f12 kf12 str F2 ----- F12 function key
+#key_f13 kf13 str F3 ----- F13 function key
+#key_f14 kf14 str F4 ----- F14 function key
+#key_f15 kf15 str F5 ----- F15 function key
+#key_f16 kf16 str F6 ----- F16 function key
+#key_f17 kf17 str F7 ----- F17 function key
+#key_f18 kf18 str F8 ----- F18 function key
+#key_f19 kf19 str F9 ----- F19 function key
+#key_f20 kf20 str FA ----- F20 function key
+#key_f21 kf21 str FB ----- F21 function key
+#key_f22 kf22 str FC ----- F22 function key
+#key_f23 kf23 str FD ----- F23 function key
+#key_f24 kf24 str FE ----- F24 function key
+#key_f25 kf25 str FF ----- F25 function key
+#key_f26 kf26 str FG ----- F26 function key
+#key_f27 kf27 str FH ----- F27 function key
+#key_f28 kf28 str FI ----- F28 function key
+#key_f29 kf29 str FJ ----- F29 function key
+#key_f30 kf30 str FK ----- F30 function key
+#key_f31 kf31 str FL ----- F31 function key
+#key_f32 kf32 str FM ----- F32 function key
+#key_f33 kf33 str FN ----- F33 function key
+#key_f34 kf34 str FO ----- F34 function key
+#key_f35 kf35 str FP ----- F35 function key
+#key_f36 kf36 str FQ ----- F36 function key
+#key_f37 kf37 str FR ----- F37 function key
+#key_f38 kf38 str FS ----- F38 function key
+#key_f39 kf39 str FT ----- F39 function key
+#key_f40 kf40 str FU ----- F40 function key
+#key_f41 kf41 str FV ----- F41 function key
+#key_f42 kf42 str FW ----- F42 function key
+#key_f43 kf43 str FX ----- F43 function key
+#key_f44 kf44 str FY ----- F44 function key
+#key_f45 kf45 str FZ ----- F45 function key
+#key_f46 kf46 str Fa ----- F46 function key
+#key_f47 kf47 str Fb ----- F47 function key
+#key_f48 kf48 str Fc ----- F48 function key
+#key_f49 kf49 str Fd ----- F49 function key
+#key_f50 kf50 str Fe ----- F50 function key
+#key_f51 kf51 str Ff ----- F51 function key
+#key_f52 kf52 str Fg ----- F52 function key
+#key_f53 kf53 str Fh ----- F53 function key
+#key_f54 kf54 str Fi ----- F54 function key
+#key_f55 kf55 str Fj ----- F55 function key
+#key_f56 kf56 str Fk ----- F56 function key
+#key_f57 kf57 str Fl ----- F57 function key
+#key_f58 kf58 str Fm ----- F58 function key
+#key_f59 kf59 str Fn ----- F59 function key
+#key_f60 kf60 str Fo ----- F60 function key
+#key_f61 kf61 str Fp ----- F61 function key
+#key_f62 kf62 str Fq ----- F62 function key
+#key_f63 kf63 str Fr ----- F63 function key
+#
+# IBM extensions
+#
+# These extensions follow ptr_non (replacing everything after it) in IBM
+# terminfo files.
+#
+# The places in the box[12] capabilities correspond to acsc characters, here is
+# the mapping:
+#
+# box1[0] = ACS_ULCORNER
+# box1[1] = ACS_HLINE
+# box1[2] = ACS_URCORNER
+# box1[3] = ACS_VLINE
+# box1[4] = ACS_LRCORNER
+# box1[5] = ACS_LLCORNER
+# box1[6] = ACS_TTEE
+# box1[7] = ACS_RTEE
+# box1[8] = ACS_BTEE
+# box1[9] = ACS_LTEE
+# box1[10] = ACS_PLUS
+#
+# The box2 characters are the double-line versions of these forms graphics.
+#
+box_chars_1 box1 str bx ----K box characters primary set
+#box_chars_2 box2 str by ----K box characters secondary set
+#box_attr_1 batt1 str Bx ----K attributes for box1
+#box_attr_2 batt2 str By ----K attributes for box2
+#color_bg_0 colb0 str d0 ----K background color 0
+#color_bg_1 colb1 str d1 ----K background color 1
+#color_bg_2 colb2 str d2 ----K background color 2
+#color_bg_3 colb3 str d3 ----K background color 3
+#color_bg_4 colb4 str d4 ----K background color 4
+#color_bg_5 colb5 str d5 ----K background color 5
+#color_bg_6 colb6 str d6 ----K background color 6
+#color_bg_7 colb7 str d7 ----K background color 7
+#color_fg_0 colf0 str c0 ----K foreground color 0
+#color_fg_1 colf1 str c1 ----K foreground color 1
+#color_fg_2 colf2 str c2 ----K foreground color 2
+#color_fg_3 colf3 str c3 ----K foreground color 3
+#color_fg_4 colf4 str c4 ----K foreground color 4
+#color_fg_5 colf5 str c5 ----K foreground color 5
+#color_fg_6 colf6 str c6 ----K foreground color 6
+#color_fg_7 colf7 str c7 ----K foreground color 7
+#font_0 font0 str f0 ----- select font 0
+#font_1 font1 str f1 ----- select font 1
+#font_2 font2 str f2 ----- select font 2
+#font_3 font3 str f3 ----- select font 3
+#font_4 font4 str f4 ----K select font 4
+#font_5 font5 str f5 ----K select font 5
+#font_6 font6 str f6 ----K select font 6
+#font_7 font7 str f7 ----K select font 7
+#key_back_tab kbtab str k0 ----- backtab key
+#key_do kdo str ki ----K do request key
+#key_command kcmd str kd ----K command-request key
+#key_command_pane kcpn str kW ----K command-pane key
+#key_end kend str kw ----- end key
+#key_help khlp str kq ----- help key
+#key_newline knl str nl ----K newline key
+#key_next_pane knpn str kv ----K next-pane key
+#key_prev_cmd kppn str kp ----K previous-command key
+#key_prev_pane kppn str kV ----K previous-pane key
+#key_quit kquit str kQ ----K quit key
+#key_select ksel str kU ----- select key
+#key_scroll_left kscl str kz ----K scroll left
+#key_scroll_right kscr str kZ ----K scroll right
+#key_tab ktab str ko ----K tab key
+#key_smap_in1 kmpf1 str Kv ----K special mapped key 1 input
+#key_smap_out1 kmpt1 str KV ----K special mapped key 1 output
+#key_smap_in2 kmpf2 str Kw ----K special mapped key 2 input
+#key_smap_out2 kmpt2 str KW ----K special mapped key 2 output
+#key_smap_in3 kmpf3 str Kx ----K special mapped key 3 input
+#key_smap_out3 kmpt3 str KX ----K special mapped key 3 output
+#key_smap_in4 kmpf4 str Ky ----K special mapped key 4 input
+#key_smap_out4 kmpt4 str KY ----K special mapped key 4 output
+#key_smap_in5 kmpf5 str Kz ----K special mapped key 5 input
+#key_smap_out5 kmpt5 str KZ ----K special mapped key 5 output
+#appl_defined_str apstr str za ----K application-defined string
+# The key_smap_in[6789] and key_smap_out[6789] capabilities aren't described in
+# the IBM manual pages, so the cap name strings are guesses. The terminfo
+# names are almost certainly right, the termcap ones almost certainly wrong.
+#key_smap_in6 kmpf6 str k! ----K special mapped key 6 input
+#key_smap_out6 kmpt6 str K@ ----K special mapped key 6 output
+#key_smap_in7 kmpf7 str k# ----K special mapped key 7 input
+#key_smap_out7 kmpt7 str K$ ----K special mapped key 7 output
+#key_smap_in8 kmpf8 str k% ----K special mapped key 8 input
+#key_smap_out8 kmpt8 str K^ ----K special mapped key 8 output
+#key_smap_in9 kmpf9 str k& ----K special mapped key 9 input
+#key_smap_out9 kmpt9 str K* ----K special mapped key 9 output
+# Undocumented capabilities end here
+#key_sf1 ksf1 str S1 ----K special function key 1
+#key_sf2 ksf2 str S2 ----K special function key 2
+#key_sf3 ksf3 str S3 ----K special function key 3
+#key_sf4 ksf4 str S4 ----K special function key 4
+#key_sf5 ksf5 str S5 ----K special function key 5
+#key_sf6 ksf6 str S6 ----K special function key 6
+#key_sf7 ksf7 str S7 ----K special function key 7
+#key_sf8 ksf8 str S8 ----K special function key 8
+#key_sf9 ksf9 str S9 ----K special function key 9
+#key_sf10 ksf10 str SA ----K special function key 10
+#key_f11 kf11 str k< ----- function key 11
+#key_f12 kf12 str k> ----- function key 12
+# The key_f13 through key_f64 capabilities aren't described in
+# the IBM manual pages, so the cap name strings are guesses. The terminfo
+# names are almost certainly right, the termcap ones certainly wrong.
+#key_f13 kf13 str k+ ----- function key 13
+#key_f14 kf14 str k+ ----- function key 14
+#key_f15 kf15 str k+ ----- function key 15
+#key_f16 kf16 str k+ ----- function key 16
+#key_f17 kf17 str k+ ----- function key 17
+#key_f18 kf18 str k+ ----- function key 18
+#key_f19 kf19 str k+ ----- function key 19
+#key_f20 kf20 str k+ ----- function key 20
+#key_f21 kf21 str k+ ----- function key 21
+#key_f22 kf22 str k+ ----- function key 22
+#key_f23 kf23 str k+ ----- function key 23
+#key_f24 kf24 str k+ ----- function key 24
+#key_f25 kf25 str k+ ----- function key 25
+#key_f26 kf26 str k+ ----- function key 26
+#key_f27 kf26 str k+ ----- function key 26
+#key_f28 kf28 str k+ ----- function key 28
+#key_f29 kf29 str k+ ----- function key 29
+#key_f30 kf30 str k+ ----- function key 30
+#key_f31 kf31 str k+ ----- function key 31
+#key_f32 kf31 str k+ ----- function key 32
+#key_f33 kf33 str k+ ----- function key 33
+#key_f34 kf34 str k+ ----- function key 34
+#key_f35 kf35 str k+ ----- function key 35
+#key_f36 kf36 str k+ ----- function key 36
+#key_f37 kf37 str k+ ----- function key 37
+#key_f38 kf38 str k+ ----- function key 38
+#key_f39 kf39 str k+ ----- function key 39
+#key_f40 kf40 str k+ ----- function key 40
+#key_f41 kf41 str k+ ----- function key 41
+#key_f42 kf42 str k+ ----- function key 42
+#key_f43 kf43 str k+ ----- function key 43
+#key_f44 kf44 str k+ ----- function key 44
+#key_f45 kf45 str k+ ----- function key 45
+#key_f46 kf46 str k+ ----- function key 46
+#key_f47 kf47 str k+ ----- function key 47
+#key_f48 kf48 str k+ ----- function key 48
+#key_f49 kf49 str k+ ----- function key 49
+#key_f50 kf50 str k+ ----- function key 50
+#key_f51 kf51 str k+ ----- function key 51
+#key_f52 kf52 str k+ ----- function key 52
+#key_f53 kf53 str k+ ----- function key 53
+#key_f54 kf54 str k+ ----- function key 54
+#key_f55 kf55 str k+ ----- function key 55
+#key_f56 kf56 str k+ ----- function key 56
+#key_f57 kf57 str k+ ----- function key 57
+#key_f58 kf58 str k+ ----- function key 58
+#key_f59 kf59 str k+ ----- function key 59
+#key_f60 kf60 str k+ ----- function key 60
+#key_f61 kf61 str k+ ----- function key 61
+#key_f62 kf62 str k+ ----- function key 62
+#key_f63 kf63 str k+ ----- function key 63
+# Undocumented capabilities end here.
+#key_action kact str kJ ----K sent by action key
+# The IBM docs say these capabilities are for table-drawing, and are
+# valid only for aixterm descriptions.
+#enter_topline_mode topl str tp ----K start top-line mode
+#enter_bottom_mode btml str bm ----K start bottom-line mode
+#enter_rvert_mode rvert str rv ----K start right-vertical mode
+#enter_lvert_mode lvert str lv ----K start left-vertical mode
+#
+#############################################################################
+#
+# ALIAS DECLARATIONS
+#
+# Here we set up aliases for translating extensions into standard terminfo.
+#
+#---------------------------------- Termcap aliases -------------------------
+#
+# BSD aliases:
+#
+# This is a common error in many termcap files. We'll get notified during
+# translation when this (or any other alias) fires.
+#
+capalias sb sr BSD scroll text down
+#
+# AT&T extensions:
+#
+# The old AT&T 5410, 5420, 5425, pc6300plus, 610, and s4 entries used a set of
+# nonstandard capabilities. Its signature is the KM capability, used to name
+# some sort of keymap file. EE, BO, CI, CV, XS, DS, FL and FE are in this
+# set. Comments in the original, and a little cross-checking with other AT&T
+# documentation, seem to establish the following mappings:
+#
+capalias BO mr AT&T enter_reverse_mode
+capalias CI vi AT&T cursor_invisible
+capalias CV ve AT&T cursor_normal
+capalias DS mh AT&T enter_dim_mode
+#capalias EE me AT&T exit_attribute_mode
+capalias FE LF AT&T label_on
+capalias FL LO AT&T label_off
+capalias XS mk AT&T enter_secure_mode
+#
+# We comment out EE because the conflicting XENIX EE is more common in
+# old entries.
+#
+# XENIX extensions:
+#
+# These are the ones we know how to translate directly:
+#
+capalias EE mh XENIX exit_attribute_mode
+capalias GE ae XENIX exit_alt_charset_mode
+capalias GS as XENIX enter_alt_charset_mode
+capalias CF vi XENIX cursor_invis
+capalias CO ve XENIX cursor_normal
+capalias EN @7 XENIX key_end
+capalias HM kh XENIX key_home
+capalias LD kL XENIX key_dl
+capalias PD kN XENIX key_npage
+capalias PN po XENIX prtr_off
+capalias PS pf XENIX prtr_on
+capalias PU kP XENIX key_ppage
+capalias RT @8 XENIX kent
+capalias UP ku XENIX kcuu1
+capalias G6 IGNORE XENIX double-ACS_ULCORNER
+capalias G7 IGNORE XENIX double-ACS_LLCORNER
+capalias G5 IGNORE XENIX double-ACS_URCORNER
+capalias G8 IGNORE XENIX double-ACS_LRCORNER
+capalias Gr IGNORE XENIX double-ACS_LTEE
+capalias Gr IGNORE XENIX double-ACS_RTEE
+capalias Gu IGNORE XENIX double-ACS_BTEE
+capalias Gd IGNORE XENIX double ACS_TTEE
+capalias Gh IGNORE XENIX double-ACS_HLINE
+capalias Gv IGNORE XENIX double-ACS_VLINE
+capalias Gc IGNORE XENIX double-ACS_PLUS
+capalias GG IGNORE XENIX acs-glitch
+#
+# IBM extensions:
+#
+capalias kq %1 IBM key_help
+#
+# Iris extensions:
+#
+capalias HS mh IRIS enter_dim_mode
+#
+# Tektronix extensions:
+#
+capalias KA k; Tek key_f10
+capalias KB F1 Tek key_f11
+capalias KC F2 Tek key_f12
+capalias KD F3 Tek key_f13
+capalias KE F4 Tek key_f14
+capalias KF F5 Tek key_f15
+capalias BC Sb Tek set_background
+capalias FC Sf Tek set_foreground
+#
+# There are also the following:
+#
+# XENIX XENIX variable name name clash with terminfo?
+# ----- ------------------- -------------------------
+# CL key_char_left
+# CR key_char_right
+# CW key_change_window
+# HP ??
+# LF key_linefeed label_off
+# NU key_next_unlocked_cell
+# PL ??
+# PR ??
+# RC key_recalc remove_clock
+# RF key_toggle_ref req_for_input
+# WL key_word_left
+# WR key_word_right
+#
+# If you know what any of the question-marked ones mean, please tell us.
+#
+#--------------------------------- Terminfo aliases ------------------------
+#
+# IBM extensions:
+#
+infoalias font0 s0ds IBM set0_des_seq
+infoalias font1 s1ds IBM set1_des_seq
+infoalias font2 s2ds IBM set2_des_seq
+infoalias font3 s3ds IBM set3_des_seq
+infoalias kbtab kcbt IBM key_backtab
+infoalias ksel kslt IBM key_select
+#
+# Some others are identical to SVr4/XPG4 capabilities, in particular:
+# kcmd, kend, khlp, and kf11...kf63.
+#
+#############################################################################
+#
+# The following sets edit modes for GNU EMACS
+# Local Variables:
+# case-fold-search:nil
+# truncate-lines:t
+# End: