terminfo.src (colored) for NCURSES


https://invisible-island.net/ncurses/
######## TERMINAL TYPE DESCRIPTIONS SOURCE FILE
#
# This version of terminfo.src is distributed with ncurses and is maintained
# by Thomas E. Dickey (TD).
#
# Report bugs and new terminal descriptions to
#       bug-ncurses@gnu.org
#
#       $Revision: 1.1153 $
#       $Date: 2024/10/05 16:04:17 $
#
# The original header is preserved below for reference.  It is noted that there
# is a "newer" version which differs in some cosmetic details (but actually
# stopped updates several years ago); we have decided to not change the header
# unless there is also a change in content.
#
# To further muddy the waters, it is noted that changes to this file as part of
# maintenance of ncurses (since 1996) are generally conceded to be copyright
# under the ncurses MIT-style license.  That was the effect of the agreement
# which the principal authors of ncurses made in 1998.  However, since much of
# the file itself is of unknown authorship (and the disclaimer below makes it
# obvious that Raymond cannot or will not convey rights over those parts),
# there is no explicit copyright notice on the file itself.
#
# It would also be a nuisance to split the file into unknown/known authorship
# and move pieces as they are maintained, since many of the maintenance changes
# have been small corrections to Raymond's translations to/from termcap format,
# correcting the data but not the accompanying annotations.
#
# In any case, note that almost half of this file is not data but annotations
# which reflect creative effort.  Furthermore, the structure of entries to
# reuse common chunks also is creative (and subject to copyright).  Finally,
# some portions of the data are derivative work under a compatible MIT-style
# license from xterm.
#
#------------------------------------------------------------------------------
https://invisible-island.net/ncurses/ncurses.faq.html#terminfo_copying
https://invisible-island.net/personal/copyrights.html#removing_notes
#------------------------------------------------------------------------------
#
#       Version 10.2.1
#       terminfo syntax
#
#       Eric S. Raymond         (current maintainer)
#       John Kunze, Berkeley
#       Craig Leres, Berkeley
#
# Please e-mail changes to terminfo@thyrsus.com; the old termcap@berkeley.edu
# address is no longer valid.  The latest version can always be found at
# <http://www.tuxedo.org/terminfo>.
#
# PURPOSE OF THIS FILE:
#
# This file describes the capabilities of various character-cell terminals,
# as needed by software such as screen-oriented editors.
#
# Other terminfo and termcap files exist, supported by various OS vendors
# or as relics of various older versions of UNIX.  This one is the longest
# and most comprehensive one in existence.  It subsumes not only the entirety
# of the historical 4.4BSD, GNU, System V and SCO termcap files and the BRL
# termcap file, but also large numbers of vendor-maintained termcap and
# terminfo entries more complete and carefully tested than those in historical
# termcap/terminfo versions.
#
# Pointers to related resources (including the ncurses distribution) may
# be found at <http://www.tuxedo.org/terminfo>.
#
# INTERNATIONALIZATION:
#
# This file uses only the US-ASCII character set (no ISO8859 characters).
#
# This file assumes a US-ASCII character set. If you need to fix this, start
# by global-replacing \E(B and \E)B with the appropriate ISO 6429 enablers
# for your character set.  \E(A and \E)A enables the British character set
# with the pound sign at position 2/3.
#
# In a Japanese-processing environment using EUC/Japanese or Shift-JIS,
# C1 characters are considered the first-byte set of the Japanese encodings,
# so \E)0 should be avoided in <enacs> and initialization strings.
#
# FILE FORMAT:
#
# The version you are looking at may be in any of three formats: master
# (terminfo with OT capabilities), stock terminfo, or termcap.  You can tell
# which by the format given in the header above.
#
# The master format is accepted and generated by the terminfo tools in the
# ncurses suite; it differs from stock (System V-compatible) terminfo only
# in that it admits a group of capabilities (prefixed `OT') equivalent to
# various obsolete termcap capabilities.  You can, thus, convert from master
# to stock terminfo simply by filtering with `sed "/OT[^,]*,/s///"'; but if
# you have ncurses `tic -I' is nicer (among other things, it automatically
# outputs entries in a canonical form).
#
# The termcap version is generated automatically from the master version
# using tic -C.  This filtering leaves in the OT capabilities under their
# original termcap names.  All translated entries fit within the 1023-byte
# string-table limit of archaic termcap libraries except where explicitly
# noted below.  Note that the termcap translation assumes that your termcap
# library can handle multiple tc capabilities in an entry. 4.4BSD has this
# capability.  Older versions of GNU termcap, through 1.3, do not.
#
# For details on these formats, see terminfo(5) in the ncurses distribution,
# and termcap(5) in the 4.4BSD Unix Programmer's Manual.  Be aware that 4.4BSD
# curses has been declared obsolete by the caretakers of the 4.4BSD sources
# as of June 1995; they are encouraging everyone to migrate to ncurses.
#
# Note: unlike some other distributed terminfo files (Novell Unix & SCO's),
# no entry in this file has embedded comments.  This is so source translation
# to termcap only has to carry over leading comments.  Also, no name field
# contains embedded whitespace (such whitespace confuses rdist).
#
# Further note: older versions of this file were often installed with an editor
# script (reorder) that moved the most common terminal types to the front of
# the file.  This should no longer be necessary, as the file is now ordered
# roughly by type frequency with ANSI/VT100 and other common types up front.
#
# Some information has been merged in from terminfo files distributed by
# USL and SCO (see COPYRIGHTS AND OTHER DELUSIONS below).  Much information
# comes from vendors who maintain official terminfos for their hardware
# (notably DEC and Wyse).
#
# A detailed change history is included at the end of this file.
#
# FILE ORGANIZATION:
#
# Comments in this file begin with # - they cannot appear in the middle
# of a terminfo/termcap entry (this feature had to be sacrificed in order
# to allow standard terminfo and termcap syntax to be generated cleanly from
# the master format).  Individual capabilities are commented out by
# placing a period between the colon and the capability name.
#
# The file is divided up into major sections (headed by lines beginning with
# the string "########") and minor sections (beginning with "####"); do
#
#       grep "^####" <file> | more
#
# to see a listing of section headings.  The intent of the divisions is
# (a) to make it easier to find things, and (b) to order the database so
# that important and frequently-encountered terminal types are near the
# front (so that you'll get reasonable search efficiency from a linear
# search of the termcap form even if you don't use reorder).  Minor sections
# usually correspond to manufacturers or standard terminal classes.
# Parenthesized words following manufacturer names are type prefixes or
# product line names used by that manufacturers.
#
# HOW TO READ THE ENTRIES:
#
# The first name in an entry is the canonical name for the model or
# type, last entry is a verbose description.  Others are mnemonic synonyms for
# the terminal.
#
# Terminal names look like <manufacturer> <model> - <modes/options>
# The part to the left of the dash, if a dash is present, describes the
# particular hardware of the terminal.  The part to the right may be used
# for flags indicating special ROMs, extra memory, particular terminal modes,
# or user preferences.
#
# All names should be in lower case, for consistency in typing.
#
# The following are conventionally used suffixes:
#       -2p     Has two pages of memory.  Likewise 4p, 8p, etc.
#       -am     Enable auto-margin.
#       -m      Monochrome.  Suppress color support
#       -mc     Magic-cookie.  Some terminals (notably older Wyses) can
#               only support one attribute without magic-cookie lossage.
#               Their base entry is usually paired with another that
#               uses magic cookies to support multiple attributes.
#       -nam    No auto-margin - suppress <am> capability
#       -nl     No labels - suppress soft labels
#       -ns     No status line - suppress status line
#       -rv     Terminal in reverse video mode (black on white)
#       -s      Enable status line.
#       -vb     Use visible bell (<flash>) rather than <bel>.
#       -w      Wide - in 132 column mode.
# If a name has multiple suffixes and one is a line height, that one should
# go first.  Thus `aaa-30-s-rv' is recommended over `aaa-s-rv-30'.
#
# Entries with embedded plus signs are designed to be included through use/tc
# capabilities, not used as standalone entries.
#
# To avoid search clashes, some older all-numeric names for terminals have
# been removed (i.e., "33" for the Model 33 Teletype, "2621" for the HP2621).
# All primary names of terminals now have alphanumeric prefixes.
#
# Comments marked "esr" are mostly results of applying the termcap-compiler
# code packaged with ncurses and contemplating the resulting error messages.
# In many cases, these indicated obvious fixes to syntax garbled by the
# composers.  In a few cases, I was able to deduce corrected forms for garbled
# capabilities by looking at context.  All the information in the original
# entries is preserved in the comments.
#
# In the comments, terminfo capability names are bracketed with <> (angle
# brackets).  Termcap capability names are bracketed with :: (colons).
#
# INTERPRETATION OF USER CAPABILITIES
#
# The System V Release 4 and XPG4 terminfo format defines ten string
# capabilities for use by applications, <u0>...<u9>.   In this file, we use
# certain of these capabilities to describe functions which are not covered
# by terminfo.  The mapping is as follows:
#
#       u9      terminal enquire string (equiv. to ANSI/ECMA-48 DA)
#       u8      terminal answerback description
#       u7      cursor position request (equiv. to VT100/ANSI/ECMA-48 DSR 6)
#       u6      cursor position report (equiv. to ANSI/ECMA-48 CPR)
#
# The terminal enquire string <u9> should elicit an answerback response
# from the terminal.  Common values for <u9> will be ^E (on older ASCII
# terminals) or \E[c (on newer VT100/ANSI/ECMA-48-compatible terminals).
#
# The cursor position request (<u7>) string should elicit a cursor position
# report.  A typical value (for VT100 terminals) is \E[6n.
#
# The terminal answerback description (u8) must consist of an expected
# answerback string.  The string may contain the following scanf(3)-like
# escapes:
#
#       %c      Accept any character
#       %[...]  Accept any number of characters in the given set
#
# The cursor position report (<u6>) string must contain two scanf(3)-style
# %d format elements.  The first of these must correspond to the Y coordinate
# and the second to the %d.  If the string contains the sequence %i, it is
# taken as an instruction to decrement each value after reading it (this is
# the inverse sense from the cup string).  The typical CPR value is
# \E[%i%d;%dR (on VT100/ANSI/ECMA-48-compatible terminals).
#
# These capabilities are used by tack(1m), the terminfo action checker
# (distributed with ncurses 5.0).
#
# TABSET FILES
#
# All the entries in this file have been edited to assume that the tabset
# files directory is /usr/share/tabset, in conformance with the File Hierarchy
# Standard for Linux and open-source BSD systems.  Some vendors (notably Sun)
# use /usr/lib/tabset or (more recently) /usr/share/lib/tabset.
#
# No curses package we know of actually uses these files.  If their location
# is an issue, you will have to hand-patch the file locations before compiling
# this file.
#
# REQUEST FOR CONTACT INFORMATION AND HISTORICAL MATERIAL
#
# As the ANSI/ECMA-48 standard and variants take firmer hold, and as
# character-cell terminals are increasingly replaced by X displays, much of
# this file is becoming a historical document (this is part of the reason for
# the new organization, which puts ANSI types, xterm, Unix consoles,
# and vt100 up front in confidence that this will catch 95% of new hardware).
#
# For the terminal types still alive, I'd like to have manufacturer's
# contact data (Internet address and/or snail-mail + phone).
#
# I'm also interested in enriching the comments so that the latter portions of
# the file do in fact become a potted history of VDT technology as seen by
# UNIX hackers.  Ideally, I'd like the headers for each manufacturer to
# include its live/dead/out-of-the-business status, and for as many
# terminal types as possible to be tagged with information like years
# of heaviest use, popularity, and interesting features.
#
# I'm especially interested in identifying the obscure entries listed under
# `Miscellaneous obsolete terminals, manufacturers unknown' before the tribal
# wisdom about them gets lost.  If you know a lot about obscure old terminals,
# please go to the terminfo resource page, grab the UFO file (ufo.ti), and
# eyeball it for things you can identify and describe.
#
# If you have been around long enough to contribute, please read the file
# with this in mind and send me your annotations.
#
# COPYRIGHTS AND OTHER DELUSIONS
#
# The BSD ancestor of this file had a standard Regents of the University of
# California copyright with dates from 1980 to 1993.
#
# Some information has been merged in from a terminfo file SCO distributes.
# It has an obnoxious boilerplate copyright which I'm ignoring because they
# took so much of the content from the ancestral BSD versions of this file
# and didn't attribute it, thereby violating the BSD Regents' copyright.
#
# Not that anyone should care.  However many valid functions copyrights may
# serve, putting one on a termcap/terminfo file with hundreds of anonymous
# contributors makes about as much sense as copyrighting a wall-full of
# graffiti -- it's legally dubious, ethically bogus, and patently ridiculous.
#
# This file deliberately has no copyright.  It belongs to no one and everyone.
# If you claim you own it, you will merely succeed in looking like a fool.
# Use it as you like.  Use it at your own risk.  Copy and redistribute freely.
# There are no guarantees anywhere.  Svaha!
#

######## ANSI, UNIX CONSOLE, AND SPECIAL TYPES
#
# This section describes terminal classes and brands that are still
# quite common.
#

#### Specials
#
# Special "terminals".  These are used to label tty lines when you don't
# know what kind of terminal is on it.  The characteristics of an unknown
# terminal are the lowest common denominator - they look about like a ti 700.
#

dumb|80-column dumb tty,
        am,
        cols#80,
        bel=^Gcr=\rcud1=\nind=\n,
unknown|unknown terminal type,
        gnuse=dumb,
lpr|printer|line printer,
        OTbs, hcos,
        cols#132lines#66,
        bel=^Gcr=\rcub1=^Hcud1=\nff=^Lind=\n,
glasstty|classic glass tty interpreting ASCII control characters,
        OTbs, am,
        cols#80,
        bel=^Gclear=^Lcr=\rcub1=^Hcud1=\nht=^Ikcub1=^H,
        kcud1=\nnel=\r\n.kbs=^H,

vanilla|dumb tty,
        OTbs,
        bel=^Gcr=\rcud1=\nind=\n,

# This is almost the same as "dumb", but with no prespecified width.
# DEL and ^C are hardcoded to act as kill characters.
# ^D acts as a line break (just like newline).
# It also interprets
#      \033];xxx\007
# for compatibility with xterm -TD
9term|Plan9 terminal emulator for X,
        am,
        OTnl=\nbel=^Gcud1=\n,

#### ANSI.SYS/ISO 6429/ECMA-48 Capabilities
#
# See the end-of-file comment for more on these.
#

# ANSI capabilities are broken up into pieces, so that a terminal
# implementing some ANSI subset can use many of them.
ansi+local1|ANSI normal-mode cursor-keys,
        cub1=\E[Dcud1=\E[Bcuf1=\E[Ccuu1=\E[A,
ansi+local|ANSI normal-mode parameterized cursor-keys,
        cub=\E[%p1%dDcud=\E[%p1%dBcuf=\E[%p1%dC,
        cuu=\E[%p1%dAuse=ansi+local1,
ansi+tabs|ANSI tab-stops,
        cbt=\E[Zht=^Ihts=\EHtbc=\E[3g,
ansi+inittabs|ANSI initial tab-stops,
        it#8use=ansi+tabs,
ansi+erase|ANSI clear screen/line,
        clear=\E[H\E[Jed=\E[Jel=\E[K,
ansi+rca|ANSI relative cursor-addressing (1-based),
        hpa=\E[%p1%{1}%+%dGvpa=\E[%p1%{1}%+%dd,
ansi+rca2|ANSI relative cursor-addressing,
        hpa=\E[%i%p1%dGvpa=\E[%i%p1%dd,
ansi+cup|ANSI absolute cursor-addressing,
        cup=\E[%i%p1%d;%p2%dHhome=\E[H,
ansi+rep|ANSI repeat-character,
        rep=%p1%c\E[%p2%{1}%-%db,
ansi+idl1|ANSI insert/delete one line,
        dl1=\E[Mil1=\E[L,
ansi+idl|ANSI insert/delete lines,
        dl=\E[%p1%dMil=\E[%p1%dLuse=ansi+idl1,
ansi+idc1|ANSI insert/delete one character,
        dch1=\E[Pich1=\E[@rmir=\E[4lsmir=\E[4h,
ansi+idc|ANSI insert/delete characters,
        dch=\E[%p1%dPich=\E[%p1%d@use=ansi+idc1,
ansi+arrows|ANSI normal-mode home and cursor-keys,
        kbs=^Hkcub1=\E[Dkcud1=\E[Bkcuf1=\E[Ckcuu1=\E[A,
        khome=\E[H,
ansi+apparrows|ANSI application-mode home and cursor-keys,
        kcub1=\EODkcud1=\EOBkcuf1=\EOCkcuu1=\EOAkhome=\EOH,
        use=ansi+arrows,
ansi+sgr|ANSI graphic renditions,
        blink=\E[5minvis=\E[8mrev=\E[7m,
        sgr=\E[0%?%p3%t;7%;%?%p4%t;5%;%?%p7%t;8%;m,
        sgr0=\E[0m,
ansi+sgrso|ANSI standout only,
        rmso=\E[msmso=\E[7m,
ansi+sgrul|ANSI underline only,
        rmul=\E[msmul=\E[4m,
ansi+sgrbold|ANSI graphic renditions; assuming terminal has bold; not dim,
        bold=\E[1m,
        sgr=\E[%?%p1%t7;%;%?%p2%t4;%;%?%p3%t7;%;%?%p4%t5;%;%?%p6%t1;
            %;%?%p7%t8;%;m
,
        use=ansi+sgruse=ansi+sgrsouse=ansi+sgrul,
ansi+sgrdim|ANSI graphic renditions; assuming terminal has dim; not bold,
        dim=\E[2m,
        sgr=\E[%?%p1%t7;%;%?%p2%t4;%;%?%p3%t7;%;%?%p4%t5;%;%?%p5%t2;
            %;%?%p7%t8;%;m
,
        use=ansi+sgruse=ansi+sgrsouse=ansi+sgrul,

# ECMA-48 does not specify scroll-regions, but most people consider it to be
# "ANSI" because it is widely-supported.  See ecma+index for the standard form.
ansi+csr|ANSI scroll-region plus cursor save & restore,
        csr=\E[%i%p1%d;%p2%drrc=\E8sc=\E7,

# The normal (ANSI) flavor of "media copy" building block asserts that
# characters sent to the printer do not echo on the screen. DEC terminals
# can also be put into autoprinter mode, where each line is sent to the
# printer as you move off that line, e.g., by a carriage return.
ansi+pp|ANSI printer port,
        mc5i,
        mc0=\E[imc4=\E[4imc5=\E[5i,
dec+pp|DEC autoprinter mode,
        mc0=\E[imc4=\E[?4imc5=\E[?5i,

# The IBM PC alternate character set.  Plug this into any Intel console entry.
# We use \E[11m for rmacs rather than \E[12m so the <acsc> string can use the
# ROM graphics for control characters such as the diamond, up- and down-arrow.
# This works with the System V, Linux, and BSDI consoles.  It's a safe bet this
# will work with any Intel console, they all seem to have inherited \E[11m
# from the ANSI.SYS de-facto standard.
klone+acs|alternate character set for ansi.sys displays,
        acsc=+\020\,\021-\030.^Y0\333`\004a\261f\370g\361h\260j
             \331k\277l\332m\300n\305o~p\304q\304r\304s_t\303u\264v
             \301w\302x\263y\363z\362{\343|\330}\234~\376
,
        rmacs=\E[10msmacs=\E[11m,

# Highlight controls corresponding to the ANSI.SYS standard.  Most
# console drivers for Intel boxes obey these.  Makes the same assumption
# about \E[11m as klone+acs.  True ANSI/ECMA-48 would have <rmso=\E[27m>,
# <rmul=\E[24m>, but this isn't a documented feature of ANSI.SYS.
klone+sgr|attribute control for ansi.sys displays,
        blink=\E[5mbold=\E[1mrev=\E[7mrmpch=\E[10m,
        rmso=\E[mrmul=\E[m,
        sgr=\E[0;10%?%p1%t;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p6
            %t;1%;%?%p9%t;11%;m
,
        sgr0=\E[0;10msmpch=\E[11msmso=\E[7msmul=\E[4m,
        use=klone+acs,

# Most Intel boxes do not treat "invis" (invisible) text.
klone+sgr8|attribute control for ansi.sys displays with invis,
        invis=\E[8m,
        sgr=\E[0;10%?%p1%t;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p6
            %t;1%;%?%p7%t;8%;%?%p9%t;11%;m
,
        use=klone+sgr,

# Highlight controls corresponding to the ANSI.SYS standard.  *All*
# console drivers for Intel boxes obey these.  Does not assume \E[11m will
# work; uses \E[12m instead, which is pretty bulletproof but loses you the ACS
# diamond and arrow characters under curses.
klone+sgr-dumb|attribute control for ansi.sys displays (no ESC [ 11 m),
        sgr=\E[0;10%?%p1%t;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p6
            %t;1%;%?%p7%t;8%;%?%p9%t;12%;m
,
        sgr0=\E[0;10msmacs=\E[12muse=ansi+sgrbold,
        use=klone+acs,

# KOI8-R (RFC1489) acs (alternate character set)
# From: Qing Long <qinglong@Bolizm.ihep.su>, 24 Feb 1996.
klone+koi8acs|alternate character set for ansi.sys displays with KOI8 charset,
        acsc=+\020\,\021-\036.^_0\215`\004a\237f\234g\232h\222i
             \220j\205k\203l\202m\204n\212o\213p\216q\0r\217s\214t
             \206u\207v\210w\211x\201y\230z\231{\267|\274}L~
             \225
,
        rmacs=\E[10msmacs=\E[11m,

# ANSI.SYS color control.  The setab/setaf caps depend on the coincidence
# between SVr4/XPG4's color numbers and ANSI.SYS attributes.  Here are longer
# but equivalent strings that don't rely on that coincidence:
# setb=\E[4%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}%=%t3%e%p1%d%;m,
# setf=\E[3%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}%=%t3%e%p1%d%;m,
# The DOS 5 manual asserts that these sequences meet the ISO 6429 standard.
# They match a subset of ECMA-48.
klone+color|color control for ansi.sys and ISO6429-compatible displays,
        colors#8ncv#3pairs#64,
        op=\E[37;40msetab=\E[4%p1%dmsetaf=\E[3%p1%dm,

# This is better than klone+color, it doesn't assume white-on-black as the
# default color pair,  but many `ANSI' terminals don't grok the <op> cap.
ecma+color|color control for ECMA-48-compatible terminals,
        AX,
        op=\E[39;49muse=klone+color,

ecma+italics|ECMA-48 italics,
        ritm=\E[23msitm=\E[3m,

# Attribute control for ECMA-48-compatible terminals
ecma+sgr|attribute capabilities for true ECMA-48 terminals,
        rmso=\E[27mrmul=\E[24muse=klone+sgr8,

ecma+strikeout|ECMA-48 strikeout/crossed-out,
        rmxx=\E[29m, smxx=\E[9m,

# ECMA-48 does not include the VT100 indexing and scroll-margins.  It has its
# own variation.
ecma+index|ECMA-48 scroll up/down,
        indn=\E[%p1%dSrin=\E[%p1%dT,

# For comparison, here are all the capabilities implied by the Intel
# Binary Compatibility Standard (level 2) that fit within terminfo.
# For more detail on this rather pathetic standard, see the comments
# near the end of this file.
ibcs2|Intel Binary Compatibility Standard prescriptions,
        cbt=\E[Zclear=\Eccub1=\E[1Dcud1=\E[1Bcuf1=\E[1C,
        cup=\E[%i%p1%d;%p2%dHcuu1=\E[1Adch=\E[%p1%dP,
        dispc=\E=%p1%dgech=\E[%p1%dXhpa=\E[%i%p1%dGhts=\EH,
        ich=\E[%p1%d@ich1=\E[@il=\E[%p1%dLrc=\E7,
        rmam=\E[?7lsc=\E7smam=\E[?7htbc=\E[g,
        vpa=\E[%i%p1%dduse=ansi+localuse=ecma+index,

#### ANSI/ECMA-48 terminals and terminal emulators
#
# See near the end of this file for details on ANSI conformance.
# Don't mess with these entries!  Lots of other entries depend on them!
#
# This section lists entries in a least-capable to most-capable order.
# if you're in doubt about what `ANSI' matches yours, try them in that
# order and back off from the first that breaks.

# ansi-mr is for ANSI terminals with ONLY relative cursor addressing
# and more than one page of memory.  It uses local motions instead of
# direct cursor addressing, and makes almost no assumptions. It does
# assume auto margins, no padding and/or xon/xoff, and a 24x80 screen.
ansi-mr|mem rel cup ANSI,
        amxon,
        cols#80lines#24use=vanillause=ansi+erase,
        use=ansi+local1,

# ansi-mini is a bare minimum ANSI terminal. This should work on anything, but
# beware of screen size problems and memory relative cursor addressing.
ansi-mini|any ANSI terminal with pessimistic assumptions,
        amxon,
        cols#80lines#24use=vanillause=ansi+cup,
        use=ansi+erase,

# ansi-mtabs adds relative addressing and minimal tab support
ansi-mtabs|any ANSI terminal with pessimistic assumptions (relative addressing),
        it#8,
        ht=^Iuse=ansi-miniuse=ansi+local1,

# ANSI X3.64 from emory!mlhhh (Hugh Hansard) via BRL
#
# The following is an entry for the full ANSI 3.64 (1977).  It lacks
# padding, but most terminals using the standard are "fast" enough
# not to require any -- even at 9600 bps.  If you encounter problems,
# try including the padding specifications.
#
# Note: the :as: and :ae: specifications are not implemented here, for
# the available termcap documentation does not make clear WHICH alternate
# character set to specify.  ANSI 3.64 seems to make allowances for several.
# Please make the appropriate adjustments to fit your needs -- that is
# if you will be using alternate character sets.
#
# There are very few terminals running the full ANSI 3.64 standard,
# so I could only test this entry on one verified terminal (Visual 102).
# I would appreciate the results on other terminals sent to me.
#
# Please report comments, changes, and problems to:
#
# U.S. MAIL:   Hugh Hansard
#              Box: 22830
#              Emory University
#              Atlanta, GA. 30322.
#
# USENET {akgua,msdc,sb1,sb6,gatech}!emory!mlhhh.
#
# (Added vt100 <rc>,<sc> to quiet a tic warning --esr)
ansi77|ANSI 3.64 standard 1977 version,
        OTbs, ammir,
        cols#80it#8lines#24,
        bel=^Gclear=\E[;H\E[2Jcr=\rcub1=^H,
        cup=\E[%i%p1%d;%p2%dHdch1=\E[Pdl1=\E[M$<5*/>,
        ed=\E[Jel=\E[Khome=\E[Hht=^Iil1=\E[L$<5*/>ind=\ED,
        kf1=\EOPkf2=\EORkf4=\EOSnel=\r\EDri=\EMrmir=\E[4l,
        rmso=\E[mrmul=\E[msmir=\E[4hsmso=\E[7msmul=\E[4m,
        use=ansi+arrowsuse=ansi+csruse=ansi+local1,

# Procomm and some other ANSI emulations don't recognize all of the ANSI-
# standard capabilities.  This entry deletes <cuu>, <cuf>, <cud>, <cub>, and
# <vpa>/<hpa> capabilities, forcing curses to use repetitions of <cuu1>,
# <cuf1>, <cud1> and <cub1>.  Also deleted <ich> and <ich1>, as QModem up to
# 5.03 doesn't recognize these.  Finally, we delete <rep> and <ri>, which seem
# to confuse many emulators.  On the other hand, we can count on these programs
# doing <rmacs>/<smacs>/<sgr>. Older versions of this entry featured
# <invis=\E[9m>, but <invis=\E[8m> now seems to be more common under
# ANSI.SYS influence.
# From: Eric S. Raymond <esr@snark.thyrsus.com> Oct 30 1995
pcansi-m|pcansi-mono|ibm-pc terminal programs claiming to be ANSI (mono mode),
        OTbs, ammirmsgr,
        cols#80lines#24,
        bel=^Gcr=\rcup=\E[%i%p1%d;%p2%dHdch1=\E[Pdl1=\E[M,
        home=\E[Hht=^Iil1=\E[Lind=\nuse=ansi+arrows,
        use=ansi+eraseuse=ansi+inittabsuse=ansi+local1,
        use=klone+sgr-dumb,

pcansi-25-m|pcansi25m|ibm-pc terminal programs with 25 lines (mono mode),
        lines#25use=pcansi-m,
pcansi-33-m|pcansi33m|ibm-pc terminal programs with 33 lines (mono mode),
        lines#33use=pcansi-m,
pcansi-43-m|ansi43m|ibm-pc terminal programs with 43 lines (mono mode),
        lines#43use=pcansi-m,
# The color versions.  All PC emulators do color...
pcansi|ibm-pc terminal programs claiming to be ANSI,
        use=klone+coloruse=pcansi-m,
pcansi-25|pcansi25|ibm-pc terminal programs with 25 lines,
        lines#25use=pcansi,
pcansi-33|pcansi33|ibm-pc terminal programs with 33 lines,
        lines#33use=pcansi,
pcansi-43|pcansi43|ibm-pc terminal programs with 43 lines,
        lines#43use=pcansi,

# ansi-m -- full ANSI X3.64 with ANSI.SYS-compatible attributes, no color.
# If you want pound signs rather than dollars, replace `B' with `A'
# in the <s0ds>, <s1ds>, <s2ds>, and <s3ds> capabilities.
# From: Eric S. Raymond <esr@snark.thyrsus.com> Nov 6 1995
ansi-m|ansi-mono|ANSI X3.64-1979 terminal with ANSI.SYS compatible attributes,
        mc5i,
        dch=\E[%p1%dPdl=\E[%p1%dMech=\E[%p1%dXel1=\E[1K,
        hpa=\E[%i%p1%dGht=\E[Iich=\E[%p1%d@il=\E[%p1%dL,
        kcbt=\E[Zkich1=\E[Lmc4=\E[4imc5=\E[5inel=\r\E[S,
        rep=%p1%c\E[%p2%{1}%-%dbs0ds=\E(Bs1ds=\E)B,
        s2ds=\E*Bs3ds=\E+Bvpa=\E[%i%p1%dduse=ansi+local,
        use=ecma+indexuse=pcansi-m,

# ECMA-48 addresses three of the four capabilities here:
#
# u6 -
#       8.3.14 CPR - ACTIVE POSITION REPORT
#       Notation: (Pn1;Pn2) Representation: CSI Pn1;Pn2 05/02
#       Parameter default values: Pn1 = 1; Pn2 = 1
#
# u7
#       8.3.35 DSR - DEVICE ST A TUS REPORT
#       Notation: (Ps) Representation: CSI Ps 06/14
#       Parameter default value: Ps = 0
#       DSR is used either to report the status of the sending device or to
#       request a status report from the receiving device, depending on the
#       parameter values:
#       6 a report of the active presentation position or of the active data
#         position in the form of ACTIVE POSITION REPORT (CPR) is requested
#
# u9 -
#       8.3.24 DA - DEVICE ATTRIBUTES
#       Notation: (Ps) Representation: CSI Ps 06/03
#       Parameter default value: Ps = 0
#       With a parameter value not equal to 0, DA is used to identify the
#       device which sends the DA.  The parameter value is a device type
#       identification code according to a register which is to be established. 
#       If the parameter value is 0, DA is used to request an identifying DA
#       from a device.
#
# DEC (and most "ANSI") terminals reply with a private-mode ("?") sequence,
# but that register "which is to be" in ECMA-48 was never established.
# For terminals that support DA1, a more specific u8 capability is preferred,
# except for those (such as xterm) which can be configured to return different
# responses.
ansi+cpr|ncurses extension for ANSI CPR,
        u6=\E[%i%d;%dRu7=\E[6n,
ansi+enq|ncurses extension for ANSI ENQ,
        u8=\E[?%[;0123456789]cu9=\E[cuse=ansi+cpr,
# DEC terminals provided DECID, subsumed into DA1:
decid+cpr|ncurses extension for DECID,
        u8=\E[?%[;0123456789]cu9=\EZuse=ansi+cpr,

# ansi -- this terminfo expresses the largest subset of X3.64 that will fit in
# standard terminfo.  Assumes ANSI.SYS-compatible attributes and color.
# From: Eric S. Raymond <esr@snark.thyrsus.com> Nov 6 1995
ansi|ansi/pc-term compatible with color,
        use=ansi+enquse=ecma+coloruse=klone+sgr8use=ansi-m,

# ansi-generic is a vanilla ANSI terminal. This is assumed to implement
# all the normal ANSI stuff with no extensions. It assumes
# insert/delete line/char is there, so it won't work with
# VT100 clones. It assumes video attributes for bold, blink,
# underline, and reverse, which won't matter much if the terminal
# can't do some of those. Padding is assumed to be zero, which
# shouldn't hurt since xon/xoff is assumed.
ansi-generic|ansiterm|generic ANSI standard terminal,
        amxon,
        cols#80lines#24use=vanillause=ansi+csruse=ansi+cup,
        use=ansi+rcause=ansi+eraseuse=ansi+tabs,
        use=ansi+localuse=ansi+idcuse=ansi+idluse=ansi+rep,
        use=ansi+sgrbolduse=ansi+arrows,

#### DOS ANSI.SYS variants
#
# This completely describes the sequences specified in the DOS 2.1 ANSI.SYS
# documentation (except for the keyboard key reassignment feature, which
# doesn't fit the <pfkey> model well).  The klone+acs sequences were valid
# though undocumented.  The <pfkey> capability is untested but should work for
# keys F1-F10 (%p1 values outside this range will yield unpredictable results).
# From: Eric S. Raymond <esr@snark.thyrsus.com> Nov 7 1995
#
# DOS 2.0 (January 1983) documented these features in
# Chapter 13, "Using Extended Screen and Keyboard Control" -TD
ansi.sys-old|ANSI.SYS under PC-DOS 2.0,
        OTbs, ammirmsgrxon,
        cols#80lines#25,
        clear=\E[2Jcub1=^Hcup=\E[%i%p1%d;%p2%dHel=\E[k,
        home=\E[His2=\E[m\E[?7hkcub1=^Hkcud1=\nkcuf1=^L,
        kcuu1=^Kkhome=^^pfkey=\E[0;%p1%{58}%+%d;%p2"%s"p,
        rc=\E[urmam=\E[?7lsc=\E[ssmam=\E[?7huse=ansi+cpr,
        use=ansi+local1use=klone+coloruse=klone+sgr8,

# Keypad:       Home=\0G        Up=\0H  PrPag=\0I
#               ka1,kh          kcuu1           kpp,ka3
#
#               Left=\0K        5=\0L           Right=\0M
#               kcub1           kb2             kcuf1
#
#               End=\0O         Down=\0P        NxPag=\0Q
#               kc1,kend        kcud1           kc3,knp
#
#               Ins=\0R         Del=\0S
#               kich1           kdch1
#
# On keyboard with 12 function keys,
#       shifted f-keys: F13-F24
#       control f-keys: F25-F36
#       alt f-keys:     F37-F48
# The shift/control/alt keys do not modify each other, but alt overrides both,
# and control overrides shift.
#
# <pfkey> capability for F1-F48 -TD
ansi.sys|ANSI.SYS 3.1 and later versions,
        el=\E[Kka1=\0Gka3=\0Ikb2=\0Lkc1=\0Okc3=\0Q,
        kcbt=\0^Okcub1=\0Kkcud1=\0Pkcuf1=\0Mkcuu1=\0H,
        kdch1=\0Skend=\0Okf1=\0;kf10=\0Dkf11=\0\205,
        kf12=\0\206kf13=\0Tkf14=\0Ukf15=\0Vkf16=\0W,
        kf17=\0Xkf18=\0Ykf19=\0Zkf2=\0<kf20=\0[kf21=\0\\,
        kf22=\0]kf23=\0\207kf24=\0\210kf25=\0\^kf26=\0_,
        kf27=\0`kf28=\0akf29=\0bkf3=\0=kf30=\0ckf31=\0d,
        kf32=\0ekf33=\0fkf34=\0gkf35=\0\211kf36=\0\212,
        kf37=\0hkf38=\0ikf39=\0jkf4=\0>kf40=\0kkf41=\0l,
        kf42=\0mkf43=\0nkf44=\0okf45=\0pkf46=\0q,
        kf47=\0\213kf48=\0\214kf5=\0?kf6=\0@kf7=\0Akf8=\0B,
        kf9=\0Ckhome=\0Gkich1=\0Rknp=\0Qkpp=\0I,
        pfkey=\E[0;%?%p1%{11}%<%t%':'%e%p1%{13}%<%t%'z'%e%p1%{23}%<
              %t%'G'%e%p1%{25}%<%t%'p'%e%p1%'#'%<%t%'E'%e%p1%'%'%<%t
              %'f'%e%p1%'/'%<%t%'C'%e%{92}%;%p1%+%d;%p2"%s"p
,
        use=ansi+arrowsuse=ansi.sys-old,

#
# Define IBM PC keypad keys for vi as per MS-Kermit while using ANSI.SYS.
# This should only be used when the terminal emulator cannot redefine the keys.
# Since redefining keys with ansi.sys also affects PC-DOS programs, the key
# definitions must be restored.  If the terminal emulator is quit while in vi
# or others using <smkx>/<rmkx>, the keypad will not be defined as per PC-DOS.
# The PgUp and PgDn are prefixed with ESC so that tn3270 can be used on Unix
# (^U and ^D are already defined for tn3270).  The ESC is safe for vi but it
# does "beep".  ESC ESC i is used for Ins to avoid tn3270 ESC i for coltab.
# Note that <kcub1> is always BS, because PC-dos can tolerate this change.
# Caution: vi is limited to 256 string bytes, longer crashes or weirds out vi.
# Consequently the End keypad key could not be set (it is relatively safe and
# actually useful because it sends ^@ O, which beeps and opens a line above).
ansi.sysk|ansisysk|PC-DOS 3.1 ANSI.SYS with keypad redefined for vi,
        is2=U2\sPC-DOS\s3.1\sANSI.SYS\swith\skeypad\sredefined\sfor
            \svi\s9-29-86\n\E[;75;8p
,
        rmkx=\E[;71;0;71p\E[;72;0;72p\E[;73;0;73p\E[;77;0;77p\E[;80;
             0;80p\E[;81;0;81p\E[;82;0;82p\E[;83;0;83p
,
        smkx=\E[;71;30p\E[;72;11p\E[;73;27;21p\E[;77;12p\E[;80;10p
             \E[;81;27;4p\E[;82;27;27;105p\E[;83;127p
,
        use=ansi.sys,
#
# Adds ins/del line/character, hence vi reverse scrolls/inserts/deletes nicer.
nansi.sys|nansisys|PC-DOS Public Domain NANSI.SYS,
        dch1=\E[1Pdl1=\E[1Mich1=\E[1@il1=\E[1L,
        is2=U3 PC-DOS Public Domain NANSI.SYS 9-23-86\n,
        use=ansi.sys,
#
# See ansi.sysk and nansi.sys above.
nansi.sysk|nansisysk|PC-DOS Public Domain NANSI.SYS with keypad redefined for vi,
        dch1=\E[1Pdl1=\E[1Mich1=\E[1@il1=\E[1L,
        is2=U4\sPC-DOS\sPublic\sDomain\sNANSI.SYS\swith\skeypad
            \sredefined\sfor\svi\s9-29-86\n\E[;75;8p
,
        use=ansi.sysk,

#### Atari ST terminals

# From Guido Flohr <gufl0000@stud.uni-sb.de>.
#
tw52|tw52-color|Toswin window manager with color,
        bce,
        colors#16pairs#0x100,
        oc=\Eb?\Ec0op=\Eb?\Ec0,
        setab=\Ec%?%p1%{0}%=%t?%e%p1%{7}%=%t0%e%p1%{15}%=%t7%e%p1
              %{48}%+%c
,
        setaf=\Eb%?%p1%{0}%=%t?%e%p1%{7}%=%t0%e%p1%{15}%=%t7%e%p1
              %{48}%+%c
,
        setb=\Ec%?%p1%{0}%=%t?%e%p1%{7}%=%t0%e%p1%{15}%=%t7%e%p1
             %{48}%+%c
,
        setf=\Eb%?%p1%{0}%=%t?%e%p1%{7}%=%t0%e%p1%{15}%=%t7%e%p1
             %{48}%+%c
,
        use=tw52-m,
tw52-m|Toswin window manager monochrome,
        ul,
        ma#999,
        bold=\Eyadch1=\Eadim=\EyB,
        is2=\Ev\Eq\Ez_\Ee\Ei\Eb?\Ec0rev=\EyPrmso=\EzQ,
        rmul=\EzHrs2=\Ev\Eq\Ez_\Ee\Ei\Eb?\Ec0sgr0=\Ez_,
        smso=\EyQsmul=\EyHuse=at-m,
tt52|Atari TT medium and high resolution,
        lines#30use=at-color,
st52-color|at-color|atari-color|atari_st-color|Atari ST with color,
        bce,
        colors#16pairs#0x100,
        is2=\Ev\Eq\Ee\Eb1\Ec0rs2=\Ev\Eq\Ee\Eb1\Ec0,
        setab=\Ec%?%p1%{0}%=%t1%e%p1%{1}%=%t2%e%p1%{2}%=%t3%e%p1%{3}
              %=%t>%e%p1%{4}%=%t4%e%p1%{5}%=%t7%e%p1%{6}%=%t5%e%p1
              %{7}%=%t0%e%p1%{8}%=%t8%e%p1%{9}%=%t9%e%p1%{10}%=%t:%e
              %p1%{11}%=%t;%e%p1%{12}%=%t<%e%p1%{13}%=%t=%e%p1%{14}
              %=%t6%e?
,
        setaf=\Eb%?%p1%{0}%=%t1%e%p1%{1}%=%t2%e%p1%{2}%=%t3%e%p1%{3}
              %=%t>%e%p1%{4}%=%t4%e%p1%{5}%=%t7%e%p1%{6}%=%t5%e%p1
              %{7}%=%t0%e%p1%{8}%=%t8%e%p1%{9}%=%t9%e%p1%{10}%=%t:%e
              %p1%{11}%=%t;%e%p1%{12}%=%t<%e%p1%{13}%=%t=%e%p1%{14}
              %=%t6%e?
,
        setb=\Ec%?%p1%{0}%=%t1%e%p1%{1}%=%t2%e%p1%{2}%=%t3%e%p1%{3}
             %=%t>%e%p1%{4}%=%t4%e%p1%{5}%=%t7%e%p1%{6}%=%t5%e%p1
             %{7}%=%t0%e%p1%{8}%=%t8%e%p1%{9}%=%t9%e%p1%{10}%=%t:%e
             %p1%{11}%=%t;%e%p1%{12}%=%t<%e%p1%{13}%=%t=%e%p1%{14}%=
             %t6%e?
,
        setf=\Eb%?%p1%{0}%=%t1%e%p1%{1}%=%t2%e%p1%{2}%=%t3%e%p1%{3}
             %=%t>%e%p1%{4}%=%t4%e%p1%{5}%=%t7%e%p1%{6}%=%t5%e%p1
             %{7}%=%t0%e%p1%{8}%=%t8%e%p1%{9}%=%t9%e%p1%{10}%=%t:%e
             %p1%{11}%=%t;%e%p1%{12}%=%t<%e%p1%{13}%=%t=%e%p1%{14}%=
             %t6%e?
,
        use=st52,
st52|st52-m|at|at-m|atari|atari-m|atari_st|atarist-m|Atari ST,
        ameomirnpc,
        civis=\Efclear=\EEcnorm=\Eedl1=\EMel1=\Eoil1=\EL,
        is2=\Ev\Eq\EekLFT=\EdkRIT=\Eckdch1=^?kf1=\EP,
        kf10=\EYkf11=\Epkf12=\Eqkf13=\Erkf14=\Eskf15=\Et,
        kf16=\Eukf17=\Evkf18=\Ewkf19=\Exkf2=\EQkf20=\Ey,
        kf3=\ERkf4=\ESkf5=\ETkf6=\EUkf7=\EVkf8=\EWkf9=\EX,
        khlp=\EHkhome=\EEkich1=\EIknp=\Ebkpp=\Eakund=\EK,
        rc=\Ekrev=\Eprmso=\Eqrs2=\Ev\Eq\Eesc=\Ejsgr0=\Eq,
        smso=\Epuse=vt52-basic,
tw100|Toswin VT100 window manager,
        eomirmsgrxon,
        colors#8cols#80it#8lines#24pairs#64vt#3,
        acsc=++\,\,--..00II``aaffgghhjjkkllmmnnooppqqrrssttuuvvwwxxy
             yzz{{||}}~~
,
        bel=^Gblink=\E[5mbold=\E[1mcivis=\Ef,
        clear=\E[2J\E[Hcnorm=\Eecr=\rcub1=^Hcud1=\EB,
        cuf1=\ECcup=\E[%i%p1%d;%p2%dHcuu1=\EAdch1=\Ea,
        dim=\E[2mdl=\E[%p1%dMdl1=\E[Med=\E[Jel=\E[K,
        el1=\E[1Khome=\E[Hht=^Ihts=\EHich=\E[%p1%d@il1=\EL,
        ind=\nis2=\E<\E)0kdch1=^?kf1=\EOPkf10=\EOYkf11=\Ep,
        kf12=\Eqkf13=\Erkf14=\Eskf15=\Etkf16=\Eukf17=\Ev,
        kf18=\Ewkf19=\Exkf2=\EOQkf20=\Eykf3=\EORkf4=\EOS,
        kf5=\EOTkf6=\EOUkf7=\EOVkf8=\EOWkf9=\EOXkhlp=\EH,
        khome=\E\EEkich1=\EIknp=\Ebkpp=\E\Eakund=\EK,
        ll=\E[24Hnel=\EEoc=\E[30;47mop=\E[30;47mrev=\E[7m,
        ri=\EMrmacs=^Ormcup=\E[?7hrmir=\Eirmkx=\E[?1l\E>,
        rmso=\E[mrmul=\E[m,
        rs1=\E<\E[20l\E[?3;6;9l\E[r\Eq\E(B\017\E)0\E>,
        setb=\E[4%p1%'0'%+%Pa%?%ga%'0'%=%t0%e%ga%'1'%=%t4%e%ga%'2'%=
             %t2%e%ga%'3'%=%t6%e%ga%'4'%=%t1%e%ga%'5'%=%t5%e%ga%'6'
             %=%t3%e7%;m
,
        setf=\E[3%p1%'0'%+%Pa%?%ga%'0'%=%t0%e%ga%'1'%=%t4%e%ga%'2'%=
             %t2%e%ga%'3'%=%t6%e%ga%'4'%=%t1%e%ga%'5'%=%t5%e%ga%'6'
             %=%t3%e7%;m
,
        sgr0=\E[msmacs=^Nsmcup=\E[?7lsmir=\Eh,
        smkx=\E[?1h\E=smso=\E[7msmul=\E[4mtbc=\E[3g,
        use=ansi+apparrowsuse=ansi+csruse=ansi+local,

# The entries for stv52 and stv52pc probably need a revision.
stv52|MiNT virtual console,
        ammsgr,
        lines#30,
        blink=\Erbold=\EyAcivis=\Efclear=\EEcnorm=\E. \Ee,
        cub1=^Hcvvis=\E."dim=\Emdl1=\EMil1=\ELind=\n$<2*/>,
        kdch1=^?kf1=\EPkf10=\EYkf11=\Epkf12=\Eqkf13=\Er,
        kf14=\Eskf15=\Etkf16=\Eukf17=\Evkf18=\Ewkf19=\Ex,
        kf2=\EQkf20=\Eykf3=\ERkf4=\ESkf5=\ETkf6=\EUkf7=\EV,
        kf8=\EWkf9=\EXkhlp=\EHkhome=\EEkich1=\EIknp=\Eb,
        kpp=\Eakund=\EKnel=\r\n$<2*/>op=\Eb@\EcOrev=\Ep,
        ri=\EI$<2*/>rmcup=\Ev\E. \Ee\Ez_rmso=\Eqrmul=\EzH,
        rs1=\Ez_\Eb@\EcAsgr0=\Ez_smcup=\Ev\Ee\Ez_smso=\Ep,
        smul=\EyHuse=vt52-basic,
stv52pc|MiNT virtual console with PC charset,
        ammsgr,
        lines#30,
        acsc=+\257\,\256-\^.v0\333I\374`\177a\260f\370g\361h\261j
             \331k\277l\332m\300n\305o\377p-q\304r-s_t+u+v+w+x\263y
             \363z\362{\343|\366}\234~\371
,
        blink=\Erbold=\EyAcivis=\Efclear=\EEcnorm=\E. \Ee,
        cub1=^Hcvvis=\E."dim=\Emdl1=\EMil1=\ELind=\n$<2*/>,
        kdch1=^?kf1=\EPkf10=\EYkf11=\Epkf12=\Eqkf13=\Er,
        kf14=\Eskf15=\Etkf16=\Eukf17=\Evkf18=\Ewkf19=\Ex,
        kf2=\EQkf20=\Eykf3=\ERkf4=\ESkf5=\ETkf6=\EUkf7=\EV,
        kf8=\EWkf9=\EXkhlp=\EHkhome=\EEkich1=\EIknp=\Eb,
        kpp=\Eakund=\EKnel=\r\n$<2*/>rev=\Epri=\EI$<2*/>,
        rmcup=\Ev\E. \Ee\Ez_rmso=\Eqrmul=\EzH,
        rs1=\Ez_\Eb@\EcAsgr0=\Ez_smcup=\Ev\Ee\Ez_smso=\Ep,
        smul=\EyHuse=vt52-basic,

# From: Simson L. Garfinkel <simsong@media-lab.mit.edu>
atari-old|Atari st,
        OTbs, am,
        cols#80it#8lines#25,
        clear=\EH\EJcub1=\EDcud1=\EBcuf1=\EC,
        cup=\EY%p1%{32}%+%c%p2%{32}%+%ccuu1=\EAdl1=\EM,
        ed=\EJel=\EKht=^Iil1=\ELri=\EIrmso=\Eqsgr0=\Eq,
        smso=\Epuse=vt52+arrows,
# UniTerm terminal program for the Atari ST:  49-line VT220 emulation mode
# From: Paul M. Aoki <aoki@ucbvax.berkeley.edu>
uniterm|uniterm49|UniTerm VT220 emulator with 49 lines,
        lines#49,
        is2=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h\E[1;49r\E[49;1Huse=vt220-base,
# MiNT VT52 emulation. 80 columns, 25 rows.
# MiNT is Now TOS, the operating system which comes with all Ataris now
# (mainly Atari Falcon). This termcap is for the VT52 emulation you get
# under tcsh/zsh/bash/sh/ksh/ash/csh when you run MiNT in `console' mode
# From: Per Persson <pp@gnu.ai.mit.edu>, 27 Feb 1996
st52-old|Atari ST with VT52 emulation,
        amkm,
        cols#80lines#25,
        bel=^Gcivis=\Efclear=\EH\EJcnorm=\Eecr=\rcub1=\ED,
        cud1=\EBcuf1=\ECcup=\EY%p1%{32}%+%c%p2%{32}%+%c,
        cuu1=\EAdl1=\EMed=\EJel=\EKhome=\EHht=^Iil1=\EL,
        ind=\nka1=\E#7ka3=\E#5kb2=\E#9kbs=^Hkc1=\E#1,
        kc3=\E#3kclr=\E#7kcub1=\E#Kkcud1=\E#Pkcuf1=\E#M,
        kcuu1=\E#Hkf0=\E#Dkf1=\E#;kf2=\E#<kf3=\E#=kf4=\E#>,
        kf5=\E#?kf6=\E#@kf7=\E#Akf8=\E#Bkf9=\E#Ckhome=\E#G,
        kil1=\E#Rkind=\E#2kri=\E#8lf0=f10nel=\r\nrc=\Ek,
        ri=\EIrmcup=, rmso=\Eqrs1=\Ez_\Eb@\EcAsc=\Ejsgr0=\Eq,
        smcup=\Eesmso=\Ep,

#### BeOS
#
# BeOS entry for Terminal program Seems to be almost ANSI
beterm|BeOS Terminal,
        ameomirmsgrxenlxon,
        cols#80it#8lines#25ncv#5,
        bel=^Gbold=\E[1mcr=\rcub1=^Hcud1=\n,
        cup=\E[%i%p1%d;%p2%dHech=\E[%p1%dXel1=\E[1K,
        home=\E[Hhpa=\E[%i%p1%dGht=^Ihts=\EHind=\n,
        kf1=\E[11~kf10=\E[20~kf11=\E[21~kf12=\E[22~,
        kf2=\E[12~kf3=\E[13~kf4=\E[14~kf5=\E[15~kf6=\E[16~,
        kf7=\E[17~kf8=\E[18~kf9=\E[19~khome=\E[1~kspd=^Z,
        nel=\r\nop=\E[mrev=\E[7mri=\EMrmkx=\E[?4lrmso=\E[m,
        rmul=\E[24mrs1=\Ecsetb=\E[%p1%{40}%+%cm,
        setf=\E[%p1%{30}%+%cmsgr0=\E[0;10msmkx=\E[?4h,
        smso=\E[7msmul=\E[4mu6=\E[%i%p1%d;%p2%dRu7=\E[6n,
        vpa=\E[%i%p1%dduse=ansi+arrowsuse=ansi+csr,
        use=ansi+eraseuse=ansi+idcuse=ansi+idl,
        use=ansi+localuse=klone+coloruse=vt220+pcedit,

#### Linux consoles
#

# release 1.2.13: 1995/03
#
# This entry is good for the 1.2.13 or later version of the Linux console.
#
# ***************************************************************************
# *                                                                         *
# *                           WARNING:                                      *
# * Linuxes come with a default keyboard mapping kcbt=^I.  This entry, in   *
# * response to user requests, assumes kcbt=\E[Z, the ANSI/ECMA reverse-tab *
# * character. Here are the keymap replacement lines that will set this up: *
# *                                                                         *
#       keycode  15 = Tab             Tab
#               alt     keycode  15 = Meta_Tab
#               shift   keycode  15 = F26
#       string F26 ="\033[Z"
# *                                                                         *
# * This has to use a key slot which is unfortunate (any unused one will    *
# * do, F26 is the higher-numbered one).  The change ought to be built      *
# * into the kernel tables.                                                 *
# *                                                                         *
# ***************************************************************************
#
# All linux kernels since 1.2.13 (at least) set the screen size
# themselves; this entry assumes that capability.
#
linux-basic|Linux console (basic),
        ambceeomirmsgrxenlxon,
        it#8ncv#18, U8#1,
        acsc=+\020\,\021-\030.^Y0\333`\004a\261f\370g\361h\260i
             \316j\331k\277l\332m\300n\305o~p\304q\304r\304s_t\303u
             \264v\301w\302x\263y\363z\362{\343|\330}\234~\376
,
        bel=^Gcr=\rcub1=^Hcud1=\ncup=\E[%i%p1%d;%p2%dH,
        dim=\E[2mech=\E[%p1%dXel1=\E[1K,
        flash=\E[?5h$<200/>\E[?5lhome=\E[Hhpa=\E[%i%p1%dG,
        ht=^Ihts=\EHind=\nkb2=\E[Gkbs=^?kcbt=\E[Zkf1=\E[[A,
        kf10=\E[21~kf11=\E[23~kf12=\E[24~kf2=\E[[B,
        kf3=\E[[Ckf4=\E[[Dkf5=\E[[Ekf6=\E[17~kf7=\E[18~,
        kf8=\E[19~kf9=\E[20~khome=\E[1~kmous=\E[Mkspd=^Z,
        nel=\r\nri=\EMrmam=\E[?7lrmso=\E[27mrmul=\E[24m,
        rs1=\Ec\E]R,
        sgr=\E[0;10%?%p1%t;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p5
            %t;2%;%?%p6%t;1%;%?%p9%t;11%;m
,
        smam=\E[?7htbc=\E[3gvpa=\E[%i%p1%dduse=ansi+arrows,
        use=ansi+csruse=ansi+eraseuse=ansi+idcuse=ansi+idl,
        use=ansi+localuse=vt220+pcedituse=vt102+enq,
        use=klone+sgruse=ecma+coloruse=linux+sfkeys,

linux+decid|ncurses extension for Linux console DECID,
        u8=\E[?6cuse=decid+cpr,

linux+sfkeys|shifted function-keys for Linux console,
        kf13=\E[25~kf14=\E[26~kf15=\E[28~kf16=\E[29~,
        kf17=\E[31~kf18=\E[32~kf19=\E[33~kf20=\E[34~,

linux-m|Linux console no color,
        colors@, pairs@,
        setab@, setaf@, setb@, setf@, use=linux,

# release 1.3: 1995/06
#
# The 1.3.x kernels add color-change capabilities; if yours doesn't have this
# and it matters, turn off <ccc>.  The %02x escape used to implement this is
# not supposedly back-portable to older SV curses (although it has worked fine
# on Solaris for several years) and not supported in ncurses versions before
# 1.9.9.
linux-c-nc|Linux console with color-change,
        ccc,
        initc=\E]P%p1%x%p2%{255}%*%{1000}%/%02x%p3%{255}%*%{1000}%/
              %02x%p4%{255}%*%{1000}%/%02x
,
        oc=\E]Ruse=linux-basic,
# From: Dennis Henriksen <opus@osrl.dk>, 9 July 1996
linux-c|Linux console 1.3.6+ for older ncurses,
        ccc,
        initc=\E]P%?%p1%{9}%>%t%p1%{10}%-%'a'%+%c%e%p1%d%;%p2%{255}
              %*%{1000}%/%Pr%gr%{16}%/%Px%?%gx%{9}%>%t%gx%{10}%-%'a'
              %+%c%e%gx%d%;%gr%{15}%&%Px%?%gx%{9}%>%t%gx%{10}%-%'a'
              %+%c%e%gx%d%;%p3%{255}%*%{1000}%/%Pr%gr%{16}%/%Px%?%gx
              %{9}%>%t%gx%{10}%-%'a'%+%c%e%gx%d%;%gr%{15}%&%Px%?%gx
              %{9}%>%t%gx%{10}%-%'a'%+%c%e%gx%d%;%p4%{255}%*%{1000}
              %/%Pr%gr%{16}%/%Px%?%gx%{9}%>%t%gx%{10}%-%'a'%+%c%e%gx
              %d%;%gr%{15}%&%Px%?%gx%{9}%>%t%gx%{10}%-%'a'%+%c%e%gx
              %d%;
,
        oc=\E]Ruse=linux-basic,

# release 2.2: 1999/01
#
# The 2.2.x kernels add a private mode that sets the cursor type; use that to
# get a block cursor for cvvis.
# reported by Frank Heckenbach <frank@g-n-u.de>.
linux2.2|Linux 2.2.x console,
        civis=\E[?25l\E[?1ccnorm=\E[?25h\E[?0c,
        cvvis=\E[?25h\E[?8cuse=linux-c-nc,

# release 2.6: 2003/12 - 2004/12
#
# Linux 2.6.x has a fix for SI/SO to work with UTF-8 encoding added here:
#       http://lkml.iu.edu/hypermail/linux/kernel/0602.2/0738.html
# Although the kernel has mappings for these, they were not in the default
# font (tested with Debian and Fedora):
#       '`' diamond
#       '~' scan line 1
#       'p' scan line 3
#       'r' scan line 7
#       '_' scan line 9
#
# The fix for SI/SO is part of a configurable (i.e., "optional") kernel feature
# misleadingly called CONFIG_CONSOLE_TRANSLATIONS.  Disabling that not only
# omits the line-drawing using SI/SO, but also part/all of the Unicode feature:
#
#    https://cateee.net/lkddb/web-lkddb/CONSOLE_TRANSLATIONS.html
#       "This enables support for font mapping and Unicode translation on virtual consoles."
#
# This mailing list thread in July 2008 illustrates:
#
#    https://marc.info/?t=121734656700005&r=1&w=4
#       "commit a29ccf6f823a84d89e1c7aaaf221cf7282022024 break console on slackware 12.1"
#
# The change which made it configurable was to reduce the size for use in
# embedded systems.  Some background is found in
#
#    https://lwn.net/Articles/284767/
#       "An interview with the new embedded maintainers"
linux2.6|Linux 2.6.x console,
        acsc=++\,\,--..00``aaffgghhiijjkkllmmnnooppqqrrssttuuvvwwxxy
             yzz{{||}}~~
,
        enacs=\E)0rmacs=^O,
        sgr=\E[0;10%?%p1%t;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p5
            %t;2%;%?%p6%t;1%;m%?%p9%t\016%e\017%;
,
        sgr0=\E[m\017smacs=^Nuse=linux2.2,

# The 3.0 kernel adds support for clearing scrollback buffer (capability E3).
# It is the same as xterm's erase-saved-lines feature.
#
# Linux 3.0 was released in July 2011.  The keyboard utilities (kbd) are
# used for configuring its keyboard mappings.
#
# kbd 1.14 was released before that (January 2008), but due to its placement
# late in the Linux 2.6.x series had no immediate effect for most users.  That
# provided a default mapping for shift-tab to the (misnamed) Meta_Tab, i.e.,
# the same as Alt-Tab.
#
# The suggested mapping for the conventional \E[Z is provided in this entry as
# an extended key to lessen user surprise -TD
linux3.0|Linux 3.0 kernels,
        kcbt=\E^I, E3=\E[3J, kcbt2=\E[Zuse=linux2.6,

# This is Linux console for ncurses.
linux|Linux console,
        use=linux3.0,

# Subject: linux 2.6.26 vt back_color_erase
# Changes to the Linux console driver broke bce model as reported in
#       https://bugzilla.novell.com/show_bug.cgi?id=418613
# apparently from
#       http://lkml.org/lkml/2008/4/26/305
#       http://lkml.org/lkml/2008/10/3/66
linux2.6.26|Linux console w/o bce,
        bce@, use=linux2.6,

# See the note on ICH/ICH1 VERSUS RMIR/SMIR near the end of file
linux-nic|Linux with ich/ich1 suppressed for non-curses programs,
        ich@, ich1@, use=linux,

# This assumes you have used setfont(8) to load one of the Linux koi8-r fonts.
# acsc entry from Pavel Roskin" <pavel@absolute.spb.su>, 29 Sep 1997.
linux-koi8|Linux with koi8 alternate character set,
        acsc=+\020\,\021-\030.^Y0\215`\004a\221f\234g\237h\220i
             \276j\205k\203l\202m\204n\212o~p\0q\0r\0s_t\206u\207v
             \211w\210x\201y\230z\231{\267|\274~\224
,
        use=linuxuse=klone+koi8acs,

# Another entry for KOI8-r with Qing Long's acsc.
# (which one better complies with the standard?)
linux-koi8r|Linux with koi8-r alternate character set,
        use=linuxuse=klone+koi8acs,

# Entry for the latin1 and latin2 fonts
linux-lat|Linux with latin1 or latin2 alternate character set,
        acsc=+\020\,\021-\030.^Y0\333`\004a\013f\370g\361h\260i
             \316j\211k\214l\206m\203n\305o~p\304q\212r\304s_t\207u
             \215v\301w\302x\205y\363z\362{\343|\330}\234~\376
,
        use=linux,

# This uses graphics from VT codeset instead of from cp437.
# reason: cp437 (aka "straight to font") is not functional under luit.
# from: Andrey V Lukyanov <land@long.yar.ru>.
linux-vt|Linux console using VT codes for graphics,
        acsc=++\,\,--..00``aaffgghhiijjkkllmmnnooppqqrrssttuuvvwwxxy
             yzz~~
,
        rmacs=\E(Krmpch@, sgr@, sgr0=\E[0m\E(K\017smacs=\E(0,
        smpch@, use=linux,

# release: 0.3.9b 1997/01 to 2000/05
#
# This is based on the Linux console (relies on the console to perform some
# of the functionality), but does not recognize as many control sequences.
# The program comes bundled with an old (circa 1998) copy of the Linux
# console terminfo.  It recognizes some non-ANSI/VT100 sequences such as
#       \E*     move cursor to home, as as \E[H
#       \E,X    same as \E(X
#       \EE     move cursor to beginning of row
#       \E[y,xf same as \E[y,xH
#
# Note: The status-line support is buggy (dsl does not work).
kon|kon2|Kanji ON Linux console,
        ambceccceoeslokhsmirmsgrxenlxon,
        it#8ncv#18,
        bel=^Gcivis=\E[?25lcnorm=\E[?25hcr=\rcub1=^H,
        cud1=\ncup=\E[%i%p1%d;%p2%dHdim=\E[2m,
        dsl=\E[?H\E[?Eel1=\E[1Kfsl=\E[?Fhome=\E[H,
        hpa=\E[%i%p1%dGht=^Ihts=\EHind=\n,
        initc=\E]P%p1%x%p2%02x%p3%02x%p4%02xkb2=\E[Gkbs=^?,
        kf1=\E[[Akf10=\E[21~kf11=\E[23~kf12=\E[24~,
        kf13=\E[25~kf14=\E[26~kf15=\E[28~kf16=\E[29~,
        kf17=\E[31~kf18=\E[32~kf19=\E[33~kf2=\E[[B,
        kf20=\E[34~kf3=\E[[Ckf4=\E[[Dkf5=\E[[Ekf6=\E[17~,
        kf7=\E[18~kf8=\E[19~kf9=\E[20~khome=\E[1~kspd=^Z,
        nel=\r\nop=\E[37;40mri=\EMrmso=\E[27mrmul=\E[24m,
        rs1=\Ec,
        sgr=\E[0;10%?%p1%t;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p5
            %t;2%;%?%p6%t;1%;%?%p7%t;8%;%?%p9%t;11%;m
,
        sgr0=\E[0;10mtbc=\E[3gtsl=\E[?Tu8=\E[?6c,
        vpa=\E[%i%p1%dduse=ansi+arrowsuse=ansi+csr,
        use=ansi+enquse=ansi+eraseuse=ansi+idcuse=ansi+idl,
        use=ansi+localuse=ansi+sgrbolduse=ecma+sgr,
        use=klone+coloruse=vt220+pcedit,

# release: 0.4.7 2005/05
#
jfbterm|japanese framebuffer terminal,
        acsc=++\,\,--..00``aaffgghhiijjkkllmmnnooppqqrrssttuuvvwwxxy
             yzz{{||}}~~
,
        sgr0=\E[0muse=kon,

# FbTerm
# Another variant.  There are two parts (src, src/lib) with the latter
# comprising the escape-sequence parsing.  The copyright notice on that
# says it is based on GTerm by Timothy Miller.
#
# The original developer "dragchan" has left, but as of March 2017 there is
# (still dead) code from May 2015 here:
#       https://github.com/izmntuk/fbterm
#
# The acsc string may be incorrect.
#
# Not used here, the program recognizes escapes for italic, underline and
# dim, rendering those as green, cyan and gray respectively.
fbterm|FbTerm for Linux with framebuffer,
        colors#0x100pairs#0x10000,
        acsc=+\020\,\021-\030.^Y0\333`\004a\261f\370g\361h\260i
             \316j\331k\277l\332m\300n\305o~p\304q\304r\304s_t\303u
             \264v\301w\302x\263y\363z\362{\343|\330}\234~\376
,
        initc=\E[3;%p1%d;%p2%d;%p3%d;%p4%d}rmacs=\E[10m,
        setab=\E[2;%p1%d}setaf=\E[1;%p1%d},
        sgr=\E[0;10%?%p1%t;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p5
            %t;2%;%?%p6%t;1%;%?%p9%t;11%;m
,
        sgr0=\E[0;10msmacs=\E[11muse=linux,

# 16-color linux console entry; this works with a 256-character
# console font but bright background colors turn into dim ones when
# you use a 512-character console font. This uses bold for bright
# foreground colors and blink for bright background colors.
#
# Interestingly, the original version of this entry in 2009 used a documented
# (but nonstandard) SGR 21, which was supported in the Linux console since 1992
# as an equivalent for SGR 22.  Long after (early 2018), someone modified the
# console driver to make it ignore SGR 21 because the ECMA-48 standard
# suggested a different use for that particular code:
#
https://github.com/torvalds/linux/commit/65d9982d7e523a1a8e7c9af012da0d166f72fc56#diff-7da3c215d12c9f6b88e1a37d38b116f0
#
# Two years later, someone (unfamiliar with ECMA-48 this time) documented it:
#
https://git.kernel.org/pub/scm/docs/man-pages/man-pages.git/commit/man4/console_codes.4?id=a133a6bc03d751a424fe0a4adea2198757599615
#
# For background, refer to the report on bug-ncurses:
#
https://lists.gnu.org/archive/html/bug-ncurses/2019-10/msg00059.html
linux-16color|Linux console with 16 colors,
        colors#16ncv#42pairs#0x100,
        setab=\E[4%p1%{8}%m%d%?%p1%{7}%>%t;5%e;25%;m,
        setaf=\E[3%p1%{8}%m%d%?%p1%{7}%>%t;1%e;22%;m,
        use=linux,

# bterm (bogl 0.1.18)
# Implementation is in bogl-term.c
# Key capabilities from linux terminfo entry
#
# Notes:
# bterm only supports acs using wide-characters, has case for these: qjxamlkut
# bterm does not support sgr, since it only processes one parameter -TD
bterm|bogl virtual terminal,
        ambce,
        colors#8cols#80lines#24pairs#64,
        acsc=aajjkkllmmqqttuuxxbold=\E[1mclear=\E[H\E[2J,
        cr=\rcub1=^Hcud1=\ncup=\E[%i%p1%d;%p2%dHed=\E[J,
        el=\E[Khome=\E[Hind=\nkb2=\E[Gkbs=^?kcbt=\E[Z,
        kf1=\E[[Akf10=\E[21~kf11=\E[23~kf12=\E[24~,
        kf13=\E[25~kf14=\E[26~kf15=\E[28~kf16=\E[29~,
        kf17=\E[31~kf18=\E[32~kf19=\E[33~kf2=\E[[B,
        kf20=\E[34~kf3=\E[[Ckf4=\E[[Dkf5=\E[[Ekf6=\E[17~,
        kf7=\E[18~kf8=\E[19~kf9=\E[20~khome=\E[1~,
        kmous=\E[Mkspd=^Znel=\r\nop=\E[49m\E[39mrev=\E[7m,
        ri=\EMrmacs=^Ormso=\E[27mrmul=\E[24m,
        setab=\E[4%p1%dmsetaf=\E[3%p1%dmsgr0=\E[0msmacs=^N,
        smso=\E[7msmul=\E[4muse=ansi+arrows,
        use=vt220+pcedituse=vt220+cvis,

#### Mach
#

# From: Matthew Vernon <mcv21@pick.sel.cam.ac.uk>
mach|Mach console,
        amkm, NQ,
        cols#80it#8lines#25,
        bel=^Gblink=\E[5mbold=\E[1mclear=\Eccr=\rcub1=^H,
        cud1=\ncup=\E[%i%p1%d;%p2%dHed=\E[Jel=\E[K,
        home=\E[Hht=^Iind=\nkbs=^?kdch1=\E[9kend=\E[Y,
        kf1=\EOPkf10=\EOYkf2=\EOQkf3=\EORkf4=\EOSkf5=\EOT,
        kf6=\EOUkf7=\EOVkf8=\EOWkf9=\EOXkich1=\E[@kll=\E[F,
        knp=\E[Ukpp=\E[Vrev=\E[7mrmso=\E[0mrmul=\E[24m,
        sgr0=\E[0msmso=\E[7msmul=\E[4muse=ansi+arrows,
        use=ansi+idluse=ansi+local,

mach-bold|Mach console with bold instead of underline,
        rmul=\E[0msmul=\E[1muse=mach,
mach-color|Mach console with ANSI color,
        colors#8pairs#64,
        dim=\E[2minvis=\E[8mop=\E[37;40mrmso=\E[27m,
        setab=\E[4%p1%dmsetaf=\E[3%p1%dmuse=mach,

# From: Samuel Thibault
# Source: git://git.sv.gnu.org/hurd/gnumach.git
# Files: i386/i386at/kd.c
#
# Added nel, hpa, sgr and removed rmacs, smacs based on source -TD
mach-gnu|GNU Mach,
        acsc=+>\,<-\^.v0\333`+a\261f\370g\361h\260i#j\331k\277l
             \332m\300n\305o~p\304q\304r\304s_t\303u\264v\301w\302x
             \263y\363z\362{\343|\330}\234~\376
,
        dch=\E[%p1%dPdch1=\E[Pdim=\E[2mech=\E[%p1%dX,
        el1=\E[1Khpa=\E[%i%p1%dGich=\E[%p1%d@ich1=\E[@,
        invis=\E[8mnel=\EE,
        sgr=\E[0%?%p1%t;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p5%t;
            2%;%?%p6%t;1%;%?%p7%t;8%;m
,
        use=ecma+indexuse=mach,

mach-gnu-color|GNU Mach console with ANSI color,
        colors#8pairs#64,
        op=\E[37;40mrmso=\E[27msetab=\E[4%p1%dm,
        setaf=\E[3%p1%dmuse=mach-gnu,

# From: Marcus Brinkmann
http://git.savannah.gnu.org/cgit/hurd/hurd.git/log/console/
#
# Comments in the original are summarized here:
#
# hurd uses 8-bit characters (km).
#
# Although it doesn't do XON/XOFF, we don't want padding characters (xon).
#
# Regarding compatibility to vt100:  hurd doesn't specify <xenl>, as we don't
# have the eat_newline_glitch.  It doesn't support setting or removing tab
# stops (hts/tbc).
#
# hurd uses ^H instead of \E[D for cub1, as only ^H implements <bw> and it is
# one byte instead three.
#
# <ich1> is not included because hurd has insert mode.
#
# hurd doesn't use ^J for scrolling, because this could put things into the
# scrollback buffer.
#
# gsbom/grbom are used to enable/disable real bold (not intensity bright) mode.
# This is a GNU extension.
#
# The original has commented-out ncv, but is restored here.
#
# Reading the source, RIS resets cnorm, but not xmous.
hurd|The GNU Hurd console server,
        ambcebweokmmirmsgrxenlxon, NQ,
        it#8ncv#18,
        acsc=++\,\,--..00``aaffgghhiijjkkllmmnnooppqqrrssttuuvvwwxxy
             yzz{{||}}~~
,
        bel=^Gcbt=\E[Zclear=\Eccr=\rcub1=^Hcvvis=\E[34l,
        dch=\E[%p1%dPdch1=\E[Pdim=\E[2mech=\E[%p1%dX,
        el1=\E[1Kflash=\Eght=^Iich=\E[%p1%d@ind=\E[S,
        kb2=\E[Gkbs=^?kcbt=\E[Zkf1=\EOPkf10=\E[21~,
        kf11=\E[23~kf12=\E[24~kf13=\E[25~kf14=\E[26~,
        kf15=\E[28~kf16=\E[29~kf17=\E[31~kf18=\E[32~,
        kf19=\E[33~kf2=\EOQkf20=\E[34~kf3=\EORkf4=\EOS,
        kf5=\E[15~kf6=\E[17~kf7=\E[18~kf8=\E[19~kf9=\E[20~,
        khome=\E[1~kmous=\E[Mkspd=^Znel=\r\nop=\E[39;49m,
        ri=\E[Trmir=\E[4lrmso=\E[27mrmul=\E[24m,
        rs1=\EM\E[?1000l,
        sgr=\E[0%?%p1%t;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p5%t;
            2%;%?%p6%t;1%;%?%p7%t;8%;%?%p9%t;11%;m
,
        smir=\E[4h, grbom=\E[>1l, gsbom=\E[>1h,
        use=ansi+apparrowsuse=ansi+csruse=ansi+cup,
        use=ansi+eraseuse=ansi+idluse=ansi+local,
        use=ansi+rca2use=ansi+sgrbolduse=vt220+pcedit,
        use=ecma+indexuse=ecma+italicsuse=klone+acs,
        use=klone+coloruse=vt220+cvis,

#### QNX
#

# QNX 4.0 Console
# Michael's original version of this entry had <am@>, <smcup=\Ei>,
# <rmcup=\Eh\ER>; this was so terminfo applications could write the lower
# right corner without triggering a scroll.  The ncurses terminfo library can
# handle this case with the <ich1> capability, and prefers <am> for better
# optimization.  Bug: The <op> capability resets attributes.
# From: Michael Hunter <mphunter@qnx.com> 30 Jul 1996
# (removed: <sgr=%?%p1%t\E<%;%p2%t\E[%;%p3%t\E(%;%p4%t\E{%;%p6%t\E<%;,>)
qnx|qnx4|QNX console,
        daisykmmirmsgrxhpaxt,
        colors#8cols#80it#4lines#25ncv#3pairs#8,
        acsc=O\333a\261j\331k\277l\332m\300n\305o\337q\304s\334t
             \303u\264v\301w\302x\263
,
        bel=^Gblink=\E{bold=\E<civis=\Ey0clear=\EH\EJ,
        cnorm=\Ey1cr=\rcub1=^Hcud1=\ncuf1=\EC,
        cup=\EY%p1%{32}%+%c%p2%{32}%+%ccuu1=\EAcvvis=\Ey2,
        dch1=\Efdl1=\EFed=\EJel=\EKhome=\EHht=^Iich1=\Ee,
        il1=\EEind=\nkBEG=\377\356kCAN=\377\263,
        kCMD=\377\267kCPY=\377\363kCRT=\377\364,
        kDL=\377\366kEND=\377\301kEOL=\377\311,
        kEXT=\377\367kFND=\377\370kHLP=\377\371,
        kHOM=\377\260kIC=\377\340kLFT=\377\264,
        kMOV=\377\306kMSG=\377\304kNXT=\377\272,
        kOPT=\377\372kPRT=\377\275kPRV=\377\262,
        kRDO=\377\315kRES=\377\374kRIT=\377\266,
        kRPL=\377\373kSAV=\377\307kSPD=\377\303,
        kUND=\377\337kbeg=\377\300kcan=\377\243kcbt=\377\0,
        kclo=\377\343kclr=\377\341kcmd=\377\245,
        kcpy=\377\265kcrt=\377\305kctab=\377\237,
        kcub1=\377\244kcud1=\377\251kcuf1=\377\246,
        kcuu1=\377\241kdch1=\377\254kdl1=\377\274,
        ked=\377\314kel=\377\310kend=\377\250kent=\377\320,
        kext=\377\270kf1=\377\201kf10=\377\212,
        kf11=\377\256kf12=\377\257kf13=\377\213,
        kf14=\377\214kf15=\377\215kf16=\377\216,
        kf17=\377\217kf18=\377\220kf19=\377\221,
        kf2=\377\202kf20=\377\222kf21=\377\223,
        kf22=\377\224kf23=\377\333kf24=\377\334,
        kf25=\377\225kf26=\377\226kf27=\377\227,
        kf28=\377\230kf29=\377\231kf3=\377\203,
        kf30=\377\232kf31=\377\233kf32=\377\234,
        kf33=\377\235kf34=\377\236kf35=\377\276,
        kf36=\377\277kf37=\377\321kf38=\377\322,
        kf39=\377\323kf4=\377\204kf40=\377\324,
        kf41=\377\325kf42=\377\326kf43=\377\327,
        kf44=\377\330kf45=\377\331kf46=\377\332,
        kf47=\377\316kf48=\377\317kf5=\377\205kf6=\377\206,
        kf7=\377\207kf8=\377\210kf9=\377\211kfnd=\377\346,
        khlp=\377\350khome=\377\240khts=\377\342,
        kich1=\377\253kil1=\377\273kind=\377\261,
        kmov=\377\351kmrk=\377\355kmsg=\377\345,
        knp=\377\252knxt=\377\312kopn=\377\357,
        kopt=\377\353kpp=\377\242kprt=\377\255,
        kprv=\377\302krdo=\377\336kref=\377\354,
        kres=\377\360krfr=\377\347kri=\377\271,
        krmir=\377\313krpl=\377\362krst=\377\352,
        ksav=\377\361kslt=\377\247kspd=\377\335,
        ktbc=\377\344kund=\377\365mvpa=\E!%p1%02dop=\ER,
        rep=\Eg%p2%{32}%+%c%p1%crev=\E(ri=\EIrmcup=\Eh\ER,
        rmso=\E)rmul=\E]rs1=\ERsetb=\E@%p1%Pb%gb%gf%d%d,
        setf=\E@%p1%Pf%gb%gf%d%dsgr0=\E}\E]\E>\E)smcup=\Ei,
        smso=\E(smul=\E[,
#
#
qnxt|qnxt4|QNX4 terminal,
        crxmuse=qnx4,
#
qnxm|QNX4 with mouse events,
        maddr#1,
        chr=\E/cvr=\E"is1=\E/0tmcub=\E/>1hmcub1=\E/>7h,
        mcud=\E/>1hmcud1=\E/>1l\E/>9hmcuf=\E/>1h\E/>9l,
        mcuf1=\E/>7lmcuu=\E/>6hmcuu1=\E/>6lrmicm=\E/>2l,
        smicm=\E/>2huse=qnx4,
#
qnxw|QNX4 windows,
        xvpause=qnxm,
#
#       Monochrome QNX4 terminal or console. Setting this terminal type will
#       allow an application running on a color console to behave as if it
#       were a monochrome terminal. Output will be through stdout instead of
#       console writes because the term routines will recognize that the
#       terminal name starts with 'qnxt'.
#
qnxtmono|Monochrome QNX4 terminal or console,
        colors@, pairs@,
        scp@, use=qnx4,

# From: Federico Bianchi <bianchi@pc-arte2.arte.unipi.it>, 1 Jul 1998
# (esr: commented out <scp> and <rmcup> to avoid warnings.)
# (TD: derive from original qnx4 entry)
qnxt2|QNX 2.15 serial terminal,
        am,
        civis@, cnorm@, cvvis@, dch1@, ich1@, kRES@, kRPL@, kUND@, kspd@,
        rep@, rmcup@, rmso=\E>setb@, setf@, smcup@, smso=\E<use=qnx4,

# QNX ANSI terminal definition
qansi-g|QNX ANSI,
        ameslokhsxon,
        colors#8cols#80lines#25ncv#19pairs#64wsl#80,
        acsc=Oa``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^Gclear=\E[2J\E[Hcr=\rcsr=\E[%i%p1%d;%p2%dr,
        cup=\E[%i%p1%d;%p2%dH$<5>cvvis=\E[?12;25h,
        dch=\E[%p1%dPdch1=\E[Pdim=\E[2mdl=\E[%p1%dM,
        dl1=\E[1Mdsl=\E[rech=\E[%p1%dXed=\E[Jel=\E[K,
        el1=\E[1K\E[Xflash=\E[?5h$<200>\E[?5lfsl=\E[?6h\E8,
        home=\E[Hhpa=\E[%i%p1%dGich=\E[%p1%d@ich1=\E[1@,
        il=\E[%p1%dLil1=\E[1Lind=\E[Sinvis=\E[9m,
        is2=\E>\E[?1l\E[?7h\E[0;10;39;49mis3=\E(B\E)0,
        kBEG=\ENnkCAN=\E[skCMD=\E[tkCPY=\ENskCRT=\ENt,
        kDL=\ENvkEXT=\ENwkFND=\ENxkHLP=\ENykHOM=\E[h,
        kLFT=\E[dkNXT=\E[ukOPT=\ENzkPRV=\E[vkRIT=\E[c,
        kcan=\E[Skcbt=\E[Zkclo=\ENckclr=\ENakcmd=\E[G,
        kcpy=\E[gkctab=\E[zkdch1=\E[Pkdl1=\E[pkend=\E[Y,
        kext=\E[ykf1=\EOPkf10=\EOYkf11=\EOZkf12=\EOA,
        kf13=\EOpkf14=\EOqkf15=\EOrkf16=\EOskf17=\EOt,
        kf18=\EOukf19=\EOvkf2=\EOQkf20=\EOwkf21=\EOx,
        kf22=\EOykf23=\EOzkf24=\EOakf25=\E[1~kf26=\E[2~,
        kf27=\E[3~kf28=\E[4~kf29=\E[5~kf3=\EORkf30=\E[6~,
        kf31=\E[7~kf32=\E[8~kf33=\E[9~kf34=\E[10~,
        kf35=\E[11~kf36=\E[12~kf37=\E[17~kf38=\E[18~,
        kf39=\E[19~kf4=\EOSkf40=\E[20~kf41=\E[21~,
        kf42=\E[22~kf43=\E[23~kf44=\E[24~kf45=\E[25~,
        kf46=\E[26~kf47=\E[27~kf48=\E[28~kf5=\EOTkf6=\EOU,
        kf7=\EOVkf8=\EOWkf9=\EOXkfnd=\ENfkhlp=\ENh,
        khts=\ENbkich1=\E[@kil1=\E[`kind=\E[akmov=\ENi,
        kmrk=\ENmkmsg=\ENeknp=\E[Ukopn=\ENokopt=\ENk,
        kpp=\E[Vkref=\ENlkres=\ENpkrfr=\ENgkri=\E[b,
        krpl=\ENrkrst=\ENjksav=\ENqkslt=\E[Tktbc=\ENd,
        kund=\ENull=\E[99Hnel=\EEop=\E[39;49mri=\E[T,
        rmacs=^Ormam=\E[?7lrmso=\E[27mrmul=\E[24m,
        rs1=\017\E[?7h\E[0;39;49m$<2>\E>\E[?1l,
        rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h,
        setb=\E[4%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}
             %=%t3%e%p1%d%;m
,
        setf=\E[3%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}
             %=%t3%e%p1%d%;m
,
        sgr=\E[0%?%p6%t;1%;%?%p5%t;2%;%?%p2%t;4%;%?%p4%t;5%;%?%p3%p1
            %|%t;7%;%?%p7%t;9%;m%?%p9%t\016%e\017%;
,
        sgr0=\E[m\017smacs=^Nsmam=\E[?7h,
        tsl=\E7\E1;24r\E[?6l\E[25;%i%p1%dHuse=ansi+arrows,
        use=ansi+localuse=ansi+repuse=ansi+inittabs,
        use=ansi+sgrbolduse=att610+cvis0use=decid+cpr,
        use=ecma+index,
#
qansi|QNX ANSI with console writes,
        daisyxhpause=qansi-g,
#
qansi-t|QNX ANSI without console writes,
        crxmuse=qansi,
#
qansi-m|QNX ANSI with mouse,
        maddr#1,
        chr=\E[cvr=\E]is1=\E[0tmcub=\E[>1hmcub1=\E[>7h,
        mcud=\E[>1hmcud1=\E[>1l\E[>9hmcuf=\E[>1h\E[>9l,
        mcuf1=\E[>7lmcuu=\E[>6hmcuu1=\E[>6lrmicm=\E[>2l,
        smicm=\E[>2huse=qansi,
#
qansi-w|QNX ANSI for windows,
        xvpause=qansi-m,

#### SCO consoles

# SCO console and SOS-Syscons console for 386bsd
# (scoansi: had unknown capabilities
#       :Gc=N:Gd=K:Gh=M:Gl=L:Gu=J:Gv=\072:\
#       :GC=E:GD=B:GH=D:GL=\64:GU=A:GV=\63:GR=C:
#       :G1=?:G2=Z:G3=@:G4=Y:G5=;:G6=I:G7=H:G8=<:\
#       :CW=\E[M:NU=\E[N:RF=\E[O:RC=\E[P:\
#       :WL=\E[S:WR=\E[T:CL=\E[U:CR=\E[V:\
# I renamed GS/GE/HM/EN/PU/PD/RT and added klone+sgr-dumb, based
# on the <smacs>=\E[12m  -- esr)
#
# klone+sgr-dumb is an error since the acsc does not match -TD
#
# In this description based on SCO's keyboard(HW) manpage list of default
# function key values:
#       F13-F24 are shifted F1-F12
#       F25-F36 are control F1-F12
#       F37-F48 are shift+control F1-F12
#
# hpa/vpa work in the console, but not in scoterm:
#       hpa=\E[%p1%dG,
#       vpa=\E[%p1%dd,
#
# SCO's terminfo uses
#       kLFT=\E[d,
#       kRIT=\E[c,
# which do not work (console or scoterm).
#
# Console documents only 3 attributes can be set with SGR (so we don't use sgr).
scoansi-old|SCO Extended ANSI standard crt (5.0.5),
        OTbs, ambceeoxon, NQ,
        colors#8cols#80it#8lines#25pairs#64,
        acsc=+/\,.-\230.\2310[5566778899::;;<<==>>FFGGHHIIJJKKLLMMNN
             OOPPQQRRSSTTUUVVWWXX`\204a0fxgqh2jYk?lZm@nEqDtCu4vAwBx3
             yszr{c}\034~\207
,
        bel=^Gblink=\E[5mbold=\E[1mcbt=\E[Z,
        civis=\E[=14;12Cclear=\E[H\E[2Jcnorm=\E[=10;12C,
        cub1=^Hcup=\E[%i%p1%d;%p2%dHcvvis=\E[=0;12C,
        dch=\E[%p1%dPdch1=\E[Pdispc=\E[=%p1%dged=\E[m\E[J,
        el=\E[m\E[Kel1=\E[1Khome=\E[Hht=^Ihts=\EH,
        ich=\E[%p1%d@ich1=\E[@ind=\E[Sinvis=\E[8mkbeg=\E[E,
        kcbt=\E[Zkdch1=^?kend=\E[Fkf1=\E[Mkf10=\E[V,
        kf11=\E[Wkf12=\E[Xkf13=\E[Ykf15=\E[akf16=\E[b,
        kf17=\E[ckf18=\E[dkf19=\E[ekf2=\E[Nkf20=\E[f,
        kf21=\E[gkf22=\E[hkf23=\E[ikf24=\E[jkf25=\E[k,
        kf26=\E[lkf27=\E[mkf28=\E[nkf29=\E[okf3=\E[O,
        kf30=\E[pkf31=\E[qkf32=\E[rkf33=\E[skf34=\E[t,
        kf35=\E[ukf36=\E[vkf37=\E[wkf38=\E[xkf39=\E[y,
        kf4=\E[Pkf40=\E[zkf41=\E[@kf42=\E[[kf43=\E[\\,
        kf44=\E[]kf45=\E[\^kf46=\E[_kf47=\E[`kf48=\E[{,
        kf5=\E[Qkf6=\E[Rkf7=\E[Skf8=\E[Tkf9=\E[Ukich1=\E[L,
        knp=\E[Gkpp=\E[Iop=\E[0;37;40mrc=\E8rev=\E[7m,
        ri=\E[Trmacs=\E[10mrmam=\E[?7lrmso=\E[mrmul=\E[m,
        sc=\E7setab=\E[4%p1%dmsetaf=\E[3%p1%dm,
        sgr0=\E[0;10msmacs=\E[12msmam=\E[?7hsmso=\E[7m,
        smul=\E[4muse=ansi+arrowsuse=ansi+idl,
        use=ansi+localuse=ecma+index,

scoansi-new|SCO Extended ANSI standard crt (5.0.6),
        km,
        civis=\E[=0ccnorm=\E[=1ccsr=\E[%i%p1%d;%p2%dr,
        cvvis=\E[=2cmgc=\E[=roc=\E[51mop=\E[50m,
        rep=\E[%p1%d;%p2%dbrmm=\E[=11L,
        sgr=\E[0%?%p1%p3%|%t;7%;%?%p2%t;4%;%?%p4%t;5%;%?%p6%t;1%;%?
            %p7%t;8%;%?%p9%t;12%e;10%;m
,
        smgb=\E[=1;0msmgbp=\E[=1;%i%p1%dm,
        smglp=\E[=2;%i%p1%dmsmgr=\E[=3;0m,
        smgrp=\E[=3;%i%p1%dmsmgt=\E[=0;0m,
        smgtp=\E[=0;%i%p1%dmsmm=\E[=10L,
        wind=\E[%i%p1%d;%p2%d;%i%p3%d;%p4%dr,
        use=scoansi-old,
# make this easy to change...
scoansi|SCO Extended ANSI standard crt,
        use=scoansi-old,

#### SGI consoles

# Sent by Stefan Stapelberg <stefan@rent-a-guru.de>, 24 Feb 1997, this is
# from SGI's terminfo database.  SGI's entry shows F9-F12 with the codes
# for the application keypad mode.  We have added iris-ansi-ap rather than
# change the original to keypad mode.
#
# (iris-ansi: added rmam/smam based on init string -- esr)
#
# This entry, and those derived from it, is used in xwsh (also known as
# winterm).  Some capabilities that do not fit into the terminfo model
# include the shift- and control-functionkeys:
#
# F1-F12 generate different codes when shift or control modifiers are used.
# For example:
#       F1              \E[001q
#       shift F1        \E[013q
#       control-F1      \E[025q
#
# In application keypad mode, F9-F12 generate codes like vt100 PF1-PF4, i.e.,
# \EOP to \EOS.  The shifted and control modifiers still do the same thing.
#
# The cursor keys also have different codes:
#       control-up      \E[162q
#       control-down    \E[165q
#       control-left    \E[159q
#       control-right   \E[168q
#
#       shift-up        \E[161q
#       shift-down      \E[164q
#       shift-left      \E[158q
#       shift-right     \E[167q
#
#       control-tab     \[072q
#
iris-ansi|iris-ansi-net|IRIS emulating 40 line ANSI terminal (almost VT100),
        am,
        cols#80it#8lines#40,
        bel=^Gbold=\E[1mclear=\E[H\E[2J,
        cnorm=\E[9/y\E[12/y\E[=6lcr=\rcud1=\n,
        cup=\E[%i%p1%d;%p2%dH,
        cvvis=\E[10/y\E[=1h\E[=2l\E[=6hed=\E[Jel=\E[K,
        el1=\E[1Khome=\E[Hht=^Ihts=\EHind=\ED,
        is2=\E[?1l\E>\E[?7h\E[100g\E[0m\E7\E[r\E8kDC=\E[P,
        kEND=\E[147qkHOM=\E[143qkLFT=\E[158qkPRT=\E[210q,
        kRIT=\E[167qkSPD=\E[218qkcbt=\E[Zkdch1=^?,
        kend=\E[146qkent=\rkf1=\E[001qkf10=\E[010q,
        kf11=\E[011qkf12=\E[012qkf2=\E[002qkf3=\E[003q,
        kf4=\E[004qkf5=\E[005qkf6=\E[006qkf7=\E[007q,
        kf8=\E[008qkf9=\E[009qkich1=\E[139qknp=\E[154q,
        kpp=\E[150qkprt=\E[209qkrmir=\E[146qkspd=\E[217q,
        nel=\EEpfkey=\EP101;%p1%d.y%p2%s\E\\rc=\E8,
        rev=\E[7mri=\EMrmam=\E[?7lrmso=\E[mrmul=\E[msc=\E7,
        sgr0=\E[msmam=\E[?7hsmso=\E[1;7msmul=\E[4m,
        tbc=\E[3guse=ansi+arrowsuse=ansi+idluse=ansi+local,

iris-ansi-ap|IRIS ANSI in application-keypad mode,
        is2=\E[?1l\E=\E[?7hkent=\EOMuse=iris-ansi,

# From the man-page, this is a quasi-vt100 emulator that runs on SGI's IRIX
# (T.Dickey 98/1/24)
iris-color|xwsh|IRIX ANSI with color,
        ncv#33,
        csr=\E[%i%p1%d;%p2%drdch=\E[%p1%dPdim=\E[2m,
        ech=\E[%p1%dXich=\E[%p1%d@rmul=\E[24mrs1=\Ec,
        rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h,
        use=ecma+italicsuse=vt100+enquse=klone+color,
        use=iris-ansi-ap,

#### OpenBSD consoles
#
# From: Alexei Malinin <Alexei.Malinin@mail.ru>; October, 2011.
#
# The following terminal descriptions for the  AMD/Intel PC console
# were prepared  based on information contained in  the OpenBSD-4.9
# termtypes.master and wscons(4) & vga(4) manuals (2010, November).
#
# Added bce based on testing with tack -TD
# Added several capabilities to pccon+base, reading wsemul_vt100_subr.c -TD
# Changed kbs to DEL and removed keys that duplicate stty settings -TD
#
# Notes from testing with vttest:
#       fails wrapping test
#       no 8-bit controls
#       identifies as vt200 with selective erase, but does not implement DECSCA
#       no vt52 mode
#       also lacks these:
#               ESC # 8   DEC Screen Alignment Test (DECALN).
#               CSI ? 5 h Reverse Video (DECSCNM).
#
pccon+keys|OpenBSD PC keyboard keys,
        kbs=^?kend=\E[8~kent=\rkf1=\E[11~kf10=\E[21~,
        kf11=\E[23~kf12=\E[24~kf13=\E[25~kf14=\E[26~,
        kf15=\E[28~kf16=\E[29~kf17=\E[31~kf18=\E[32~,
        kf19=\E[33~kf2=\E[12~kf20=\E[34~kf21=\E[35~,
        kf22=\E[36~kf23=\E[37~kf24=\E[38~kf3=\E[13~,
        kf4=\E[14~kf5=\E[15~kf6=\E[17~kf7=\E[18~kf8=\E[19~,
        kf9=\E[20~khome=\E[7~krfr=^Ruse=ansi+arrows,
        use=vt220+pcedit,
pccon+sgr+acs0|sgr and simple ASCII pseudographics for OpenBSD PC console,
        acsc=+>\,<-\^.v0#`+a:f\\h#i#j+k+l+m+n+o~p-q-r-s_t+u+v+w+x|y#
             z#{*|!}#~o
,
        bold=\E[1mrev=\E[7mrmso=\E[27m,
        sgr=\E[0%?%p1%p3%|%t;7%;%?%p6%t;1%;%?%p2%t;4%;m,
        sgr0=\E[msmso=\E[7m,
pccon+sgr+acs|sgr and default ASCII pseudographics for OpenBSD PC console,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bold=\E[1menacs=\E)0rev=\E[7mrmacs=\E(Brmso=\E[27m,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;m%?%p9%t\E(0%e
            \E(B%;
,
        sgr0=\E[m\E(Bsmacs=\E(0smso=\E[7m,
# underline renders as color
pccon+colors|ANSI colors for OpenBSD PC console,
        bce,
        ncv#2,
        op=\E[49;39muse=klone+color,
# OpenBSD uses wscons,
# + which does not implement DECSCNM or anything comparable, so it does not
#   support flash.
# + it renders underline using color.
pccon+base|base capabilities for OpenBSD PC console,
        amkmmc5imsgrnpcnxonxenlxon,
        cols#80it#8lines#24,
        bel=^Gcr=\rcub1=^Hcud1=\ncup=\E[%i%p1%d;%p2%dH,
        dch=\E[%p1%dPdch1=\E[Pech=\E[%p1%dXel1=\E[1K,
        home=\E[Hht=^Ihts=\EHich=\E[%p1%d@ind=\EDnel=\EE,
        ri=\EMrmam=\E[?7lrmul=\E[24mrs2=\Ecsmam=\E[?7h,
        smul=\E[4mtbc=\E[3guse=ansi+cpruse=ansi+csr,
        use=ansi+eraseuse=ansi+idluse=ansi+local,

pccon0-m|OpenBSD PC console without colors & with simple ASCII pseudographics,
        use=pccon+sgr+acs0use=pccon+baseuse=pccon+keys,
pccon0|OpenBSD PC console with simple ASCII pseudographics,
        use=pccon0-muse=pccon+colors,
pccon-m|OpenBSD PC console without colors,
        use=pccon+baseuse=pccon+sgr+acsuse=pccon+keys,
        use=ansi+enquse=vt220+cvis,
pccon|OpenBSD PC console,
        use=pccon-muse=pccon+colors,

#### NetBSD consoles
#
# pcvt termcap database entries (corresponding to release 3.31)
# Author's last edit-date: [Fri Sep 15 20:29:10 1995]
#
# (For the terminfo master file, I translated these into terminfo syntax.
# Then I dropped all the pseudo-HP entries. we don't want and can't use
# the :Xs: flag. Then I split :is: into a size-independent <is1> and a
# size-dependent <is2>.  Finally, I added <rmam>/<smam> -- esr)

# NOTE: <ich1> has been taken out of this entry. for reference, it should
# be <ich1=\E[@>.  For discussion, see ICH/ICH1 VERSUS RMIR/SMIR below.
# (esr: added <civis> and <cnorm> to resolve NetBSD Problem Report #4583)
pcvtXX|pcvt VT200 emulator (DEC VT220),
        amkmmirmsgrxenl,
        it#8vt#3,
        acsc=++\,\,--..00``aaffgghhiijjkkllmmnnooppqqrrssttuuvvwwxxy
             yzz~~
,
        bel=^Gblink=\E[5mbold=\E[1mcr=\rcub1=^H,
        cup=\E[%i%p1%d;%p2%dHdch=\E[%p1%dPdch1=\E[P,
        el1=\E[1Khome=\E[Hht=^Ihts=\EHich=\E[%p1%d@ind=\ED,
        is1=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8hkbs=^?,
        kdch1=\E[3~kf1=\E[17~kf2=\E[18~kf3=\E[19~,
        kf4=\E[20~kf5=\E[21~kf6=\E[23~kf7=\E[24~kf8=\E[25~,
        khome=\E[1~kich1=\E[2~kll=\E[4~knp=\E[6~kpp=\E[5~,
        nel=\EErev=\E[7mrf=/usr/share/tabset/vt100ri=\EM,
        rmacs=\E(Brmam=\E[?7lrmir=\E[4lrmkx=\E[?1l\E>,
        rmso=\E[27mrmul=\E[24m,
        rs1=\Ec\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8hsgr0=\E[m,
        smacs=\E(0smam=\E[?7hsmir=\E[4hsmkx=\E[?1h\E=,
        smso=\E[7msmul=\E[4mtbc=\E[3guse=ansi+apparrows,
        use=ansi+csruse=ansi+eraseuse=ansi+idl,
        use=ansi+localuse=decid+cpruse=ecma+index,
        use=vt220+cvis,

#       NetBSD/FreeBSD VT220 terminal emulator console (pc keyboard & monitor)
#       termcap entries for pure VT220-Emulation and 25, 28, 35, 40, 43 and
#       50 lines entries; 80 columns
pcvt25|DEC VT220 emulation with 25 lines,
        cols#80lines#25,
        is2=\E[1;25r\E[25;1Huse=pcvtXX,
pcvt28|DEC VT220 emulation with 28 lines,
        cols#80lines#28,
        is2=\E[1;28r\E[28;1Huse=pcvtXX,
pcvt35|DEC VT220 emulation with 35 lines,
        cols#80lines#35,
        is2=\E[1;35r\E[35;1Huse=pcvtXX,
pcvt40|DEC VT220 emulation with 40 lines,
        cols#80lines#40,
        is2=\E[1;40r\E[40;1Huse=pcvtXX,
pcvt43|DEC VT220 emulation with 43 lines,
        cols#80lines#43,
        is2=\E[1;43r\E[43;1Huse=pcvtXX,
pcvt50|DEC VT220 emulation with 50 lines,
        cols#80lines#50,
        is2=\E[1;50r\E[50;1Huse=pcvtXX,

#       NetBSD/FreeBSD VT220 terminal emulator console (pc keyboard & monitor)
#       termcap entries for pure VT220-Emulation and 25, 28, 35, 40, 43 and
#       50 lines entries; 132 columns
pcvt25w|DEC VT220 emulation with 25 lines and 132 cols,
        cols#132lines#25,
        is2=\E[1;25r\E[25;1Huse=pcvtXX,
pcvt28w|DEC VT220 emulation with 28 lines and 132 cols,
        cols#132lines#28,
        is2=\E[1;28r\E[28;1Huse=pcvtXX,
pcvt35w|DEC VT220 emulation with 35 lines and 132 cols,
        cols#132lines#35,
        is2=\E[1;35r\E[35;1Huse=pcvtXX,
pcvt40w|DEC VT220 emulation with 40 lines and 132 cols,
        cols#132lines#40,
        is2=\E[1;40r\E[40;1Huse=pcvtXX,
pcvt43w|DEC VT220 emulation with 43 lines and 132 cols,
        cols#132lines#43,
        is2=\E[1;43r\E[43;1Huse=pcvtXX,
pcvt50w|DEC VT220 emulation with 50 lines and 132 cols,
        cols#132lines#50,
        is2=\E[1;50r\E[50;1Huse=pcvtXX,

#       OpenBSD implements a color variation
pcvt25-color|DEC VT220 emulation with 25 lines and color,
        cols#80lines#25,
        is2=\E[1;25r\E[25;1Hkf1=\EOPkf10=\E[29~kf11=\E[23~,
        kf12=\E[24~kf13=\E[25~kf14=\E[26~kf15=\E[28~,
        kf16=\E[29~kf17=\E[31~kf18=\E[32~kf19=\E[33~,
        kf2=\EOQkf20=\E[34~kf3=\EORkf4=\EOSkf5=\E[17~,
        kf6=\E[18~kf7=\E[19~kf8=\E[20~kf9=\E[21~use=pcvtXX,
        use=ecma+color,

# Terminfo entries to enable the use of the ncurses library in colour on a
# NetBSD-arm32 console (only tested on a RiscPC).
# Created by Dave Millen <dmill@globalnet.co.uk> 22.07.98
# modified codes for setf/setb to setaf/setab, then to klone+color, corrected
# typo in invis - TD
arm100|arm100-am|Arm(RiscPC) ncurses compatible (for 640x480),
        bcexenlxon,
        lines#30,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        blink=\E[5m$<2>bold=\E[1m$<2>cub1=^Hcud1=\n,
        cuf1=\E[C$<2>cuu1=\E[A$<2>invis=\E[8m$<2>ka1=\E[q,
        ka3=\E[skb2=\E[rkc1=\E[pkc3=\E[nkent=\E[Mkf0=\E[y,
        kf1=\E[Pkf10=\E[xkf2=\E[Qkf3=\E[Rkf4=\E[Skf5=\E[t,
        kf6=\E[ukf7=\E[vkf8=\E[lkf9=\E[wrev=\E[7m$<2>,
        rmacs=^Ormam=\E[?7lrmkx=\E[?1l\E>rmso=\E[m$<2>,
        rmul=\E[m$<2>,
        sgr=\E[0%?%p1%p6%|%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5
            %;%?%p7%t;8%;m%?%p9%t\016%e\017%;$<2>
,
        sgr0=\E[m\017$<2>smacs=^Nsmam=\E[?7hsmkx=\E[?1h\E=,
        smso=\E[7m$<2>smul=\E[4m$<2>use=ansi+csr,
        use=ansi+localuse=ecma+sgruse=vt100+4bsd,
        use=klone+color,

arm100-w|arm100-wam|Arm(RiscPC) ncurses compatible (for 1024x768),
        cols#132lines#50use=arm100,

# NetBSD/x68k console VT200 emulator. This port runs on a 68K machine
# manufactured by Sharp for the Japanese market.
# From Minoura Makoto <minoura@netlaputa.or.jp>, 12 May 1996
x68k|x68k-ite|NetBSD/x68k ITE,
        cols#96lines#32,
        kbs=^?kclr=\E[9~khlp=\E[28~use=vt220-base,

# <tv@pobox.com>:
# Entry for the DNARD OpenFirmware console, close to ANSI but not quite.
#
# (still unfinished, but good enough so far.)
ofcons|DNARD OpenFirmware console,
        bw,
        cols#80lines#30,
        bel=^Gblink=\2335mbold=\2331mclear=^Lcr=\r,
        cub=\233%p1%dDcub1=\233Dcud=\233%p1%dBcud1=\233B,
        cuf=\233%p1%dCcuf1=\233Ccup=\233%i%p1%d;%p2%dH,
        cuu=\233%p1%dAcuu1=\233Adch=\233%p1%dPdch1=\233P,
        dim=\2332mdl=\233%p1%dMdl1=\233Med=\233Jel=\233K,
        flash=^Ght=^Iich=\233%p1%d@ich1=\233@il=\233%p1%dL,
        il1=\233Lind=\ninvis=\2338mkbs=^Hkcub1=\233D,
        kcud1=\233Bkcuf1=\233Ckcuu1=\233Akdch1=\233P,
        kf1=\2330Pkf10=\2330Mkf2=\2330Qkf3=\2330W,
        kf4=\2330xkf5=\2330tkf6=\2330ukf7=\2330qkf8=\2330r,
        kf9=\2330pknp=\233/kpp=\233?nel=\r\nrev=\2337m,
        rmso=\2330mrmul=\2330m,
        sgr=\2330%?%p6%t;1%;%?%p2%t;4%;%?%p4%t;5%;%?%p5%t2%;%?%p7%t8
            %;%?%p1%p3%|%t;7%;m
,
        sgr0=\2330msmso=\2337msmul=\2334m,

# NetBSD "wscons" emulator in VT220 mode.
# This entry is based on the NetBSD termcap entry.  The emulator renders
# underlined text in red.  Colors are otherwise usable.  NetBSD developers
# prefer to not specify the corresponding ncv value.
#
# Testing the emulator and reading the source code (NetBSD 2.0), it appears
# that "vt220" is inaccurate.  There are a few VT220-features, but most of the
# VT220 screens in vttest do not work with this emulator.  For instance, it
# identifies itself (primary DA response) as a VT220 with selective erase.  But
# the selective erase feature does not work.  The secondary response is copied
# from Kermit's emulation of VT220, does not correspond to actual VT220.  At
# the level of detail in a termcap, it is a passable emulator, since ECH does
# work.  Don't use it on a VMS system -TD
wsvt25|NetBSD wscons in 25 line DEC VT220 mode,
        bce,
        colors#8lines#25pairs#64,
        is2=\E[r\E[25;1Hkdch1=\E[3~kend=\E[8~kf1=\E[11~,
        kf2=\E[12~kf3=\E[13~kf4=\E[14~kf5=\E[15~,
        khome=\E[7~op=\E[mrs1=\Ecsetab=\E[4%p1%dm,
        setaf=\E[3%p1%dmuse=vt220,

wsvt25m|NetBSD wscons in 25 line DEC VT220 mode with Meta,
        kmuse=wsvt25,

# NetBSD 6.x still uses wscons, with minor changes (2014/02/22) -TD
#
# TERM is by default vt100 for the console, wsvt25 for other ttys.
# Initial testing set TERM=xterm, based on comments by developers, found too
# many differences to continue in that path.  However, test-results may be
# useful to people curious about compatibility with xterm.
#
# Testing with tack:
# -----------------
# Failed: cbt, bel, flash, cvvis, smul (color), blink, invis
# There is color-bleeding in the color-pairs screen.
# Attributes do not work with color
# Failed: vpa/hpa
# Failed: kf1-kf4, kf13-kf48, khome, kend
#       (effectively xterm-r6 for function-keys)
# None of the function or cursor key-modifiers are encoded.
# Console hangs in the smm/rmm test if TERM=xterm, does not show test
#
# Testing with vttest:
# -------------------
# Identifies as VT220 with selective erase
#       (however, selective erase refers to DECSCA, SPA)
# Does not implement VT52
# Uses spaces to simulate double-size characters
# Does not support 8-bit controls
# Does not support VT220 reports
# Does not support send/receive mode
# Supports ECH (like rxvt)
# Does not support DECSCA
# Does not support any of the ISO-6429 cursor-movement
# Does not support any of the ISO-6429 miscellaneous tests
#       (SL/SR also leave unexpected char on screen too)
# Background does not change in menu 11.6.9 (SGR 22-27)
# None of the xterm special features tests work
netbsd6|NetBSD wscons in 25 line DEC VT100 mode,
        kbs=^?use=wsvt25,

# `rasterconsole' provided by 4.4BSD, NetBSD and OpenBSD on SPARC, and
# DECstation/pmax.
rcons|BSD rasterconsole,
        use=sun-il,
# Color version of above. Color currently only provided by NetBSD.
rcons-color|BSD rasterconsole with ANSI color,
        bce,
        colors#8pairs#64,
        op=\E[msetab=\E[4%p1%dmsetaf=\E[3%p1%dmuse=rcons,

# mgterm -- MGL/MGL2, MobileGear Graphic Library
# for PocketBSD,PocketLinux,NetBSD/{hpcmips,mac68k}
# -- the setf/setb are probably incorrect, more likely setaf/setab -TD
# -- compare with cons25w
mgterm|MGL/MGL2 MobileGear Graphic Library,
        OTbs, OTpt, ambcebweokmmsgrnpc,
        colors#8cols#80it#8lines#18pairs#64,
        bel=^Gblink=\E[5mbold=\E[1mcbt=\E[Zcr=\rcub1=^H,
        cup=\E[%i%p1%d;%p2%dHdch=\E[%p1%dPdch1=\E[P,
        dim=\E[30;1mech=\E[%p1%dXel1=\E[1Khome=\E[H,
        hpa=\E[%i%p1%d`ht=^Iich=\E[%p1%d@ich1=\E[@ind=\E[S,
        kb2=\E[Ekcbt=\E[Zkdch1=^?kend=\E[Fkf1=\E[M,
        kf10=\E[Vkf11=\E[Wkf12=\E[Xkf2=\E[Nkf3=\E[O,
        kf4=\E[Pkf5=\E[Qkf6=\E[Rkf7=\E[Skf8=\E[Tkf9=\E[U,
        kich1=\E[Lknp=\E[Gkpp=\E[Inel=\E[Eop=\E[xrev=\E[7m,
        ri=\E[Trmso=\E[mrs2=\E[x\E[m\Ecsetb=\E[4%p1%dm,
        setf=\E[3%p1%dmsgr0=\E[msmso=\E[7mvpa=\E[%i%p1%dd,
        use=ansi+arrowsuse=ansi+csruse=ansi+erase,
        use=ansi+idluse=ansi+localuse=ecma+index,

#### FreeBSD console entries

# Originally from termcap:
#
# From: Andrey Chernov <ache@astral.msk.su> 29 Mar 1996
# Andrey Chernov maintains the FreeBSD termcap distributions.
#
# Note: Users of FreeBSD 2.1.0 and older versions must either upgrade
# or comment out the :cb: capability in the console entry.
#
# Alexander Lukyanov reports:
# I have seen FreeBSD-2.1.5R... The old el1 bug changed, but it is still there.
# Now el1 clears not only to the line beginning, but also a large chunk
# of previous line. But there is another bug - ech does not work at all.

# syscons, sc - the console driver
#
# for syscons
# common entry without semigraphics
# Bug: The <op> capability resets attributes.
# Bug? The ech and el1 attributes appear to move the cursor in some cases; for
# instance el1 does if the cursor is moved to the right margin first.  Removed
# by T.Dickey 97/5/3 (ech=\E[%p1%dX, el1=\E[1K)
#
# Setting colors turns off reverse; we cannot guarantee order, so use ncv.
# Note that this disables standout with color.
#
# The emulator sends different strings based on shift- and control-keys,
# like scoansi:
#       F13-F24 are shifted F1-F12
#       F25-F36 are control F1-F12
#       F37-F48 are shift+control F1-F12
cons25w|ansiw|ansi80x25-raw|FreeBSD console (25-line raw mode),
        ambcebweomsgrnpc,
        cols#80it#8lines#25ncv#21,
        bel=^Gblink=\E[5mbold=\E[1mcbt=\E[Zcnorm=\E[=0C,
        cr=\rcub1=^Hcup=\E[%i%p1%d;%p2%dHcvvis=\E[=1C,
        dch=\E[%p1%dPdch1=\E[Pdim=\E[30;1mech=\E[%p1%dX,
        home=\E[Hhpa=\E[%i%p1%d`ht=^Iich=\E[%p1%d@,
        ich1=\E[@ind=\E[Skb2=\E[Ekcbt=\E[Zkdch1=^?,
        kend=\E[Fkf1=\E[Mkf10=\E[Vkf11=\E[Wkf12=\E[X,
        kf13=\E[Ykf14=\E[Zkf15=\E[akf16=\E[bkf17=\E[c,
        kf18=\E[dkf19=\E[ekf2=\E[Nkf20=\E[fkf21=\E[g,
        kf22=\E[hkf23=\E[ikf24=\E[jkf25=\E[kkf26=\E[l,
        kf27=\E[mkf28=\E[nkf29=\E[okf3=\E[Okf30=\E[p,
        kf31=\E[qkf32=\E[rkf33=\E[skf34=\E[tkf35=\E[u,
        kf36=\E[vkf37=\E[wkf38=\E[xkf39=\E[ykf4=\E[P,
        kf40=\E[zkf41=\E[@kf42=\E[[kf43=\E[\\kf44=\E[],
        kf45=\E[\^kf46=\E[_kf47=\E[`kf48=\E[{kf5=\E[Q,
        kf6=\E[Rkf7=\E[Skf8=\E[Tkf9=\E[Ukich1=\E[Lknp=\E[G,
        kpp=\E[Inel=\E[Eop=\E[xrc=\E8rev=\E[7mri=\E[T,
        rmso=\E[mrs2=\E[x\E[m\Ecsc=\E7,
        sgr=\E[0%?%p1%t;2;7%;%?%p3%t;7%;%?%p4%t;5%;%?%p5%t;30;1%;%?
            %p6%t;1%;m
,
        sgr0=\E[msmso=\E[7mvpa=\E[%i%p1%dduse=ansi+arrows,
        use=ansi+eraseuse=ansi+idluse=ansi+local,
        use=ecma+indexuse=klone+color,

cons25|ansis|ansi80x25|FreeBSD console (25-line ANSI mode),
        acsc=-\030.^Y0\333`\004a\260f\370g\361h\261i\025j\331k\277l
             \332m\300n\305q\304t\303u\264v\301w\302x\263y\363z\362~
             \371
,
        use=cons25w,
cons25-debian|FreeBSD console with debian backspace (25-line ANSI mode),
        kbs=^?kdch1=\E[3~use=cons25,
cons25-m|ansis-mono|ansi80x25-mono|FreeBSD console (25-line mono ANSI mode),
        colors@, pairs@,
        bold@, dim@, op@, rmul=\E[msetab@, setaf@,
        sgr=\E[0%?%p1%t;2;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;m,
        smul=\E[4muse=cons25,
cons30|ansi80x30|FreeBSD console (30-line ANSI mode),
        lines#30use=cons25,
cons30-m|ansi80x30-mono|FreeBSD console (30-line mono ANSI mode),
        lines#30use=cons25-m,
cons43|ansi80x43|FreeBSD console (43-line ANSI mode),
        lines#43use=cons25,
cons43-m|ansi80x43-mono|FreeBSD console (43-line mono ANSI mode),
        lines#43use=cons25-m,
cons50|ansil|ansi80x50|FreeBSD console (50-line ANSI mode),
        lines#50use=cons25,
cons50-m|ansil-mono|ansi80x50-mono|FreeBSD console (50-line mono ANSI mode),
        lines#50use=cons25-m,
cons60|ansi80x60|FreeBSD console (60-line ANSI mode),
        lines#60use=cons25,
cons60-m|ansi80x60-mono|FreeBSD console (60-line mono ANSI mode),
        lines#60use=cons25-m,
cons25r|pc3r|ibmpc3r|cons25-koi8-r|FreeBSD console w/koi8-r cyrillic,
        acsc=-\030.^Y0\215`\004a\220f\234h\221i\025j\205k\203l\202m
             \204n\212q\0t\206u\207v\211w\210x\201y\230z\231~
             \225
,
        use=cons25w,
cons25r-m|pc3r-m|ibmpc3r-mono|cons25-koi8r-m|FreeBSD console w/koi8-r cyrillic (mono),
        colors@, pairs@,
        op@, rmul=\E[msetab@, setaf@,
        sgr=\E[0%?%p1%t;2;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p5
            %t;30;1%;%?%p6%t;1%;m
,
        smul=\E[4muse=cons25r,
cons50r|cons50-koi8r|FreeBSD console w/koi8-r cyrillic (50 lines),
        lines#50use=cons25r,
cons50r-m|cons50-koi8r-m|FreeBSD console w/koi8-r cyrillic (50-line mono),
        lines#50use=cons25r-m,
cons60r|cons60-koi8r|FreeBSD console w/koi8-r cyrillic (60 lines),
        lines#60use=cons25r,
cons60r-m|cons60-koi8r-m|FreeBSD console w/koi8-r cyrillic (60-line mono),
        lines#60use=cons25r-m,
# ISO 8859-1 FreeBSD console
cons25l1|cons25-iso8859|FreeBSD console w/iso 8859-1 chars,
        acsc=+\253\,\273-\030.\031`\201a\202f\207g\210i\247j\213k
             \214l\215m\216n\217o\220p\221q\222r\223s\224t\225u
             \226v\227w\230x\231y\232z\233~\237
,
        use=cons25w,
cons25l1-m|cons25-iso-m|FreeBSD console w/iso 8859-1 chars (mono),
        colors@, pairs@,
        bold@, dim@, op@, rmul=\E[msetab@, setaf@,
        sgr=\E[0%?%p1%t;2;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;m,
        smul=\E[4muse=cons25l1,
cons50l1|cons50-iso8859|FreeBSD console w/iso 8859-1 chars (50 lines),
        lines#50use=cons25l1,
cons50l1-m|cons50-iso-m|FreeBSD console w/iso 8859-1 chars (50-line mono),
        lines#50use=cons25l1-m,
cons60l1|cons60-iso|FreeBSD console w/iso 8859-1 chars (60 lines),
        lines#60use=cons25l1,
cons60l1-m|cons60-iso-m|FreeBSD console w/iso 8859-1 chars (60-line mono),
        lines#60use=cons25l1-m,

# vt - virtual terminal console driver
#
# Starting with FreeBSD 8, an alternative configuration for syscons is provided,
# which is intended to be xterm-compatible.  See for example
#       http://svnweb.freebsd.org/base/stable/8/sys/dev/syscons/
# in particular scterm-teken.c
#
# Some of the documentation refers to this as "vt"; its proper name is "teken".
#
# The sc(4) manual page states that it is possible to switch between the two
# by editing /boot/loader.conf, adding
#       kern.vty=sc
# Doing that does not change the default TERM variable.  That is hard-coded in
# /etc/ttys, rather than deriving it from the kernel state.
#
# For FreeBSD 12 and 13:
# ---------------------
# In newer releases, it is no longer possible to boot into a configuration that
# works with syscons.  According to efi(4),
# "The vt(4) system console is automatically selected when booting via UEFI."
# See FreeBSD #264226.
#
# FreeBSD 13 supports 64-bit machines which boot with UEFI:
#       https://www.freebsd.org/platforms/
# The i386 platform does not use UEFI (and modifying the loader configuration
# does load sysconf); however because no updates (fixes) are available, most
# developers will regard that as unsupported.
#
# With FreeBSD 13, even when syscons is loaded (e.g., with the i386 platform),
# its function-keys are not configured.  Using
#       vidcontrol -T cons25
# repairs this.
#
# When teken is loaded, vidcontrol can switch at runtime between the
# teken/cons25 function keys:
#       vidcontrol -T cons25
#       vidcontrol -T xterm
# However due to a limitation in the implementation, only the first 12 function
# keys are available.  The real syscons supports 48 function keys (using the
# shift and control modifiers), while xterm supports more than twice as many.
#
# vidcontrol does not change the emulation. As a result, the quarter (17/73) of
# non-function key capabilities which differ between syscons and teken are
# unsupported in the UEFI-based configurations.
#
# tack:
#       VT100 line-drawing does not work (UTF-8 equivalents do).
#       Shift/control modifiers have no effect on special keys.
#       Meta does not work.
# vttest:
#       supports REP (repeat).
#       still does not support left/right margins
#       SU/SD work, but not SL/SR
#       alternate screen does not work
#       ENQ/DA1 is unimplemented (the terminal does not identify itself)
#       CPR, XCPR are unimplemented (i.e., vttest and resize are broken)
#       implements X11 (original) xterm-mouse.
# ncurses:
#       UTF-8 line-drawing works, including some double/thick lines
#
# For FreeBSD 9 and 10:
# --------------------
# The /etc/ttys entries for console and other ttys are all configured to set
# TERM=xterm.
#
# Testing with tack:
# There is no VT100 line-drawing (uses +'s and -'s)
# Shifted f1-f12 give cons25 codes, rather than xterm function-keys
#
# Testing with vttest:
# Menu 2 diamonds don't work, blink ditto, light background ditto
# The terminal identifies itself as VT100 with AVO
# There is no VT52 support
# There is no doublesize character support
# The terminal supports ECH (like rxvt)
# The terminal does not support send/receive mode
# The terminal supports all of the ISO-6429 cursor-movement
# The terminal supports some of the ISO-6429 miscellaneous tests
#       (SL/SR also leave unexpected char on screen too)
#
# Considering cons25 as a base, the line-drawing mostly works, but is missing
# the cells which happen to have ASCII control-character values:
#       -    ^X    arrow pointing up
#       .    ^Y    arrow pointing down
#       i    ^Y    lantern
#       `    ^D    diamond
#
# Those are removed from this entry's acsc string to avoid confusion.
# The resulting description provides correct line-drawing and function-keys -TD
teken-2018|teken as of 2018,
        bw@, mirxenl, NQ,
        acsc=0\333a\260f\370g\361h\261j\331k\277l\332m\300n\305q
             \304t\303u\264v\301w\302x\263y\363z\362~\371
,
        cvvis@, hpa=\E[%i%p1%dGhts=\EHkdch1=\E[3~kent=\r,
        kf1=\EOPkf10=\E[21~kf11=\E[23~kf12=\E[24~kf2=\EOQ,
        kf3=\EORkf4=\EOSkf5=\E[15~kf6=\E[17~kf7=\E[18~,
        kf8=\E[19~kf9=\E[20~kich1=\E[2~knp=\E[6~kpp=\E[5~,
        rmir=\E[4lsmir=\E[4htbc=\E[3guse=vt220+cvis,
        use=cons25,

teken-2022|teken as of 2022,
        ambceeomirmsgrnpc, NQ,
        cols#80it#8lines#25ncv#21, U8#1,
        bold=\E[1mcr=\rcub1=^Hdim=\E[30;1mech=\E[%p1%dX,
        ind=\E[Skent=\rnel=\E[Eop=\E[xrev=\E[7mri=\E[T,
        rmso=\E[27mrs2=\E[x\E[m\Ec,
        sgr=\E[0%?%p1%t;2;7%;%?%p3%t;7%;%?%p5%t;30;1%;%?%p6%t;1%;m,
        sgr0=\E[muse=vt220+cvisuse=ecma+index,
        use=ansi+arrowsuse=ansi+csruse=ansi+cup,
        use=ansi+eraseuse=ansi+idcuse=ansi+idl,
        use=ansi+localuse=ansi+rca2use=ansi+sgrso,
        use=ansi+tabsuse=klone+color,

teken-vt+fkeys|teken's xterm special keys,
        kend=\E[Fkf1=\EOPkf10=\E[21~kf11=\E[23~kf12=\E[24~,
        kf2=\EOQkf3=\EORkf4=\EOSkf5=\E[15~kf6=\E[17~,
        kf7=\E[18~kf8=\E[19~kf9=\E[20~khome=\E[H,
        use=vt220+pcedit,

teken-sc+fkeys|teken's syscons special keys,
        kdch1=^?kend=\E[Fkf1=\E[Mkf10=\E[Vkf11=\E[W,
        kf12=\E[Xkf2=\E[Nkf3=\E[Okf4=\E[Pkf5=\E[Qkf6=\E[R,
        kf7=\E[Skf8=\E[Tkf9=\E[Ukhome=\E[Hkich1=\E[L,
        knp=\E[Gkpp=\E[I,

teken-sc|teken imitating syscons,
        use=teken-sc+fkeysuse=teken-2022,

teken|teken-vt|teken imitating xterm,
        xenluse=teken-vt+fkeysuse=xterm+x11mouse,
        use=teken-2022,

teken-16color|teken using 16 colors,
        use=ibm+16coloruse=teken,

#### 386BSD and BSD/OS Consoles
#

# This was the original 386BSD console entry (I think).
# Some places it's named oldpc3|oldibmpc3.
# From: Alex R.N. Wetmore <aw2t@andrew.cmu.edu>
origpc3|origibmpc3|IBM PC 386BSD console,
        OTbs, ambweoxon,
        cols#80lines#25,
        acsc=j\331k\277l\332m\300n\305q\304t\303u\264v\301w\302x
             \263
,
        bold=\E[7mclear=\Eccub1=^Hcup=\E[%i%p1%2d;%p2%2dH,
        ed=\E[Jel=\E[Khome=\E[Hind=\E[Skcub1=\E[D,
        kcud1=\E[Bkcuf1=\E[Ckcuu1=\E[Akhome=\E[Yri=\E[T,
        rmso=\E[1;0x\E[2;7xrmul=\E[1;0x\E[2;7x,
        sgr0=\E[m\E[1;0x\E[2;7xsmso=\E[1;7x\E[2;0x,
        smul=\E[1;7x\E[2;0xuse=ansi+local1,

# description of BSD/386 console emulator in version 1.0 (supplied by BSDI)
oldpc3|oldibmpc3|old IBM PC BSD/386 console,
        OTbs, km,
        lines#25,
        bel=^Gbold=\E[=15Fcr=\rcud1=\ndim=\E[=8Fdl1=\E[M,
        ht=^Iil1=\E[Lind=\nkich1=\E[Lkll=\E[Fknp=\E[G,
        kpp=\E[Inel=\r\nsgr0=\E[=Ruse=ansi+arrows,

# Description of BSD/OS console emulator in version 1.1, 2.0, 2.1
# Note, the emulator supports many of the additional console features
# listed in the iBCS2 (e.g. character-set selection) though not all
# are described here.  This entry really ought to be upgraded.
# Also note, the console will also work with fewer lines after doing
# "stty rows NN", e.g. to use 24 lines.
# (Color support from Kevin Rosenberg <kevin@cyberport.com>, 2 May 1996)
# Bug: The <op> capability resets attributes.
bsdos-pc|IBM PC BSD/OS console,
        sgr=\E[0;10%?%p1%t;7%;%?%p2%t;1%;%?%p3%t;7%;%?%p4%t;5%;%?%p6
            %t;1%;%?%p7%t;8%;%?%p9%t;11%;m
,
        use=bsdos-pc-nobold,

bsdos-pc-nobold|BSD/OS PC console w/o bold,
        use=klone+coloruse=bsdos-pc-m,

bsdos-pc-m|bsdos-pc-mono|BSD/OS PC console mono,
        OTbs, ameokmxon,
        cols#80it#8lines#25,
        bel=^Gclear=\Eccr=\rcub1=^Hcud1=\n,
        cup=\E[%i%p1%d;%p2%dHed=\E[Jel=\E[Khome=\E[Hht=^I,
        ind=\nkich1=\E[Lkll=\E[Fknp=\E[Gkpp=\E[Inel=\r\n,
        rc=\E8sc=\E7,
        sgr=\E[0;10%?%p1%t;7%;%?%p3%t;7%;%?%p4%t;5%;%?%p6%t;1%;%?%p7
            %t;8%;%?%p9%t;11%;m%?%p5%t\E[=8F%;
,
        use=ansi+arrowsuse=ansi+idluse=ansi+local,
        use=klone+sgr8,

# Old names for BSD/OS PC console used in releases before 4.1.
pc3|BSD/OS on the PC console,
        use=bsdos-pc-nobold,
ibmpc3|pc3-bold|BSD/OS on the PC console with bold instead of underline,
        use=bsdos-pc,

# BSD/OS on the SPARC
bsdos-sparc|Sun SPARC BSD/OS console,
        use=sun,

# BSD/OS on the PowerPC
bsdos-ppc|PowerPC BSD/OS console,
        use=bsdos-pc,


#### DEC VT52
# (<acsc>/<rmacs>/<smacs> capabilities aren't in DEC's official entry -- esr)
#
# Actually (TD pointed this out at the time the acsc string was added):
# VT52 shouldn't define full acsc since most of the cells don't match.
# see VT100 manual page A-31.  This is the list that does match:
#       f degree
#       g plus/minus
#       h right-arrow
#       k down-arrow
#       m scan-1
#       o scan-3
#       q scan-5
#       s scan-7
# The line-drawing happens to work in several terminal emulators, but should
# not be used as a guide to the capabilities of the VT52.  Note in particular
# that VT52 does not support line-drawing characters (the scan-X values refer
# to a crude plotting feature) -TD
vt52|DEC VT52,
        lines#24,
        acsc=+h.k0affggolpnqprrssrmacs=\EGrmkx=\E>,
        smacs=\EFsmkx=\E=u8=\E/[KL]use=vt50huse=vt52-basic,

# This is more likely the "vt52" that you would see in emulation, i.e., no
# keypad, no graphics.
vt52-basic|VT52 for emulators,
        cols#80it#8lines#24,
        bel=^Gclear=\EH\EJcr=\rcub1=\EDcud1=\EBcuf1=\EC,
        cup=\EY%p1%' '%+%c%p2%' '%+%ccuu1=\EAed=\EJel=\EK,
        home=\EHht=^Iind=\nkbs=^Hnel=\r\nri=\EI,
        use=vt52+arrows,

vt52+arrows|cursor keys for VT52,
        kcub1=\EDkcud1=\EBkcuf1=\ECkcuu1=\EA,

#### DEC VT100 and compatibles
#
# DEC terminals from the VT100 forward are collected here. Older DEC terminals
# and micro consoles can be found in the `obsolete' section.  More details on
# the relationship between the VT100 and ANSI X3.64/ISO 6429/ECMA-48 may be
# found near the end of this file.
#
# Except where noted, these entries are DEC's official terminfos.
# Contact Bill Hedberg <hedberg@hannah.enet.dec.com> of Terminal Support
# Engineering for more information.  Updated terminfos and termcaps
# are kept available at ftp://gatekeeper.dec.com/pub/DEC/termcaps.
#
# In October 1995 DEC sold its terminals business, including the VT and Dorio
# line and trademark, to SunRiver Data Systems.  SunRiver has since changed
# its name to Boundless Technologies; see http://www.boundless.com.
#

# NOTE:  Any VT100 emulation, whether in hardware or software, almost
# certainly includes what DEC called the `Level 1 editing extension' codes;
# only the very oldest VT100s lacked these and there probably aren't any of
# those left alive.  To capture these, use one of the VT102 entries.
#
# Note that the <xenl> glitch in vt100 is not quite the same as on the Concept,
# since the cursor is left in a different position while in the
# weird state (concept at beginning of next line, vt100 at end
# of this line) so all versions of vi before 3.7 don't handle
# <xenl> right on vt100. The correct way to handle <xenl> is when
# you output the char in column 80, immediately output CR LF
# and then assume you are in column 1 of the next line. If <xenl>
# is on, am should be on too.
#
# I assume you have smooth scroll off or are at a slow enough baud
# rate that it doesn't matter (1200? or less). Also this assumes
# that you set auto-nl to "on", if you set it off use vt100-nam
# below.
#
# The padding requirements listed here are guesses. It is strongly
# recommended that xon/xoff be enabled, as this is assumed here.
#
# The vt100 uses <rs2> and <rf> rather than <is2>/<tbc>/<hts> because the
# tab settings are in non-volatile memory and don't need to be
# reset upon login. Also setting the number of columns glitches
# the screen annoyingly. You can type "reset" to get them set.
#
# The VT100 series terminals have cursor ("arrows") keys which can operate
# in two different modes: Cursor Mode and Application Mode.  Cursor Mode
# is the reset state, and is assumed to be the normal state.  Application
# Mode is the "set" state.  In Cursor Mode, the cursor keys transmit
# "Esc [ {code}" sequences, conforming to ANSI standards.  In Application
# Mode, the cursor keys transmit "Esc O <code>" sequences.  Application Mode
# was provided primarily as an aid to the porting of VT52 applications.  It is
# assumed that the cursor keys are normally in Cursor Mode, and expected that
# applications such as vi will always transmit the <smkx> string.  Therefore,
# the definitions for the cursor keys are made to match what the terminal
# transmits after the <smkx> string is transmitted.  If the <smkx> string
# is a null string or is not defined, then cursor keys are assumed to be in
# "Cursor Mode", and the cursor keys definitions should match that assumption,
# else the application may fail.  It is also expected that applications will
# always transmit the <rmkx> string to the terminal before they exit.
#
# The VT100 series terminals have an auxiliary keypad, commonly referred to as
# the "Numeric Keypad", because it is a cluster of numeric and function keys.
# The Numeric Keypad which can operate in two different modes: Numeric Mode and
# Application Mode.  Numeric Mode is the reset state, and is assumed to be
# the normal state.  Application Mode is the "set" state.  In Numeric Mode,
# the numeric and punctuation keys transmit ASCII 7-bit characters, and the
# Enter key transmits the same as the Return key (Note: the Return key
# can be configured to send either LF (\015) or CR LF).  In Application Mode,
# all the keypad keys transmit "Esc O {code}" sequences.  The PF1 - PF4 keys
# always send the same "Esc O {code}" sequences.  It is assumed that the keypad
# is normally in Numeric Mode.  If an application requires that the keypad be
# in Application Mode then it is expected that the user, or the application,
# will set the TERM environment variable to point to a terminfo entry which has
# defined the <smkx> string to include the codes that switch the keypad into
# Application Mode, and the terminfo entry will also define function key
# fields to match the Application Mode control codes.  If the <smkx> string
# is a null string or is not defined, then the keypad is assumed to be in
# Numeric Mode.  If the <smkx> string switches the keypad into Application
# Mode, it is expected that the <rmkx> string will contain the control codes
# necessary to reset the keypad to "Normal" mode, and it is also expected that
# applications which transmit the <smkx> string will also always transmit the
# <rmkx> string to the terminal before they exit.
#
# Here's a diagram of the VT100 keypad keys with their bindings.
# The top line is the name of the key (some DEC keyboards have the keys
# labelled somewhat differently, like GOLD instead of PF1, but this is
# the most "official" name).  The second line is the escape sequence it
# generates in Application Keypad mode (where "$" means the ESC
# character).  The third line contains two items, first the mapping of
# the key in terminfo, and then in termcap.
#   _______________________________________
#  |   PF1   |   PF2   |   PF3   |   PF4   |
#  |   $OP   |   $OQ   |   $OR   |   $OS   |
#  |_kf1__k1_|_kf2__k2_|_kf3__k3_|_kf4__k4_|
#  |    7         8         9         -    |
#  |   $Ow   |   $Ox   |   $Oy   |   $Om   |
#  |_kf9__k9_|_kf10_k;_|_kf0__k0_|_________|
#  |    4    |    5    |    6    |    ,    |
#  |   $Ot   |   $Ou   |   $Ov   |   $Ol   |
#  |_kf5__k5_|_kf6__k6_|_kf7__k7_|_kf8__k8_|
#  |    1    |    2    |    3    |         |
#  |   $Oq   |   $Or   |   $Os   |  enter  |
#  |_ka1__K1_|_kb2__K2_|_ka3__K3_|  $OM    |
#  |         0         |   .     |         |
#  |        $Op        |  $On    |         |
#  |___kc1_______K4____|_kc3__K5_|_kent_@8_|
#
# Note however, that the arrangement of the 5-key ka1-kc3 do not follow the
# terminfo guidelines.  That is a compromise used to assign the remaining
# keys on the keypad to kf5-kf0, used on older systems with legacy termcap
# support:
vt100+keypad|DEC VT100 numeric keypad no fkeys,
        ka1=\EOqka3=\EOskb2=\EOrkc1=\EOpkc3=\EOn,
vt100+pfkeys|DEC VT100 numeric keypad (kf1-kf4),
        kent=\EOMkf1=\EOPkf2=\EOQkf3=\EORkf4=\EOS,
        use=vt100+keypad,
vt100+fnkeys|DEC VT100 numeric keypad (kf0-kf10),
        kf0=\EOykf10=\EOxkf5=\EOtkf6=\EOukf7=\EOvkf8=\EOl,
        kf9=\EOwuse=vt100+pfkeys,
#
# A better adaptation to modern keyboards such as the PC's, which have a dozen
# function keys and the keypad 2,4,6,8 keys are labeled with arrows keys, is to
# use the 5-key arrangement to model the arrow keys as suggested in the
# terminfo guidelines:
#   _______________________________________
#  |   PF1   |   PF2   |   PF3   |   PF4   |
#  |   $OP   |   $OQ   |   $OR   |   $OS   |
#  |_kf1__k1_|_kf2__k2_|_kf3__k3_|_kf4__k4_|
#  |    7         8         9         -    |
#  |   $Ow   |   $Ox   |   $Oy   |   $Om   |
#  |_ka1__K1_|_________|_ka3__K3_|_________|
#  |    4    |    5    |    6    |    ,    |
#  |   $Ot   |   $Ou   |   $Ov   |   $Ol   |
#  |_________|_kb2__K2_|_________|_________|
#  |    1    |    2    |    3    |         |
#  |   $Oq   |   $Or   |   $Os   |  enter  |
#  |_kc1__K4_|_________|_kc3__K5_|  $OM    |
#  |         0         |   .     |         |
#  |        $Op        |  $On    |         |
#  |___________________|_________|_kent_@8_|
#
vt220+keypad|DEC VT220 numeric keypad,
        ka1=\EOwka3=\EOykb2=\EOukc1=\EOqkc3=\EOs, ka2=\EOx,
        kb1=\EOt, kb3=\EOv, kc2=\EOruse=vt100+pfkeys,
#
vt100+enq|ncurses extension for VT100-style ENQ,
        u8=\E[?1;2cuse=ansi+enq,
vt102+enq|ncurses extension for VT102-style ENQ,
        u8=\E[?6cuse=ansi+enq,
#
# And here, for those of you with orphaned VT100s lacking documentation, is
# a description of the soft switches invoked when you do `Set Up'.
#
#  Scroll 0-Jump               Shifted 3   0-#
#  |      1-Smooth             |           1-British pound sign
#  | Autorepeat 0-Off          | Wrap Around 0-Off
#  | |          1-On           | |           1-On
#  | | Screen 0-Dark Bkg       | | New Line 0-Off
#  | | |      1-Light Bkg      | | |        1-On
#  | | | Cursor 0-Underline    | | | Interlace 0-Off
#  | | | |      1-Block        | | | |         1-On
#  | | | |                     | | | |
#  1 1 0 1       1 1 1 1       0 1 0 0       0 0 1 0       <--Standard Settings
#                | | | |                     | | | |
#                | | | Auto XON/XOFF 0-Off   | | | Power 0-60 Hz
#                | | |               1-On    | | |       1-50 Hz
#                | | ANSI/VT52 0-VT52        | | Bits Per Char. 0-7 Bits
#                | |           1-ANSI        | |                1-8 Bits
#                | Keyclick 0-Off            | Parity 0-Off
#                |          1-On             |        1-On
#                Margin Bell 0-Off           Parity Sense 0-Odd
#                            1-On                         1-Even
#
# The following SET-UP modes are assumed for normal operation:
#       ANSI_MODE       AUTO_XON/XOFF_ON        NEWLINE_OFF     80_COLUMNS
#       WRAP_AROUND_ON  JUMP_SCROLL_OFF
# Other SET-UP modes may be set for operator convenience or communication
# requirements; I recommend
#       AUTOREPEAT_ON   BLOCK_CURSOR    MARGIN_BELL_OFF    SHIFTED_3_#
# Unless you have a graphics add-on such as Digital Engineering's VT640
# (and even then, whenever it can be arranged!) you should set
#       INTERLACE_OFF
#
# (vt100: I added <rmam>/<smam> based on the init string, also <OTbs>. -- esr)
vt100|vt100-am|DEC VT100 (w/advanced video),
        OTbs, xenlxon,
        vt#3,
        kcub1=\EODkcud1=\EOBkcuf1=\EOCkcuu1=\EOAlf1=pf1,
        lf2=pf2lf3=pf3lf4=pf4mc0=\E[0irmam=\E[?7l,
        rmkx=\E[?1l\E>rs2=\E<\E>\E[?3;4;5l\E[?7;8h\E[r,
        sgr=\E[0%?%p1%p6%|%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5
            %;m%?%p9%t\016%e\017%;$<2>
,
        smam=\E[?7hsmkx=\E[?1h\E=smso=\E[7m$<2>,
        use=ansi+csruse=ansi+ppuse=decid+cpruse=vt100+4bsd,
        use=vt100+fnkeys,

vt100+4bsd|DEC VT100 from 4.0BSD,
        ammsgr,
        cols#80it#8lines#24,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^Gblink=\E[5m$<2>bold=\E[1m$<2>,
        clear=\E[H\E[J$<50>cr=\rcub1=^Hcud1=\n,
        cuf1=\E[C$<2>cup=\E[%i%p1%d;%p2%dH$<5>,
        cuu1=\E[A$<2>ed=\E[J$<50>el=\E[K$<3>el1=\E[1K$<3>,
        enacs=\E(B\E)0home=\E[Hht=^Ihts=\EHind=\nkbs=^H,
        kcub1=\E[Dkcud1=\E[Bkcuf1=\E[Ckcuu1=\E[A,
        rev=\E[7m$<2>ri=\EM$<5>rmacs=^Ormso=\E[m$<2>,
        rmul=\E[m$<2>rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h,
        sgr=\E[0%?%p1%p6%|%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5
            %;m%?%p9%t\016%e\017%;$<2>
,
        sgr0=\E[m\017$<2>smacs=^Nsmso=\E[1;7m$<2>,
        smul=\E[4m$<2>tbc=\E[3guse=ansi+local,

vt100nam|vt100-nam|VT100 no automargins,
        am@, xenl@,
        rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7l\E[?8huse=vt100-am,
vt100-vb|DEC VT100 (w/advanced video) & no beep,
        bel@, flash=\E[?5h$<100/>\E[?5luse=vt100,

# Ordinary VT100 in 132 column ("wide") mode.
vt100-w|vt100-w-am|DEC VT100 132 cols (w/advanced video),
        cols#132lines#24,
        rs2=\E>\E[?3h\E[?4l\E[?5l\E[?8huse=vt100-am,
vt100-w-nam|vt100-nam-w|DEC VT100 132 cols (w/advanced video no automargin),
        cols#132lines#14vt@,
        rs2=\E>\E[?3h\E[?4l\E[?5l\E[?8huse=vt100-nam,

# VT100 with no advanced video.
vt100-nav|VT100 without advanced video option,
        xmc#1,
        blink@, bold@, rev@, rmso=\E[mrmul@, sgr@, sgr0@, smso=\E[7m,
        smul@, use=vt100,
vt100-nav-w|vt100-w-nav|DEC VT100 132 cols 14 lines (no advanced video option),
        cols#132lines#14use=vt100-nav,

# VT100 with one of the 24 lines used as a status line.
# We put the status line on the top.
vt100-s|vt100-s-top|vt100-top-s|VT100 for use with top sysline,
        eslokhs,
        lines#23,
        clear=\E[2;1H\E[J$<50>csr=\E[%i%i%p1%d;%p2%dr,
        cup=\E[%i%p1%{1}%+%d;%p2%dH$<5>dsl=\E7\E[1;24r\E8,
        fsl=\E8home=\E[2;1His2=\E7\E[2;24r\E8,
        tsl=\E7\E[1;%p1%dH\E[1Kuse=vt100-am,

# Status line at bottom.
# Clearing the screen will clobber status line.
vt100-s-bot|vt100-bot-s|VT100 for use with bottom sysline,
        eslokhs,
        lines#23,
        dsl=\E7\E[1;24r\E8fsl=\E8is2=\E[1;23r\E[23;1H,
        tsl=\E7\E[24;%p1%dH\E[1Kuse=vt100-am,

# Most of the `vt100' emulators out there actually emulate a VT102
# This entry (or vt102-nsgr) is probably the right thing to use for
# these.
vt102|DEC VT102,
        dch1=\E[Pdl1=\E[Mil1=\E[Lrmir=\E[4lsmir=\E[4h,
        use=vt100,
vt102-w|DEC VT102 in wide mode,
        cols#132,
        rs3=\E[?3huse=vt102,

# Many brain-dead PC comm programs that pretend to be `vt100-compatible'
# fail to interpret the ^O and ^N escapes properly.  Symptom: the <sgr0>
# string in the canonical vt100 entry above leaves the screen littered
# with little  snowflake or star characters (IBM PC ROM character \017 = ^O)
# after highlight turnoffs.  This entry should fix that, and even leave
# ACS support working, at the cost of making multiple-highlight changes
# slightly more expensive.
# From: Eric S. Raymond <esr@snark.thyrsus.com> July 22 1995
vt102-nsgr|VT102 no sgr (use if you see snowflakes after highlight changes),
        sgr@, sgr0=\E[muse=vt102,

# VT125 Graphics CRT.  Clear screen also erases graphics
# Some VT125's came configured with VT102 support.
vt125|VT125 graphics terminal,
        mir,
        clear=\E[H\E[2J\EPpS(E)\E\\$<50>use=vt100,

# This isn't a DEC entry, it came from University of Wisconsin.
# (vt131: I added <rmam>/<smam> based on the init string, also <OTbs> -- esr)
vt131|DEC VT131,
        OTbs, amxenl,
        cols#80it#8lines#24vt#3,
        bel=^Gblink=\E[5m$<2/>bold=\E[1m$<2/>,
        clear=\E[;H\E[2J$<50/>cr=\rcub1=^Hcud1=\n,
        cuf1=\E[C$<2/>cup=\E[%i%p1%d;%p2%dH$<5/>,
        cuu1=\E[A$<2/>ed=\E[J$<50/>el=\E[K$<3/>home=\E[H,
        ht=^Iis2=\E[1;24r\E[24;1Hkbs=^Hkcub1=\EOD,
        kcud1=\EOBkcuf1=\EOCkcuu1=\EOAkf1=\EOPkf2=\EOQ,
        kf3=\EORkf4=\EOSnel=\r\nrev=\E[7m$<2/>ri=\EM$<5/>,
        rmam=\E[?7hrmkx=\E[?1l\E>rmso=\E[m$<2/>,
        rmul=\E[m$<2/>,
        rs1=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h,
        sgr0=\E[m$<2/>smam=\E[?7hsmkx=\E[?1h\E=,
        smso=\E[7m$<2/>smul=\E[4m$<2/>use=ansi+csr,

# vt132 - like vt100 but slower and has ins/del line and such.
# I'm told that <smir>/<rmir> are backwards in the terminal from the
# manual and from the ANSI standard, this describes the actual
# terminal. I've never actually used a vt132 myself, so this
# is untested.
#
vt132|DEC VT132,
        xenl,
        dch1=\E[P$<7>dl1=\E[M$<99>il1=\E[L$<99>ind=\n$<30>,
        ip=$<7>rmir=\E[4hsmir=\E[4luse=vt100,

# This vt220 description maps F5--F9 to the second block of function keys
# at the top of the keyboard.  The "DO" key is used as F10 to avoid conflict
# with the key marked (ESC) on the vt220.  See vt220d for an alternate mapping.
# PF1--PF4 are used as F1--F4.
#
# added msgr -TD
vt220-old|vt200-old|DEC VT220 in VT100 emulation mode,
        OTbs, OTpt, ammirmsgrxenlxon,
        cols#80lines#24vt#3,
        OTnl=\n,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^Gblink=\E[5m$<2>bold=\E[1m$<2>,
        clear=\E[H\E[2J$<50>cr=\rcub1=^H,
        cup=\E[%i%p1%d;%p2%dH$<10>dch1=\E[Ped=\E[J$<50>,
        el=\E[K$<3>home=\E[Hht=^I,
        if=/usr/share/tabset/vt100ind=\ED$<20/>,
        is2=\E[1;24r\E[24;1Hkf1=\EOPkf10=\E[29~kf2=\EOQ,
        kf3=\EORkf4=\EOSkf5=\E[17~kf6=\E[18~kf7=\E[19~,
        kf8=\E[20~kf9=\E[21~khome=\E[1~kich1=\E[2~,
        rev=\E[7m$<2>rf=/usr/share/tabset/vt100,
        ri=\EM$<14/>rmacs=\E(B$<4>rmam=\E[?7lrmir=\E[4l,
        rmso=\E[27mrmul=\E[24m,
        rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p4%t;5%;%?%p1%p3%|%t;7%;m%?
            %p9%t\E(0%e\E(B%;$<2>
,
        sgr0=\E[m$<2>smacs=\E(0$<2>smam=\E[?7hsmir=\E[4h,
        smso=\E[7msmul=\E[4muse=ansi+arrowsuse=ansi+csr,
        use=ansi+idl1use=ansi+local1use=vt220+pcedit,
        use=vt220+cvis,

# Here's a picture of the Sun/PC editing keypad:
#       +--------+--------+--------+
#       | Insert | Home   | PageUp |
#       +--------+--------+--------+
#       | Delete | End    | PageDn |
#       +--------+--------+--------+
#
# VT220 emulators such as xterm, using PC-keyboards use a different layout than
# the VT220 keyboard:
#       VT220           PC
#       -----           --
#       Prev            PageUp
#       Next            PageDn
#       Insert          Insert
#       Remove          Delete
#       Find            Home
#       Select          End
vt220+pcedit|editing-keypad for VT220 using PC keyboard,
        kdch1=\E[3~kend=\E[4~khome=\E[1~kich1=\E[2~,
        knp=\E[6~kpp=\E[5~,
vt220+vtedit|editing-keypad for VT220 using DEC keyboard,
        kdch1=\E[3~kfnd=\E[1~kich1=\E[2~knp=\E[6~kpp=\E[5~,
        kslt=\E[4~,

# A much better description of the VT200/220; used to be vt220-8
# changed rmacs/smacs from shift-in/shift-out to vt200-old's explicit G0/G1
# designation to accommodate bug in pcvt -TD
#
# Here's a picture of the VT220 editing keypad:
#       +--------+--------+--------+
#       | Find   | Insert | Remove |
#       +--------+--------+--------+
#       | Select | Prev   | Next   |
#       +--------+--------+--------+
#
# Still, this is a "base" entry.  Software emulators commonly leave out the
# DECTCEM feature -TD
vt220-base|DEC VT220 as emulated,
        OTbs, ammirmsgrxenlxon,
        cols#80it#8lines#24vt#3,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^Gblink=\E[5mbold=\E[1mcr=\rcub1=^Hcud1=\n,
        dch=\E[%p1%dPdch1=\E[Pech=\E[%p1%dXel1=\E[1K,
        enacs=\E)0flash=\E[?5h$<200/>\E[?5lht=^Ihts=\EH,
        ich=\E[%p1%d@if=/usr/share/tabset/vt100ind=\ED,
        is2=\E[?7h\E[>\E[?1l\E F\E[?4lkbs=^Hkcub1=\E[D,
        kcud1=\E[Bkcuf1=\E[Ckcuu1=\E[Akf1=\EOPkf10=\E[21~,
        kf11=\E[23~kf12=\E[24~kf13=\E[25~kf14=\E[26~,
        kf17=\E[31~kf18=\E[32~kf19=\E[33~kf2=\EOQ,
        kf20=\E[34~kf3=\EORkf4=\EOSkf6=\E[17~kf7=\E[18~,
        kf8=\E[19~kf9=\E[20~khlp=\E[28~krdo=\E[29~lf1=pf1,
        lf2=pf2lf3=pf3lf4=pf4nel=\EErev=\E[7mri=\EM,
        rmacs=\E(B$<4>rmam=\E[?7lrmir=\E[4lrmso=\E[27m,
        rmul=\E[24mrs1=\E[?3l,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p4%t;5%;%?%p1%p3%|%t;7%;m%?
            %p9%t\E(0%e\E(B%;$<2>
,
        sgr0=\E[m\E(Bsmacs=\E(0$<2>smam=\E[?7hsmir=\E[4h,
        smso=\E[7msmul=\E[4mtbc=\E[3guse=ansi+csr,
        use=ansi+cupuse=ansi+ppuse=ansi+enquse=ansi+erase,
        use=ansi+idluse=ansi+localuse=vt220+vtedit,

vt220|vt200|DEC VT220,
        use=vt220+cvisuse=vt220-base,
vt220-w|vt200-w|DEC VT220 in wide mode,
        cols#132,
        rs3=\E[?3huse=vt220,
vt220-8bit|vt220-8|vt200-8bit|vt200-8|DEC VT220/200 in 8-bit mode,
        OTbs, ammc5imirmsgrxenlxon,
        cols#80it#8lines#24vt#3,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^Gblink=\2335mbold=\2331mclear=\233H\233Jcr=\r,
        csr=\233%i%p1%d;%p2%drcub=\233%p1%dDcub1=^H,
        cud=\233%p1%dBcud1=\ncuf=\233%p1%dCcuf1=\233C,
        cup=\233%i%p1%d;%p2%dHcuu=\233%p1%dAcuu1=\233A,
        dch=\233%p1%dPdch1=\233Pdl=\233%p1%dMdl1=\233M,
        ech=\233%p1%dXed=\233Jel=\233Kel1=\2331Kenacs=\E)0,
        flash=\233?5h$<200/>\233?5lhome=\233Hht=^Ihts=\EH,
        ich=\233%p1%d@if=/usr/share/tabset/vt100,
        il=\233%p1%dLil1=\233Lind=\ED,
        is2=\233?7h\233>\233?1l\E F\233?4lkbs=^H,
        kcub1=\233Dkcud1=\233Bkcuf1=\233Ckcuu1=\233A,
        kdch1=\2333~kf1=\EOPkf10=\23321~kf11=\23323~,
        kf12=\23324~kf13=\23325~kf14=\23326~kf17=\23331~,
        kf18=\23332~kf19=\23333~kf2=\EOQkf20=\23334~,
        kf3=\EORkf4=\EOSkf6=\23317~kf7=\23318~kf8=\23319~,
        kf9=\23320~kfnd=\2331~khlp=\23328~khome=\233H,
        kich1=\2332~knp=\2336~kpp=\2335~krdo=\23329~,
        kslt=\2334~lf1=pf1lf2=pf2lf3=pf3lf4=pf4mc0=\233i,
        mc4=\2334imc5=\2335inel=\EErc=\E8rev=\2337mri=\EM,
        rmacs=\E(Brmam=\233?7lrmir=\2334lrmso=\23327m,
        rmul=\23324mrs1=\233?3lsc=\E7,
        sgr=\2330%?%p6%t;1%;%?%p2%t;4%;%?%p4%t;5%;%?%p1%p3%|%t;7%;m
            %?%p9%t\E(0%e\E(B%;$<2>
,
        sgr0=\2330m\E(Bsmacs=\E(0smam=\233?7hsmir=\2334h,
        smso=\2337msmul=\2334mtbc=\2333guse=vt220+cvis8,

# vt220d:
# This VT220 description regards F6--F10 as the second block of function keys
# at the top of the keyboard.  This mapping follows the description given
# in the VT220 Programmer Reference Manual and agrees with the labeling
# on some terminals that emulate the VT220.  There is no support for an F5.
# See vt220 for an alternate mapping.
#
vt220d|DEC VT220 in VT100 mode with DEC function key labeling,
        kf10=\E[21~kf11=\E[23~kf12=\E[24~kf13=\E[25~,
        kf14=\E[26~kf15=\E[28~kf16=\E[29~kf17=\E[31~,
        kf18=\E[32~kf19=\E[33~kf20=\E[34~kf5@, kf6=\E[17~,
        kf7=\E[18~kf8=\E[19~kf9=\E[20~use=vt220-old,

vt220-nam|v200-nam|VT220 in VT100 mode with no auto margins,
        am@,
        rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7l\E[?8huse=vt220,

# vt220 termcap written Tue Oct 25 20:41:10 1988 by Alex Latzko
# (not an official DEC entry!)
# The problem with real VT220 terminals is they don't send escapes when in
# in VT220 mode.  This can be gotten around two ways.  1> don't send
# escapes or 2> put the VT220 into VT100 mode and use all the nifty
# features of VT100 advanced video which it then has.
#
# This entry takes the view of putting a VT220 into VT100 mode so
# you can use the escape key in emacs and everything else which needs it.
#
# You probably don't want to use this on a VMS machine since VMS will think
# it has a VT220 and will get fouled up coming out of emacs
#
# From: Alexander Latzko <latzko@marsenius.rutgers.edu>, 30 Dec 1996
# (Added vt100 <rc>,<sc> to quiet a tic warning -- esr)
# added msgr -TD
vt200-js|vt220-js|DEC VT200 series with jump scroll,
        ammsgr,
        cols#80,
        bel=^Gcr=\rcub1=^Hcud1=\ncuf1=\E[C,
        cup=\E[%i%p1%d;%p2%dHcuu1=\E[Adch1=\E[Pdl1=\E[M,
        home=\E[Hht=^Iil1=\E[Lind=\ED,
        is2=\E[61"p\E[H\E[?3l\E[?4l\E[?1h\E[?5l\E[?6l\E[?7h\E[?8h\E[
            ?25h\E>\E[m
,
        kbs=^Hkcub1=\EODkcud1=\EOBkcuf1=\EOCkcuu1=\EOA,
        kf1=\EOPkf2=\EOQkf3=\EORkf4=\EOSnel=\r\ED,
        rf=/usr/share/tabset/vt100ri=\EMrmdc=, rmir=\E[4l,
        rmkx=\E[?1l\E>rmso=\E[27m$<5/>rmul=\E[24m,
        rs1=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8hsmdc=,
        smir=\E[4hsmkx=\E[?1h\E=smso=\E[7m$<5/>smul=\E[4m,
        use=ansi+csruse=ansi+eraseuse=vt220+cvis,

# This was DEC's VT320.  Use the purpose-built one below instead
#vt320|DEC VT320 in VT100 emulation mode,
#       use=vt220,

# Use v320n for SCO's LYRIX.  Otherwise, use Adam Thompson's vt320-nam.
#
vt320nam|v320n|DEC VT320 in VT100 emul. mode with NO AUTO WRAP mode,
        am@,
        rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7l\E[?8h,
        use=vt220-base,

# These entries are not DEC's official ones, they were purpose-built for the
# VT320.  Here are the designer's notes:
# <kel> is end on a PC kbd.  Actually 'select' on a VT.  Mapped to
# 'Erase to End of Field'... since nothing seems to use 'end' anyways...
# khome is Home on a PC kbd.  Actually 'FIND' on a VT.
# Things that use <knxt> usually use tab anyways... and things that don't use
# tab usually use <knxt> instead...
# kprv is same as tab - Backtab is useless...
# I left out <sgr> because of its RIDICULOUS complexity,
# and the resulting fact that it causes the termcap translation of the entry
# to SMASH the 1k-barrier...
# From: Adam Thompson <athompso@pangea.ca> Sept 10 1995
# (vt320: uncommented <fsl> --esr)
vt320|vt300|DEC VT320 7 bit terminal,
        ammirmsgrxenl,
        cols#80lines#24wsl#80,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^Gblink=\E[5mbold=\E[1mclear=\E[H\E[2Jcr=\r,
        cub1=^Hcud1=\ncup=\E[%i%p1%d;%p2%dHdch=\E[%p1%dP,
        dch1=\E[Pech=\E[%p1%dXed=\E[Jel=\E[Kel1=\E[1K,
        home=\E[Hht=^Ihts=\EHich=\E[%p1%d@ind=\ED,
        is2=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h\E[1;24r\E[24;1H,
        kbs=^?kdch1=\E[3~kel=\E[4~kf10=\E[21~kf11=\E[23~,
        kf12=\E[24~kf13=\E[25~kf14=\E[26~kf15=\E[28~,
        kf16=\E[29~kf17=\E[31~kf18=\E[32~kf19=\E[33~,
        kf20=\E[34~kf6=\E[17~kf7=\E[18~kf8=\E[19~,
        kf9=\E[20~khome=\E[1~kich1=\E[2~knp=\E[6~knxt=^I,
        kpp=\E[5~kprv=\E[Zkslt=\E[4~nel=\EErev=\E[7m,
        rf=/usr/share/tabset/vt300ri=\EMrmacs=\E(B,
        rmam=\E[?7lrmir=\E[4lrmkx=\E[?1l\E>rmso=\E[m,
        rmul=\E[m,
        rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h\E[1;24r\E[24;1H,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p4%t;5%;%?%p1%p3%|%t;7%;m%?
            %p9%t\E(0%e\E(B%;$<2>
,
        sgr0=\E[m\E(Bsmacs=\E(0smam=\E[?7hsmir=\E[4h,
        smkx=\E[?1h\E=smso=\E[7msmul=\E[4mtbc=\E[3g,
        use=ansi+apparrowsuse=ansi+csruse=ansi+enq,
        use=ansi+idluse=ansi+localuse=dec+ppuse=vt220+cvis,
        use=vt220+keypaduse=dec+sl,

vt320-nam|vt300-nam|DEC VT320 7 bit terminal with no am to make SAS happy,
        am@,
        is2=\E>\E[?3l\E[?4l\E[?5l\E[?7l\E[?8h\E[1;24r\E[24;1H,
        rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7l\E[?8h\E[1;24r\E[24;1Huse=vt320,
# We have to init 132-col mode, not 80-col mode.
vt320-w|vt300-w|DEC VT320 wide 7 bit terminal,
        cols#132wsl#132,
        is2=\E>\E[?3h\E[?4l\E[?5l\E[?7h\E[?8h\E[1;24r\E[24;1H,
        rs2=\E>\E[?3h\E[?4l\E[?5l\E[?7h\E[?8h\E[1;24r\E[24;1Huse=vt320,
vt320-w-nam|vt300-w-nam|DEC VT320 wide 7 bit terminal with no am,
        am@,
        is2=\E>\E[?3h\E[?4l\E[?5l\E[?7l\E[?8h\E[1;24r\E[24;1H,
        rs2=\E>\E[?3h\E[?4l\E[?5l\E[?7l\E[?8h\E[1;24r\E[24;1Huse=vt320-w,

# VT330 and VT340 -- These are ReGIS and SIXEL graphics terminals
#   which are pretty much a superset of the VT320.  They have the
#   host writable status line, yet another different DRCS matrix size,
#   and such, but they add the DEC Technical character set, Multiple text
#   pages, selectable length pages, and the like.  The difference between
#   the VT330 and VT340 is that the former has only 2 planes and a monochrome
#   monitor, the latter has 4 planes and a color monitor.  These terminals
#   support VT131 and ANSI block mode, but as with much of these things,
#   termcap/terminfo doesn't deal with these features.
#
# Note that this entry is are set up in what was the standard way for GNU
# Emacs v18 terminal modes to deal with the cursor keys in that the arrow
# keys were switched into application mode at the same time the numeric pad
# is switched into application mode.  This changes the definitions of the
# arrow keys.  Emacs v19 is smarter and mines its keys directly out of
# your termcap or terminfo entry,
#
# From: Daniel Glasser <dag@persoft.persoft.com>, 13 Oct 1993
# (vt340: string capability "sb=\E[M" corrected to "sr";
# also, added <rmam>/<smam> based on the init string -- esr)
vt340|dec-vt340|vt330|dec-vt330|DEC VT340 graphics terminal with 24 line page,
        ameslokhsmirmsgrxenlxon,
        cols#80it#8lines#24vt#3,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        blink=\E[5mbold=\E[1mcr=\rcub1=^Hcud1=\n,
        cup=\E[%i%p1%d;%p2%dHdch=\E[%p1%dPdch1=\E[P,
        dsl=\E[2$~\r\E[1$}\E[K\E[$},
        flash=\E[?5h$<200/>\E[?5lfsl=\E[$}home=\E[Hht=^I,
        hts=\EHich=\E[%p1%d@ind=\ED,
        is2=\E<\E\sF\E>\E[?1h\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h\E[1;24r
            \E[24;1H
,
        kbs=^Hkcub1=\EODkcud1=\EOBkcuf1=\EOCkcuu1=\EOA,
        kf1=\EOPkf2=\EOQkf3=\EORkf4=\EOSkf6=\E[17~,
        kf7=\E[18~kf8=\E[19~kf9=\E[20~lf1=pf1lf2=pf2,
        lf3=pf3lf4=pf4nel=\r\EDrev=\E[7m,
        rf=/usr/share/tabset/vt300ri=\EMrmacs=\E(B,
        rmam=\E[?7lrmir=\E[4lrmkx=\E[?1l\E>rmso=\E[27m,
        rmul=\E[24mrs1=\E[?3l,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p4%t;5%;%?%p1%p3%|%t;7%;m%?
            %p9%t\E(0%e\E(B%;$<2>
,
        sgr0=\E[m\E(Bsmacs=\E(0smam=\E[?7hsmir=\E[4h,
        smkx=\E[?1h\E=smso=\E[7msmul=\E[4mtbc=\E[3g,
        tsl=\E[2$~\E[1$}\E[1;%dHuse=ansi+csruse=ansi+erase,
        use=ansi+idluse=ansi+localuse=vt220+cvis,

# Left/right margins are supported in xterm since patch #279 (2012/05/10)
vt420+lrmm|VT420 left/right margins,
        mgc=\E[?69lsmglp=\E[?69h\E[%i%p1%ds,
        smglr=\E[?69h\E[%i%p1%d;%p2%ds,
        smgrp=\E[?69h\E[%i;%p1%ds,

# DEC doesn't supply a VT400 description, so we add Daniel Glasser's
# (originally written with VT420 as its primary name, and usable for it).
#
# VT400/420 -- This terminal is a superset of the VT320.  It adds the multiple
#    text pages and long text pages with selectable length of the VT340, along
#    with left and right margins, rectangular area text copy, fill, and erase
#    operations, selected region character attribute change operations,
#    page memory and rectangle checksums, insert/delete column, reception
#    macros, and other features too numerous to remember right now.  TERMCAP
#    can only take advantage of a few of these added features.
#
# Note that this entry is set up in what was the standard way for GNU
# Emacs v18 terminal modes to deal with the cursor keys in that the arrow
# keys were switched into application mode at the same time the numeric pad
# is switched into application mode.  This changes the definitions of the
# arrow keys.  Emacs v19 is smarter and mines its keys directly out of
# your termcap entry,
#
# From: Daniel Glasser <dag@persoft.persoft.com>, 13 Oct 1993
# (vt400: string capability ":sb=\E[M:" corrected to ":sr=\E[M:";
# also, added <rmam>/<smam> based on the init string -- esr)
vt400|vt400-24|dec-vt400|DEC VT400 24x80 column autowrap,
        ameslokmirmsgrxenlxon,
        cols#80it#8lines#24vt#3,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        blink=\E[5mbold=\E[1mclear=\E[H\E[J$<10/>cr=\r,
        cub1=^Hcud1=\ndsl=\E[2$~\r\E[1$}\E[K\E[$},
        ed=\E[J$<10/>el=\E[K$<4/>flash=\E[?5h$<200/>\E[?5l,
        fsl=\E[$}ht=^Ihts=\EHind=\ED,
        is2=\E<\E\sF\E>\E[?1h\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h\E[1;24r
            \E[24;1H
,
        kbs=^Hkcub1=\EODkcud1=\EOBkcuf1=\EOCkcuu1=\EOA,
        kf1=\EOPkf2=\EOQkf3=\EORkf4=\EOSkf6=\E[17~,
        kf7=\E[18~kf8=\E[19~kf9=\E[20~lf1=pf1lf2=pf2,
        lf3=pf3lf4=pf4nel=\r\EDrev=\E[7m,
        rf=/usr/share/tabset/vt300ri=\EMrmacs=\E(B,
        rmam=\E[?7lrmkx=\E[?1l\E>rmso=\E[27mrmul=\E[24m,
        rs1=\E<\E[?3l\E[!p\E[?7h,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p4%t;5%;%?%p1%p3%|%t;7%;m%?
            %p9%t\E(0%e\E(B%;$<2>
,
        sgr0=\E[m\E(Bsmacs=\E(0smam=\E[?7hsmkx=\E[?1h\E=,
        smso=\E[7msmul=\E[4mtbc=\E[3g,
        tsl=\E[2$~\E[1$}\E[1;%dHuse=ansi+csruse=ansi+cup,
        use=ansi+idcuse=ansi+idluse=ansi+localuse=dec+sl,
        use=vt220+cvis,

# (vt420: I removed <kf0>, it collided with <kf10>.  I also restored
# a missing <sc> -- esr)
# add msgr and other capabilities from vt220 -TD
vt420|DEC VT420,
        ammirmsgrxenlxon,
        cols#80it#8lines#24vt#3,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^Gblink=\E[5m$<2>bold=\E[1m$<2>,
        clear=\E[H\E[2J$<50>cr=\rcub1=^Hcud1=\n,
        cup=\E[%i%p1%d;%p2%dH$<10>dch=\E[%p1%dPdch1=\E[P,
        ech=\E[%p1%dXed=\E[J$<50>el=\E[K$<3>el1=\E[1K,
        enacs=\E)0flash=\E[?5h$<200/>\E[?5lhome=\E[Hht=^I,
        hts=\EHich=\E[%p1%d@if=/usr/share/tabset/vt300,
        ind=\EDis2=\E[1;24r\E[24;1His3=\E[?67h\E[64;1"p,
        kbs=^Hkcub1=\E[Dkcud1=\E[Bkcuf1=\E[Ckcuu1=\E[A,
        kf1=\EOPkf10=\E[29~kf2=\EOQkf3=\EORkf4=\EOS,
        kf5=\E[17~kf6=\E[18~kf7=\E[19~kf8=\E[20~kf9=\E[21~,
        nel=\EErev=\E[7m$<2>rf=/usr/share/tabset/vt300,
        ri=\EMrmacs=\E(B$<4>rmam=\E[?7lrmir=\E[4lrmkx=\E>,
        rmsc=\E[?0;0r\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h,
        rmso=\E[27mrmul=\E[24mrs3=\E[?67h\E[64;1"p,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p4%t;5%;%?%p1%p3%|%t;7%;m%?
            %p9%t\E(0%e\E(B%;$<2>
,
        sgr0=\E[m\E(B$<2>smacs=\E(0$<2>smam=\E[?7h,
        smir=\E[4hsmkx=\E=smso=\E[7msmul=\E[4mtbc=\E[3g,
        use=ansi+csruse=ansi+enquse=ansi+idluse=ansi+pp,
        use=ansi+localuse=dec+sluse=vt220+cvis,
        use=vt420+lrmmuse=vt220+vtedit,

# DEC VT220 and up support DECUDK (user-defined keys).  DECUDK (i.e., pfx)
# takes two parameters, the key and the string.  Translating the key is
# straightforward (keys 1-5 are not defined on real terminals, though some
# emulators define these):
#
#               if (key < 16) then  value = key;
#               else if (key < 21) then value = key + 1;
#               else if (key < 25) then value = key + 2;
#               else if (key < 27) then value = key + 3;
#               else if (key < 30) then value = key + 4;
#               else value = key + 5;
#
# The string must be the hexadecimal equivalent, e.g., "5052494E" for "PRINT".
# There's no provision in terminfo for emitting a string in this format, so the
# application has to know it.
#
vt420pc|DEC VT420 w/PC keyboard,
        kdch1=^?kend=\E[4~kf1=\E[11~kf10=\E[21~kf11=\E[23~,
        kf12=\E[24~kf13=\E[11;2~kf14=\E[12;2~kf15=\E[13;2~,
        kf16=\E[14;2~kf17=\E[15;2~kf18=\E[17;2~,
        kf19=\E[18;2~kf2=\E[12~kf20=\E[19;2~kf21=\E[20;2~,
        kf22=\E[21;2~kf23=\E[23;2~kf24=\E[24;2~kf25=\E[23~,
        kf26=\E[24~kf27=\E[25~kf28=\E[26~kf29=\E[28~,
        kf3=\E[13~kf30=\E[29~kf31=\E[31~kf32=\E[32~,
        kf33=\E[33~kf34=\E[34~kf35=\E[35~kf36=\E[36~,
        kf37=\E[23;2~kf38=\E[24;2~kf39=\E[25;2~kf4=\E[14~,
        kf40=\E[26;2~kf41=\E[28;2~kf42=\E[29;2~,
        kf43=\E[31;2~kf44=\E[32;2~kf45=\E[33;2~,
        kf46=\E[34;2~kf47=\E[35;2~kf48=\E[36;2~kf5=\E[15~,
        kf6=\E[17~kf7=\E[18~kf8=\E[19~kf9=\E[20~khome=\E[H,
        pctrm=USR_TERM:vt420pcdos:,
        pfx=\EP1;1|%?%{16}%p1%>%t%{0}%e%{21}%p1%>%t%{1}%e%{25}%p1%>
            %t%{2}%e%{27}%p1%>%t%{3}%e%{30}%p1%>%t%{4}%e%{5}%;%p1%+
            %d/%p2%s\E\\
,
        use=vt420,

vt420pcdos|DEC VT420 w/PC for DOS Merge,
        lines#25,
        dispc=%?%p1%{19}%=%t\E\023\021%e%p1%{32}%<%t\E%p1%c%e%p1
              %{127}%=%t\E\177%e%p1%c%;
,
        pctrm@,
        rmsc=\E[?0;0r\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8hsgr@,
        sgr0=\E[msmsc=\E[?1;2r\E[34huse=vt420pc,

vt420f|DEC VT420 with VT kbd; VT400 mode; F1-F5 used as Fkeys,
        kdch1=^?kf1=\E[11~kf10=\E[21~kf11=\E[23~,
        kf12=\E[24~kf13=\E[25~kf14=\E[26~kf15=\E[28~,
        kf16=\E[29~kf17=\E[31~kf18=\E[32~kf19=\E[33~,
        kf2=\E[12~kf20=\E[34~kf3=\E[13~kf4=\E[14~,
        kf5=\E[15~kf6=\E[17~kf7=\E[18~kf8=\E[19~kf9=\E[20~,
        khome=\E[Hlf1=\EOPlf2=\EOQlf3=\EORlf4=\EOS,
        use=vt420,

vt510|DEC VT510,
        use=vt420,
vt510pc|DEC VT510 w/PC keyboard,
        use=vt420pc,
vt510pcdos|DEC VT510 w/PC for DOS Merge,
        use=vt420pcdos,

# VT520/VT525
#
# The VT520 is a monochrome text terminal capable of managing up to
# four independent sessions in the terminal.  It has multiple ANSI
# emulations (VT520, VT420, VT320, VT220, VT100, VT PCTerm, SCO Console)
# and ASCII emulations (WY160/60, PCTerm, 50/50+, 150/120, TVI 950,
# 925 910+, ADDS A2).  This terminfo data is for the ANSI emulations only.
#
# Terminal Set-Up is entered by pressing [F3], [Caps Lock]/[F3] or
# [Alt]/[Print Screen] depending upon which keyboard and which
# terminal mode is being used.  If Set-Up has been disabled or
# assigned to an unknown key, Set-Up may be entered by pressing
# [F3] as the first key after power up, regardless of keyboard type.
vt520|DEC VT520,
        use=ansi+rcause=vt420use=ansi+tabs,

vt525|DEC VT525,
        use=vt520,

# I just got a brand new Boundless VT520 with that company's "ANSI 2011"
# Keyboard, which replaces the old LK41R-AA keyboard.
#
# In trying to get the function keys to work, I had to cobble my own
# terminfo.src entry, since the existing vt520 entry doesn't include most of
# the function keys.  If I blend the entries for "vt420f" and "vt220+keypad"
# I seem to get them all -Mike Gran
vt520ansi|Boundless VT520 ANSI,
        use=ansi+rcause=vt420fuse=vt220+keypad,
        use=ansi+tabs,

#### VT100 emulations

# John Hawkinson <jhawk@MIT.EDU> tells us that the EWAN telnet for Windows
# (the best Windows telnet as of September 1995) presents the name `dec-vt100'
# to telnetd.   Michael Deutschmann <ldeutsch@mail.netshop.net> informs us
# that this works best with a stock vt100 entry.
dec-vt100|EWAN telnet's vt100 emulation,
        use=vt100,

# From: Adrian Garside <94ajg2@eng.cam.ac.uk>, 19 Nov 1996
dec-vt220|DOS tnvt200 terminal emulator,
        am@, use=vt220,

# Zstem340 is an (IMHO) excellent VT emulator for PC's.  I recommend it to
# anyone who needs PC VT340 emulation. (or anything below that level, for
# that matter -- DEC's ALL-in-1 seems happy with it, as does INFOPLUS's
# RDBM systems, it includes ReGIS and Sixel support!  I'm impressed...
# I can send the address if requested.
# (z340: changed garbled \E[5?l to \E[?5l, DEC smooth scroll off -- esr)
# From: Adam Thompson <athompso@pangea.ca> Sept 10 1995
z340|ZSTEM VT340 terminal emulator 132col 42line,
        lines#42,
        is2=\E>\E[?3h\E[?4l\E[?5l\E[?7h\E[?8h\E[1;42r\E[42;1H,
        rs2=\E>\E[?3h\E[?4l\E[?5l\E[?7h\E[?8h\E[1;42r\E[42;1Huse=vt320-w,
z340-nam|ZSTEM VT340 terminal emulator 132col 42line (no automatic margins),
        am@,
        is2=\E>\E[?3h\E[?4l\E[?5l\E[?7l\E[?8h\E[1;42r\E[42;1H,
        rs2=\E>\E[?3h\E[?4l\E[?5l\E[?7l\E[?8h\E[1;42r\E[42;1Huse=z340,

# expect-5.44.1.15/example/tkterm
# a minimal subset of a VT100 (compare with "news-unk).
#
# The missing "=" in smkx is not a typo (here), but an error in tkterm.
tt|tkterm|Don Libes' tk text widget terminal emulator,
        clear=\E[H\E[Jcr=\rcub1=^Hcud1=\ncuf1=\E[C,
        cup=\E[%p1%d;%p2%dHcuu1=\E[Aind=\nkf1=\EOPkf2=\EOQ,
        kf3=\EORkf4=\EOSkf5=\EOTkf6=\EOUkf7=\EOVkf8=\EOW,
        kf9=\EOXrmkx=\E[?1l\E>rmso=\E[msmkx=\E[?1h\E,
        smso=\E[7m,

######## APPLE

#### Terminal.app

# nsterm*|Apple_Terminal - AppKit Terminal.app
#
# Terminal.app is a Terminal emulator bundled with NeXT's NeXTSTEP and
# OPENSTEP/Mach operating systems, and with Apple's Rhapsody, Mac OS X
# Server and Mac OS X operating systems. There is also a
# "terminal.app" in GNUstep, but I believe it to be an unrelated
# codebase and I have not attempted to describe it here.
#
# For NeXTSTEP, OPENSTEP/Mach, Rhapsody and Mac OS X Server 1.0, you
# are pretty much on your own. Use "nsterm-7-m" and hope for the best.
# You might also try "nsterm-7" and "nsterm-old" if you suspect your
# version supports color.
#
# To determine the version of Terminal.app you're using by running:
#
#     echo "$TERM_PROGRAM" "$TERM_PROGRAM_VERSION"
#
# For Apple_Terminal v309+, use "nsterm-256color" (or "nsterm-bce")
#
# For Apple_Terminal v200+, use "nsterm-16color" (a.k.a. "nsterm")
#
# For Apple_Terminal v71+/v100+, use "nsterm-bce".
#
# For Apple_Terminal v51+, use "nsterm-7-c" or "nsterm-7-c-s".
#
# For Apple_Terminal v41+, use "nsterm-old", or "nsterm-s".
#
# For all earlier versions (Apple_Terminal), try "nsterm-7-m"
# (monochrome) or "nsterm-7" (color); "nsterm-7-m-s" and "nsterm-7-s"
# might work too, but really you're on your own here since these
# systems are very obsolete and I can't test them. I do welcome
# patches, though :).

# Other Terminals:
#
# For GNUstep_Terminal, you're probably best off using "linux" or
# writing your own terminfo.

# For MacTelnet, you're on your own. It's a different codebase, and
# seems to be somewhere between "vt102", "ncsa" and "xterm-color".

# For iTerm.app, see "iterm".

#
# The AppKit Terminal.app descriptions all have names beginning with
# "nsterm". Note that the statusline (-s) versions use the window
# titlebar as a phony status line, and may produce warnings during
# compilation as a result ("tsl uses 0 parameters, expected 1".)
# Ignore these warnings, or even ignore these entries entirely. Apps
# which need to position the cursor or do other fancy stuff inside the
# status line won't work with these entries. They're primarily useful
# for programs like Pine which provide simple notifications in the
# status line. Please note that non-ASCII characters don't work right
# in the status line, since Terminal.app incorrectly interprets their
# Unicode codepoints as MacRoman codepoints (in earlier Mac OS X
# versions) or only accepts status lines consisting entirely of
# characters from the first 256 Unicode positions (including C1 but
# not C0 or DEL.)
#
# The Mythology* of AppKit Terminal.app:
#
# In the days of NeXTSTEP 0.x and 1.x there were two incompatible
# bundled terminal emulators, Shell and Terminal. Scott Hess wrote a
# shareware replacement for Terminal called "Stuart" which NeXT bought
# and used as the basis for the Terminal.app in NeXTSTEP 2+,
# OPENSTEP/Mach, Apple Rhapsody, Mac OS X Server 1.0, and Mac OS X. I
# don't know the TERM_PROGRAM and TERM_PROGRAM_VERSION settings or
# capabilities for the early versions, but I believe that the
# TERM_PROGRAM_VERSION may have been reset at some point.
#
# The early versions were tailored to the NeXT character set. Sometime
# after the Apple acquisition the encoding was switched to MacRoman
# (initially with serious altcharset bugs due to incomplete conversion
# of the old NeXT code,) and then later to UTF-8. Also sometime during
# or just prior to the early days of Mac OS X, the Terminal grew ANSI
# 8-color support (initially buggy when combined with attributes, but
# that was later fixed.) More recently, around Mac OS X version 10.3
# or so (Terminal.app v100+) xterm-like 16-color support was added. In
# some versions (for instance 133-1 which shipped with Mac OS X
# version 10.4) this suffered from the <bce> bug, but that seems to
# have been fixed in Mac OS X version 10.5 (Terminal.app v240.2+).
#
# In the early days of Mac OS X the terminal was fairly buggy and
# would routinely crash under load. Many of these bugs seem to have
# been fixed around Mac OS X version 10.3 (Terminal.app v100+) but
# some may still remain. This change seems to correspond to
# Terminal.app reporting "xterm-color" as $TERM rather than "vt100" as
# it did previously.
#
# * This may correspond with what actually happened, but I don't
#   know. It is based on guesswork, hearsay, private correspondence,
#   my faulty memory, and the following online sources and references:
#
# [1] "Three Scotts and a Duane" by Simson L. Garfinkel
# http://www.nextcomputers.org/NeXTfiles/Articles/NeXTWORLD/93.8/93.8.Dec.Community1.html
#
# [2] NeXTSTEP entry from Wikipedia, the free encyclopedia
https://secure.wikimedia.org/wikipedia/en/wiki/Nextstep
#
# * Renamed the AppKit Terminal.app entry from "Apple_Terminal" to
#   "nsterm" to comply with the name length and case conventions and
#   limitations of various software packages [notably Solaris terminfo
#   and UNIX.] A single Apple_Terminal alias is retained for
#   backwards-compatibility.
#
# * Added function key support (F1-F4). These only work in Terminal.app
#   version 51, hopefully the capabilities won't cause problems for people
#   using version 41.
#
# * Added "full color" (-c) entries which support the 16-color mode in
#   version 51.
#
# * By default, version 51 uses UTF-8 encoding with broken altcharset
#   support, so "ASCII" (-7) entries without altcharset support were
#   added.

# nsterm - AppKit Terminal.app
#
# Apple's Mac OS X includes a Terminal.app derived from the old NeXT
# Terminal.app. It is a partial VT100 emulation with some xterm-like
# extensions. This terminfo was written to describe versions 41
# (shipped with Mac OS X version 10.0) and 51 (shipped with Mac OS X
# version 10.1) of Terminal.app.
#
# Terminal.app runs under the Mac OS X Quartz windowing system (and
# other AppKit-supported windowing systems.)  On the Mac OS X machine I
# use, the executable for Terminal.app is:
# /Applications/Utilities/Terminal.app/Contents/MacOS/Terminal
#
# If you're looking for a description of the full-screen system
# console which runs under Apple's Darwin operating system on PowerPC
# platforms, see the "xnuppc" entry instead.
#
# There were no function keys in version 41. In version 51, there are
# four working function keys (F1, F2, F3 and F4.) The function keys
# are included in all of these entries.
#
# It does not support mouse pointer position reporting. Under some
# circumstances the cursor can be positioned using option-click; this
# works by comparing the cursor position and the selected position,
# and simulating enough cursor-key presses to move the cursor to the
# selected position. This technique fails in all but the simplest
# applications.
#
# It provides partial ANSI color support (background colors interacted
# badly with bold in version 41, though, as reflected in :ncv:.) The
# monochrome (-m) entries are useful if you've disabled color support
# or use a monochrome monitor. The full color (-c) entries are useful
# in version 51, which doesn't exhibit the background color bug. They
# also enable an xterm-compatible 16-color mode.
#
# The configurable titlebar is set using xterm-compatible sequences;
# it is used as a status bar in the statusline (-s) entries. Its width
# depends on font sizes and window sizes, but 50 characters seems to
# be the default for an 80x24 window.
#
# The MacRoman character encoding is used for some of the alternate
# characters in the "MacRoman" entries; the "ASCII" (-7) entries
# disable alternate character set support entirely, and the "VT100"
# (-acs) entries rely instead on Terminal.app's own buggy VT100
# graphics emulation, which seems to think the character encoding is
# the old NeXT charset instead of MacRoman. The "ASCII" (-7) entries
# are useful in Terminal.app version 51, which supports UTF-8 and
# other ASCII-compatible character encodings but does not correctly
# implement VT100 graphics; once VT100 graphics are correctly
# implemented in Terminal.app, the "VT100" (-acs) entries should be
# usable in any ASCII-compatible character encoding [except perhaps
# in UTF-8, where some experts argue for disallowing alternate
# characters entirely.]
#
# Terminal.app reports "vt100" as the terminal type, but exports
# several environment variables which may aid detection in a shell
# profile (i.e. .profile or .login):
#
# TERM=vt100
# TERM_PROGRAM=Apple_Terminal
# TERM_PROGRAM_VERSION=41      # in Terminal.app version 41
# TERM_PROGRAM_VERSION=51      # in Terminal.app version 51
#
# For example, the following Bourne shell script would detect the
# correct terminal type:
#
# if [ :"$TERM" = :"vt100" -a :"$TERM_PROGRAM" = :"Apple_Terminal" ]
# then
#     export TERM
#     if [ :"$TERM_PROGRAM_VERSION" = :41 ]
#     then
#         TERM="nsterm-old"
#     else
#         TERM="nsterm-c-7"
#     fi
# fi
#
# In a C shell derivative, this would be accomplished by:
#
# if ( $?TERM && $?TERM_PROGRAM && $?TERM_PROGRAM_VERSION) then
#     if ( :"$TERM" == :"vt100" && :"$TERM_PROGRAM" == :"Apple_Terminal" ) then
#          if ( :"$TERM_PROGRAM_VERSION" == :41 ) then
#              setenv TERM "nsterm-old"
#          else
#              setenv TERM "nsterm-c-7"
#          endif
#     endif
# endif

# The '+' entries are building blocks
nsterm+7|AppKit Terminal.app v41+ basic capabilities w/ASCII charset,
        ambwmsgrxenlxon,
        cols#80it#8lines#24,
        bel=^Gcr=\rcub1=^Hcud1=\ndim=\E[2mel1=\E[1Kht=^I,
        hts=\EHind=\nkbs=^?kcub1=\EODkcud1=\EOBkcuf1=\EOC,
        kcuu1=\EOAkent=\EOMri=\EMrmam=\E[?7lrmkx=\E[?1l\E>,
        rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;%?
            %p5%t;2%;%?%p7%t;8%;m
,
        sgr0=\E[msmam=\E[?7hsmkx=\E[?1h\E=tbc=\E[3g,
        use=ansi+csruse=ansi+cupuse=ansi+eraseuse=ansi+idl,
        use=ansi+localuse=ansi+sgrbolduse=vt100+enq,
        use=vt100+pfkeys,

nsterm+acs|AppKit Terminal.app v41+ basic capabilities w/VT100 alternate-charset,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;%?
            %p5%t;2%;%?%p7%t;8%;m%?%p9%t\016%e\017%;
,
        sgr0=\E[m\017use=nsterm+7use=vt100+4bsd,

nsterm+mac|AppKit Terminal.app v41+ basic capabilities w/MacRoman alternate-charset,
        acsc=+\335\,\334-\366.\3770#`\327a:f\241g\261h#i
             \360jjkkllmmnno\370p\370q\321rrssttuuvvwwxxy\262z\263{
             \271|\255}\243~\245
,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;%?
            %p5%t;2%;%?%p7%t;8%;m%?%p9%t\016%e\017%;
,
        sgr0=\E[m\017use=nsterm+7use=vt100+4bsd,

# compare with xterm+sl-twm
nsterm+s|AppKit Terminal.app v41+ status-line (window titlebar) support,
        wsl#50use=xterm+sl-twm,

nsterm+c|AppKit Terminal.app v51+ full color support (including 16 colors),
        op=\E[0muse=ibm+16color,

nsterm+c41|AppKit Terminal.app v41 color support,
        ncv#37,
        op=\E[0muse=klone+color,

# These are different combinations of the building blocks

# ASCII charset (-7)
nsterm-m-7|nsterm-7-m|AppKit Terminal.app v41+ w/ASCII charset (monochrome),
        use=nsterm+7,

nsterm-m-s-7|nsterm-7-m-s|AppKit Terminal.app v41+ w/ASCII charset (monochrome w/statusline),
        use=nsterm+suse=nsterm+7,

nsterm-7|AppKit Terminal.app v41+ w/ASCII charset (color),
        use=nsterm+c41use=nsterm+7,

nsterm-7-c|nsterm-c-7|AppKit Terminal.app v51+ w/ASCII charset (full color),
        use=nsterm+cuse=nsterm+7,

nsterm-s-7|nsterm-7-s|AppKit Terminal.app v41+ w/ASCII charset (color w/statusline),
        use=nsterm+suse=nsterm+c41use=nsterm+7,

nsterm-c-s-7|nsterm-7-c-s|AppKit Terminal.app v51+ w/ASCII charset (full color w/statusline),
        use=nsterm+suse=nsterm+cuse=nsterm+7,

# VT100 alternate-charset (-acs)
nsterm-m-acs|nsterm-acs-m|AppKit Terminal.app v41+ w/VT100 alternate-charset (monochrome),
        use=nsterm+acs,

nsterm-m-s-acs|nsterm-acs-m-s|AppKit Terminal.app v41+ w/VT100 alternate-charset (monochrome w/statusline),
        use=nsterm+suse=nsterm+acs,

nsterm-acs|AppKit Terminal.app v41+ w/VT100 alternate-charset (color),
        use=nsterm+c41use=nsterm+acs,

nsterm-c-acs|nsterm-acs-c|AppKit Terminal.app v51+ w/VT100 alternate-charset (full color),
        use=nsterm+cuse=nsterm+acs,

nsterm-s-acs|nsterm-acs-s|AppKit Terminal.app v41+ w/VT100 alternate-charset (color w/statusline),
        use=nsterm+suse=nsterm+c41use=nsterm+acs,

nsterm-c-s-acs|nsterm-acs-c-s|AppKit Terminal.app v51+ w/VT100 alternate-charset (full color w/statusline),
        use=nsterm+suse=nsterm+cuse=nsterm+acs,

# MacRoman charset
nsterm-m|AppKit Terminal.app v41+ w/MacRoman charset (monochrome),
        use=nsterm+mac,

nsterm-m-s|AppKit Terminal.app v41+ w/MacRoman charset (monochrome w/statusline),
        use=nsterm+suse=nsterm+mac,

nsterm-old|AppKit Terminal.app v41+ w/MacRoman charset (color),
        use=nsterm+c41use=nsterm+mac,

nsterm-c|AppKit Terminal.app v51+ w/MacRoman charset (full color),
        use=nsterm+cuse=nsterm+mac,

nsterm-s|AppKit Terminal.app v41+ w/MacRoman charset (color w/statusline),
        use=nsterm+suse=nsterm+c41use=nsterm+mac,

nsterm-c-s|AppKit Terminal.app v51+ w/MacRoman charset (full color w/statusline),
        use=nsterm+suse=nsterm+cuse=nsterm+mac,

# In Mac OS X version 10.5 the format of the preferences has changed
# and a new, more complex technique is needed, e.g.,
#
#       python -c 'import sys,objc;NSUserDefaults=objc.lookUpClass(
#       "NSUserDefaults");ud=NSUserDefaults.alloc();
#       ud.init();prefs=ud.persistentDomainForName_(
#       "com.apple.Terminal");prefs["Window Settings"][
#       prefs["Default Window Settings"]]["TerminalType"
#       ]=sys.argv[1];ud.setPersistentDomain_forName_(prefs,
#       "com.apple.Terminal")' nsterm-16color
#
# and it is still not settable from the preferences dialog. This is
# tracked under rdar://problem/7365108 and rdar://problem/7365134
# in Apple's bug reporter.
#
# In OS X 10.5 (Leopard) the TERM which can be set in the preferences dialog
# defaults to xterm-color.  Alternative selections are ansi, dtterm, rxvt,
# vt52, vt100, vt102 and xterm.
nsterm-16color|AppKit Terminal.app v240.2+ with Mac OS X version 10.5,
        bw@, mirnpc,
        flash=\E[?5h$<200/>\E[?5lhpa=\E[%i%p1%dG,
        kdch1=\E[3~kend=\E[Fkf10=\E[21~kf11=\E[23~,
        kf12=\E[24~kf13=\E[25~kf14=\E[26~kf15=\E[28~,
        kf16=\E[29~kf17=\E[31~kf18=\E[22~kf19=\E[33~,
        kf20=\E[34~kf5=\E[15~kf6=\E[17~kf7=\E[18~,
        kf8=\E[19~kf9=\E[20~khome=\E[Hknp=\E[6~kpp=\E[5~,
        vpa=\E[%i%p1%dd, kLFT5=\E[5D, kRIT5=\E[5Cuse=ansi+idc,
        use=xterm+alt47use=nsterm-c-s-acsuse=vt220+cvis,

# The versions of Terminal.app in Mac OS X version 10.3.x seem to have
# the background color erase feature. The newer version 240.2 in Mac OS X
# version 10.5 does not.
#
# This entry is based on newsgroup comments by Alain Bench, Christian Ebert,
# and D P Schreber comparing to nsterm-c-s-acs.
#
# In Mac OS X version 10.4 and earlier, D P Schreber notes that $TERM
# can be set in Terminal.app, e.g.,
#
#       defaults write com.apple.Terminal TermCapString nsterm-bce
#
# and that it is not set in Terminal's preferences dialog.
#
# Modified for OS X 10.8, omitting bw based on testing with tack -TD
#
# Notes:
# * The terminal description matches the default settings.
# * The keyboard is configurable via a dialog.
# * By default khome, kend, knext and kprev are honored only with a
#   shift-modifier.
# * There are bindings for control left/right arrow (but not up/down).
#   Added those to nsterm-16color, which is the version used for OS X 10.6
# * "Allow VT100 application keypage mode" is by default disabled.
#   There is no way to press keypad-comma unless application mode is enabled
#   and used.
# * 132-column mode stopped working during vttest's tests.  Consider it broken.
# * CHT, REP, SU, SD are buggy.
# * ECH works (also in Leopard), but is not used here for compatibility.
# * The terminal preferences dialog replaces xterm-color by xterm-16color and
#   xterm-256color.  However, it adds "nsterm", so it is possible to use the
#   nsterm entry from this file to override the MacPorts (20110404) or
#   system (20081102) copy of this file.
# + In OS X 10.8 (Mountain Lion) the TERM which can be set in the preferences
#   dialog defaults to xterm-256color.  Alternative selections are ansi,
#   dtterm, rxvt, vt52, vt100, vt102, xterm and xterm-16color.  However,
#   the menu says "Declare terminal as" without promising to actually emulate
#   the corresponding terminals.  Indeed, changing TERM does not affect the
#   emulation itself.  This means that
#   + the function-keys do not match for dtterm for kf1-kf4 as well as
#     khome/kend
#   + the color model is the same for each setting of TERM (does not match
#     ansi or dtterm).
#   + the shift/control/meta key modifiers from rxvt and xterm variants are not
#     recognised except for a few special cases, i.e., kRIT5 and kLFT5.
#   + the VT52 emulation does not give a usable shell because screen-clearing
#     does not work as expected.
#   + selecting "xterm" or "xterm-16color" sets TERM to "xterm-256color".
# + OSX 10.9 (Yosemite) added more extended keys in the default configuration
#   as well as unmasking F10 (which had been used in the window manager). Those
#   keys are listed in this entry.
nsterm-bce|AppKit Terminal.app v71+/v100.1.8+ with Mac OS X version 10.3/10.4 (bce),
        bceuse=nsterm-16color,

# This is tested with OS X 10.8 (Mountain Lion), 2012/08/11
#       TERM_PROGRAM_VERSION=309
# Earlier reports state that these differences also apply to OS X 10.7 (Lion),
#       TERM_PROGRAM_VERSION=303
nsterm-build309|Terminal.app in OS X 10.8,
        use=xterm+256setafuse=nsterm-bce,

# removed bogus kDC7 -TD
nsterm-build326|Terminal.app in OS X 10.9,
        kDC=\E[3;2~kLFT=\E[1;2DkRIT=\E[1;2Ckcbt=\E[Z,
        kf18=\E[32~, kDC5=\E[3;5~, kLFT3=\Eb, kLFT5=\E[1;5D,
        kRIT3=\Ef, kRIT5=\E[1;5Cuse=nsterm-build309,

# actually "343.7"
nsterm-build343|Terminal.app in OS X 10.10,
        kend=\EOFkhome=\EOHuse=nsterm-build326,

# reviewed Terminal.app in El Capitan (version 2.6 build 361) -TD
# Using vttest:
# + no VT52 mode for cursor keys, though VT52 screen works in vttest
# + f1-f4 map to pf1-pf4
# + no VT220 support aside from DECTCEM and ECH
# + there are no protected areas.  Forget about anything above VT220.
# + in ECMA-48 cursor movement, VPR and HPR fail.  Others work.
# + vttest color 11.6.4 and 11.6.5 (bce for ED/EL and ECH/indexing) are bce
# + but bce fails for 11.6.7.2 (test repeat).
# + SD (11.6.7.3) also fails, but SL/SR/SU work.
# + 11.6.6 (test insert/delete char/line with bce) has several failures.
# + normal (not X10 or Highlight tracking) mouse now works.
# + mouse any-event works
# + mouse button-event works
# + in alternate screen:
#   mode 47/48 work
#   mode 1047 fails to restore cursor position (do not use)
#   mode 1049 fails to restore screen contents (do not use)
# + dtterm window-modify operations work (some messages are not printed)
# + dtterm window-report gives size of window in characters/pixels as
#   well as state of window.
# Using tack:
# + there is no difference between cnorm/cvvis
# + has dim/invis/blink (no protect of course)
# + most function keys with shift/control modifiers give beep
#   (user can configure, but out-of-the-box is what I record)
# + shift-F5 is \E[25~ through shift-F12 is \E[34~ (skips \E[30~ between
#   F8 and F9).
# + kLFT5/kRIT5 work, but not up/down with control-modifier
# + kLFT/kRIT work, but not up/down with shift-modifier
# + there are a few predefined bindings with Alt, but no clear pattern.
# + uses alt-key as UTF-8 "meta" something like xterm altSendsEscape
# Using ncurses test-program with xterm-new:
# + no italics
# Using xterm's scripts:
# + palette for 256-colors is hardcoded.
# + no support for "dynamic colors"
# + no support for tcap-query.
nsterm-build361|Terminal.app in OS X 10.11,
        XT,
        kmous=\E[Muse=nsterm-build343,

# reviewed Terminal.app in High Sierra (version 2.8 build 400) -TD
# Comparing with build361, little has changed, except that italics work.
# Direct-color is not supported, by the way.
#
# Improved rmso/rmul -TD
nsterm-build400|Terminal.app in OS X 10.13,
        rmso=\E[27mrmul=\E[24muse=xterm+sm+1006,
        use=ecma+italicsuse=nsterm-build361,

nsterm-build440|Terminal.app in MacOS 11.6.8,
        use=xterm+alt1049use=nsterm-build400,

# This is an alias which should always point to the "current" version
nsterm|nsterm-256color|Apple_Terminal|AppKit Terminal.app,
        use=nsterm-build440,

#### iTerm, iTerm2

# iTerm 0.10
#
# iTerm.app from http://iterm.sourceforge.net/ is an alternative (and more
# featureful) terminal emulator for Mac OS X.  It is similar enough in
# capabilities to nsterm-16color that I have derived this description from that
# one, but as far as I know they share no code.  Many of the features are
# user-configurable, but I attempt only to describe the default configuration
# (B. Sittler).
#
# According to its documentation, iTerm uses terminfo to obtain function key
# definitions.  For example, if it is started with TERM=xterm, it uses key
# definitions from that terminal description from the local OSX machine.  Those
# $TERM settings may be augmented using the bookmark and profile dialogs.
# However, the behavior seen with tack does not agree with either the terminfo
# description or the function keys in its "xterm" profile.
#
# NOTES:
# with vttest:
#       reports primary DA as VT100 with AVO: \E[?1;2c
#       reports secondary DA as "\E[>0;95;c"
#       supports blink and underline
#       displays bold text as red
#       recognizes all dtterm controls for modifying/querying window
#       resizing via escape sequence is very slow
#       supports X11R5 mouse (no X10) and XFree86 mouse (button- and event-tracking)
#       supports X11R5 alternate screen and XFree86 1049 (no 1047/1048)
#       supports CHA, VPA, VPR, but no other ECMA-48 cursor movement such as HPA
# with tack:
#       .
# with ncurses test-program:
#       ncurses 'k' has problem in second screen; light background does not fill
# with xterm scripts
#       can display/alter xterm-256color cube
#       can display/alter xterm-88color cube
iTerm.app|iterm|iTerm.app terminal emulator for Mac OS X,
        bcemirnpcxenlxon,
        wsl#50,
        blink=\E[5mbold=\E[1mcub1=^Hcud1=\n,
        cup=\E[%i%p1%d;%p2%dHel1=\E[1K,
        flash=\E[?5h$<200/>\E[?5lhpa=\E[%i%p1%dG,
        kLFT=\E[1;2DkRIT=\E[1;2Ckbs=^?kcbt=\E[Zkdch1=\E[3~,
        kend=\EOFkf10=\E[21~kf11=\E[23~kf12=\E[24~,
        kf5=\E[15~kf6=\E[17~kf7=\E[18~kf8=\E[19~kf9=\E[20~,
        knp=\E[6~kpp=\E[5~op=\E[0mrev=\E[7mri=\EM,
        rmam=\E[?7lrmkx=\E[?1l\E>rmso=\E[mrmul=\E[m,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;m%?
            %p9%t\016%e\017%;
,
        sgr0=\E[m\017smam=\E[?7hsmkx=\E[?1h\E=smso=\E[7m,
        smul=\E[4mvpa=\E[%i%p1%dd, kEND5=\E[1;5F,
        kHOM5=\E[1;5Huse=ansi+apparrowsuse=ansi+csr,
        use=ansi+enquse=ansi+eraseuse=ansi+idcuse=ansi+idl,
        use=ansi+localuse=vt100+4bsduse=vt100+keypad,
        use=vt100+pfkeysuse=xterm+alt47use=xterm+sl-twm,
        use=xterm+x11mouseuse=xterm+256setafuse=vt220+cvis,

# iTerm2
#
https://iterm2.com/
https://github.com/gnachman/iTerm2
# ~/Library/Preferences/com.googlecode.iterm2.plist
# "iTerm" stalled in 2009.  A different set of developers began "iTerm2".
#
# iTerm2 3.5.0
#
# NOTES:
# with esctest:
#       365 tests passed, 196 known bugs, 2 tests fail intermittently
#       the known bugs include several of the cursor-movement tests 
#       the ED, EL tests include those failing intermittently
#       DECCOLM, DECERA, DECSED, DECSERA and SPA do not work
#       most of the DECRPM, DECRQSS reports fail
# with vttest:
#       reports primary DA as VT420
#       VT420 rectangular operations, as well as DECBI/DEVFI work with margins
#       SRM does not work
#       DECSED, and SPA do not work
#       REP and SD work, SL/SR/SU do not work
# with tack:
#       status-line does not work
#
# The default settings have blinking-text and keypad-application mode disabled.
# Enabling the latter make it half-working (numlock sends an escape character).
# About half of the modified function-keys are untestable due to preassigned
# features.
#
# iTerm2 3.5.0 comes with a 4-year-old copy of xterm's terminfo (June 2020),
# which is modified, using the ncurses TERMINFO_DIRS variable to substitute
# this locally:
# + xterm-nrc and xterm+pcfN are removed
# + the developer made changes to adapt it to the 16-year-old version of
#   ncurses bundled with MacOS, i.e., changing the mouse protocol to the
#   legacy X11 format and reducing the number of colors to 32k (in more than
#   one place).  In the former case, the developer was confused about why that
#   was necessary.  In the latter, the developer clearly misunderstood how the
#   tools work.
# + vt420+lrmm is modified, removing smglr and corrupting mgc (again, developer
#   confusion).
# + the developer added a couple of features, misnaming them as "xterm" blocks:
#   + a copy of kitty+setal renamed to xterm+setulc (and Setulc) is added, but
#     the feature is first mentioned in iTerm2 changes in May 2020, while
#     it is first mention in kitty changes in December 2016.
#   + Smulx is added
#
# iTerm2 3.4.0
#
# NOTES:
# with esctest:
#       293 tests pass, 270 tests fail
# with tack:
#       minor improvements which do not alter the terminfo
#
# iTerm2 3.0.15
#
# NOTES:
# with vttest:
#       reports primary DA as VT100 with AVO: \E[?1;2c
#       reports secondary DA as "\E[>0;95;0c"
#       numeric keypad application mode does not work
#       by default, dtterm window-modifications are ignored
#       by default, dtterm window-reports return, but icon as "L", window as "l"
#       supports SD/SU, no REP, SL, SR
#       supports CBT, CHA, VPA, CNL, CPL, VPR (no HPA, CHT, HPR)
#       no improvement to XFree86 1047/1048 modes
# with tack:
#       in meta-mode, imitates xterm, sending UTF-8
#       special-key modifiers based on xterm use incompatible default for alt/meta
# with ncurses test-program:
#       no italics
#       no improvement to ncurses 'k'
# with xterm scripts:
#       acolors.sh works
#
# Italic text did not work initially, apparently because upgrading did not
# add/change that preference (set in Preferences, Profiles, Text).  A new
# install of iTerm 3.0.15 provides italics by default (blinking text is an
# option in the preferences dialog).
#
# 2018/01/21: found xterm+sm+1006 did not work with version 3.1.5
# 2018/05/19: xterm+sm+1006 seems to work with 3.1.6beta -TD
iTerm2.app|iterm2|terminal emulator for Mac OS X,
        cbt=\E[Zdim=\E[2mkEND=\E[1;2FkHOM=\E[1;2Hka1@, ka3@,
        kb2@, kc1@, kc3@, kent@, kf13=\E[1;2Pkf14=\E[1;2Q,
        kf15=\E[1;2Rkf16=\E[1;2Skf17=\E[15;2~kf18=\E[17;2~,
        kf19=\E[18;2~kf20=\E[19;2~kf21=\E[20;2~,
        kf22=\E[21;2~kf23=\E[23;2~kf24=\E[24;2~,
        kind=\E[1;2Bkri=\E[1;2Anel=\EEop=\E[39;49m,
        rmso=\E[27mrmul=\E[24m,
        rs2=\E[!p\E[?3;4l\E[4l\E>\E[?1000l,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;%?
            %p5%t;2%;m%?%p9%t\016%e\017%;
,
        Smulx=\E[4:%p1%dm, kDN3=\E\E[B, kDN4=\E[1;10B,
        kDN5=\E[1;5B, kDN6=\E[1;6B, kEND3=\E[1;9F,
        kEND4=\E[1;10F, kEND6=\E[1;6F, kEND7=\E[1;13F,
        kEND8=\E[1;14F, kHOM3=\E[1;9H, kHOM4=\E[1;10H,
        kHOM6=\E[1;6H, kHOM7=\E[1;13H, kHOM8=\E[1;14H,
        kLFT3=\E\E[D, kLFT4=\E[1;10D, kLFT5=\E[1;5D,
        kLFT6=\E[1;6D, kNXT3=\E\E[6~, kPRV3=\E\E[5~,
        kRIT3=\E\E[C, kRIT4=\E[1;10C, kRIT5=\E[1;5C,
        kRIT6=\E[1;6C, kUP3=\E\E[A, kUP4=\E[1;10A, kUP5=\E[1;5A,
        kUP6=\E[1;6Ause=ecma+indexuse=xterm+alt+title,
        use=ecma+italicsuse=itermuse=bracketed+paste,
        use=kitty+setal,

# xnuppc - Darwin PowerPC Console (a.k.a. "darwin")
#
# On PowerPC platforms, Apple's Darwin operating system uses a
# full-screen system console derived from a NetBSD framebuffer
# console. It is an ANSI-style terminal, and is not really VT-100
# compatible.
#
# Under Mac OS X, this is the system console driver used while in
# single-user mode [reachable by holding down Command-S during the
# boot process] and when logged in using console mode [reachable by
# typing ">console" at the graphical login prompt.]
#
# If you're looking for a description of the Terminal.app terminal
# emulator which runs under the Mac OS X Quartz windowing system (and
# other AppKit-supported windowing systems,) see the "nsterm"
# entry instead.
#
# NOTE: Under Mac OS X version 10.1, the default login window does not
# prompt for user name, instead requiring an icon to be selected from
# a list of known users. Since the special ">console" login is not in
# this list, you must make one of two changes in the Login Window
# panel of the Login section of System Prefs to make the special
# ">console" login accessible. The first option is to enable 'Show
# "Other User" in list for network users', which will add a special
# "Other..." icon to the graphical login panel. Selecting "Other..."
# will present the regular graphical login prompt. The second option
# is to change the 'Display Login Window as:' setting to 'Name and
# password entry fields', which replaces the login panel with a
# graphical login prompt.
#
# There are no function keys, at least not in Darwin 1.3.
#
# It has no mouse support.
#
# It has full ANSI color support, and color combines correctly with
# all three supported attributes: bold, inverse-video and underline.
# However, bold colored text is almost unreadable (bolding is
# accomplished using shifting and or-ing, and looks smeared) so bold
# has been excluded from the list of color-compatible attributes
# [using (ncv)]. The monochrome entry (-m) is useful if you use a
# monochrome monitor.
#
# There is one serious bug with this terminal emulation's color
# support: repositioning the cursor onto a cell with non-matching
# colors obliterates that cell's contents, replacing it with a blank
# and displaying a colored cursor in the "current" colors. There is
# no complete workaround at present [other than using the monochrome
# (-m) entries,] but removing the (msgr) capability seemed to help.
#
# The "standout" chosen was simple reverse-video, although a colorful
# standout might be more aesthetically pleasing. Similarly, the bold
# chosen is the terminal's own smeared bold, although a simple
# color-change might be more readable. The color-bold (-b) entries
# uses magenta colored text for bolding instead. The fancy color (-f
# and -f2) entries use color for bold, standout and underlined text
# (underlined text is still underlined, though.)
#
# Apparently the terminal emulator does support a VT-100-style
# alternate character set, but all the alternate character set
# positions have been left blank in the font. For this reason, no
# alternate character set capabilities have been included in this
# description. The console driver appears to be ASCII-only, so (enacs)
# has been excluded [although the VT-100 sequence does work.]
#
# The default Mac OS X and Darwin installation reports "vt100" as the
# terminal type, and exports no helpful environment variables. To fix
# this, change the "console" entry in /etc/ttys from "vt100" to
# "xnuppc-WxH", where W and H are the character dimensions of your
# console (see below.)
#
# The font used by the terminal emulator is apparently one originally
# drawn by Ka-Ping Yee, and uses 8x16-pixel characters. This
# file includes descriptions for the following geometries:
#
#     Pixels        Characters   Entry Name (append -m for monochrome)
#    -------------------------------------------------------------------
#     640x400       80x25        xnuppc-80x25
#     640x480       80x30        xnuppc-80x30
#     720x480       90x30        xnuppc-90x30
#     800x600       100x37       xnuppc-100x37
#     896x600       112x37       xnuppc-112x37
#     1024x640      128x40       xnuppc-128x40
#     1024x768      128x48       xnuppc-128x48
#     1152x768      144x48       xnuppc-144x48
#     1280x1024     160x64       xnuppc-160x64
#     1600x1024     200x64       xnuppc-200x64
#     1600x1200     200x75       xnuppc-200x75
#     2048x1536     256x96       xnuppc-256x96
#
# The basic "xnuppc" entry includes no size information, and the
# emulator includes no reporting capability, so you'll be at the mercy
# of the TTY device (which reports incorrectly on my hardware.) The
# color-bold entries do not include size information.

# The '+' entries are building blocks
xnuppc+basic|Darwin PowerPC console basic capabilities,
        ambcemirxenl, NQ,
        it#8,
        bold=\E[1mcr=\rcuf1=\E[Ccup=\E[%i%p1%d;%p2%dH,
        dsl=\E]2;\007el1=\E[1Khome=\E[Hht=^Ihts=\EHind=\n,
        kbs=^?kcub1=\EODkcud1=\EOBkcuf1=\EOCkcuu1=\EOA,
        rev=\E[7mri=\EMrmam=\E[?7lrmkx=\E[?1l\E>,
        rs2=\E>\E[?3l\E[?4l\E[?5l\E[?7h\E[?8h,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;m,
        sgr0=\E[msmam=\E[?7hsmkx=\E[?1h\E=tbc=\E[3g,
        use=ansi+csruse=ansi+eraseuse=ansi+local,
        use=ansi+sgrsouse=ansi+sgruluse=vt100+keypad,

xnuppc+c|Darwin PowerPC console ANSI color support,
        ncv#32use=klone+color,

xnuppc+b|Darwin PowerPC console color-bold support,
        ncv#32,
        bold=\E[35m,
        sgr=\E[0%?%p6%t;35%;%?%p2%t;4%;%?%p1%p3%|%t;7%;m,
        use=xnuppc+basic,

xnuppc+f|Darwin PowerPC console fancy color support,
        ncv#35,
        sgr=\E[0%?%p6%t;35%;%?%p2%t;36;4%;%?%p1%t;33;44%;%?%p3%t;7%;
            m
,
        smso=\E[33;44msmul=\E[36;4muse=xnuppc+b,

xnuppc+f2|Darwin PowerPC console alternate fancy color support,
        ncv#35,
        bold=\E[33m,
        sgr=\E[0%?%p6%t;33%;%?%p2%t;34%;%?%p1%t;31;47%;%?%p3%t;7%;m,
        smso=\E[31;47msmul=\E[34muse=xnuppc+basic,

# Building blocks for specific screen sizes
xnuppc+80x25|Darwin PowerPC console 80x25 support (640x400 pixels),
        cols#80lines#25,

xnuppc+80x30|Darwin PowerPC console 80x30 support (640x480 pixels),
        cols#80lines#30,

xnuppc+90x30|Darwin PowerPC console 90x30 support (720x480 pixels),
        cols#90lines#30,

xnuppc+100x37|Darwin PowerPC console 100x37 support (800x600 pixels),
        cols#100lines#37,

xnuppc+112x37|Darwin PowerPC console 112x37 support (896x600 pixels),
        cols#112lines#37,

xnuppc+128x40|Darwin PowerPC console 128x40 support (1024x640 pixels),
        cols#128lines#40,

xnuppc+128x48|Darwin PowerPC console 128x48 support (1024x768 pixels),
        cols#128lines#48,

xnuppc+144x48|Darwin PowerPC console 144x48 support (1152x768 pixels),
        cols#144lines#48,

xnuppc+160x64|Darwin PowerPC console 160x64 support (1280x1024 pixels),
        cols#160lines#64,

xnuppc+200x64|Darwin PowerPC console 200x64 support (1600x1024 pixels),
        cols#200lines#64,

xnuppc+200x75|Darwin PowerPC console 200x75 support (1600x1200 pixels),
        cols#200lines#75,

xnuppc+256x96|Darwin PowerPC console 256x96 support (2048x1536 pixels),
        cols#0x100lines#96,

# These are different combinations of the building blocks

xnuppc-m|darwin-m|Darwin PowerPC console (monochrome),
        use=xnuppc+basic,

xnuppc|darwin|Darwin PowerPC console (color),
        use=xnuppc+cuse=xnuppc+basic,

xnuppc-m-b|darwin-m-b|Darwin PowerPC console (monochrome w/color-bold),
        use=xnuppc+b,

xnuppc-b|darwin-b|Darwin PowerPC console (color w/color-bold),
        use=xnuppc+buse=xnuppc+c,

xnuppc-m-f|darwin-m-f|Darwin PowerPC console (fancy monochrome),
        use=xnuppc+f,

xnuppc-f|darwin-f|Darwin PowerPC console (fancy color),
        use=xnuppc+fuse=xnuppc+c,

xnuppc-m-f2|darwin-m-f2|Darwin PowerPC console (alternate fancy monochrome),
        use=xnuppc+f2,

xnuppc-f2|darwin-f2|Darwin PowerPC console (alternate fancy color),
        use=xnuppc+f2use=xnuppc+c,

# Combinations for specific screen sizes
xnuppc-80x25-m|darwin-80x25-m|Darwin PowerPC console (monochrome) 80x25,
        use=xnuppc+80x25use=xnuppc+basic,

xnuppc-80x25|darwin-80x25|Darwin PowerPC console (color) 80x25,
        use=xnuppc+cuse=xnuppc+80x25use=xnuppc+basic,

xnuppc-80x30-m|darwin-80x30-m|Darwin PowerPC console (monochrome) 80x30,
        use=xnuppc+80x30use=xnuppc+basic,

xnuppc-80x30|darwin-80x30|Darwin PowerPC console (color) 80x30,
        use=xnuppc+cuse=xnuppc+80x30use=xnuppc+basic,

xnuppc-90x30-m|darwin-90x30-m|Darwin PowerPC console (monochrome) 90x30,
        use=xnuppc+90x30use=xnuppc+basic,

xnuppc-90x30|darwin-90x30|Darwin PowerPC console (color) 90x30,
        use=xnuppc+cuse=xnuppc+90x30use=xnuppc+basic,

xnuppc-100x37-m|darwin-100x37-m|Darwin PowerPC console (monochrome) 100x37,
        use=xnuppc+100x37use=xnuppc+basic,

xnuppc-100x37|darwin-100x37|Darwin PowerPC console (color) 100x37,
        use=xnuppc+cuse=xnuppc+100x37use=xnuppc+basic,

xnuppc-112x37-m|darwin-112x37-m|Darwin PowerPC console (monochrome) 112x37,
        use=xnuppc+112x37use=xnuppc+basic,

xnuppc-112x37|darwin-112x37|Darwin PowerPC console (color) 112x37,
        use=xnuppc+cuse=xnuppc+112x37use=xnuppc+basic,

xnuppc-128x40-m|darwin-128x40-m|Darwin PowerPC console (monochrome) 128x40,
        use=xnuppc+128x40use=xnuppc+basic,

xnuppc-128x40|darwin-128x40|Darwin PowerPC console (color) 128x40,
        use=xnuppc+cuse=xnuppc+128x40use=xnuppc+basic,

xnuppc-128x48-m|darwin-128x48-m|Darwin PowerPC console (monochrome) 128x48,
        use=xnuppc+128x48use=xnuppc+basic,

xnuppc-128x48|darwin-128x48|Darwin PowerPC console (color) 128x48,
        use=xnuppc+cuse=xnuppc+128x48use=xnuppc+basic,

xnuppc-144x48-m|darwin-144x48-m|Darwin PowerPC console (monochrome) 144x48,
        use=xnuppc+144x48use=xnuppc+basic,

xnuppc-144x48|darwin-144x48|Darwin PowerPC console (color) 144x48,
        use=xnuppc+cuse=xnuppc+144x48use=xnuppc+basic,

xnuppc-160x64-m|darwin-160x64-m|Darwin PowerPC console (monochrome) 160x64,
        use=xnuppc+160x64use=xnuppc+basic,

xnuppc-160x64|darwin-160x64|Darwin PowerPC console (color) 160x64,
        use=xnuppc+cuse=xnuppc+160x64use=xnuppc+basic,

xnuppc-200x64-m|darwin-200x64-m|Darwin PowerPC console (monochrome) 200x64,
        use=xnuppc+200x64use=xnuppc+basic,

xnuppc-200x64|darwin-200x64|Darwin PowerPC console (color) 200x64,
        use=xnuppc+cuse=xnuppc+200x64use=xnuppc+basic,

xnuppc-200x75-m|darwin-200x75-m|Darwin PowerPC console (monochrome) 200x75,
        use=xnuppc+200x75use=xnuppc+basic,

xnuppc-200x75|darwin-200x75|Darwin PowerPC console (color) 200x75,
        use=xnuppc+cuse=xnuppc+200x75use=xnuppc+basic,

xnuppc-256x96-m|darwin-256x96-m|Darwin PowerPC console (monochrome) 256x96,
        use=xnuppc+256x96use=xnuppc+basic,

xnuppc-256x96|darwin-256x96|Darwin PowerPC console (color) 256x96,
        use=xnuppc+cuse=xnuppc+256x96use=xnuppc+basic,

######## DOS/WINDOWS
# CRT is shareware.  It implements some xterm features, including mouse.
crt|crt-vt220|CRT 2.3 emulating VT220,
        bce,
        ncv@, use=vt100+enquse=vt220-baseuse=ecma+color,

# SecureCRT 8.7.3.2279
# 8.7.3 was released 2020/08/11
# (eval 2021/02/05)
# VanDyke Software, Inc.
#
# Advertised features:
#       Xterm 24-bit color
#       Xterm 256-color
#       Double-size characters
#       Xterm extensions for mouse support and changing title bar
#       Emulates VT100, VT102, VT220, VT320, Linux console, SCO ANSI,
#       TN3270, TVI910, TVI925, Wyse 50/60, and ANSI.
# Changes:
#       Added ANSI sc/rc and REP in 2019/12/17
#       Added TVI910/ TVI925 in 2019/11/20      
#
# Default:
#       Emulate "Xterm", using "ANSI with 256color"
#       TERM=xterm-256color
#
# vttest:
#       DA1 \E[?62;1;2;6;7;8;9c (vt220 with DRCS and NRCS)
#       DA2 \E[>1;136;0c
#       double-sized characters do not work
#       Menu-1 fails (window resizes to 132-columns, but does not repaint)
#       NRCS fails (tried French, but none of the replacements worked)
#       VT100 line-drawing works, except the C/R, etc., are an hline.
#       VT52 works except for S8C1T bug.
#       RIS hangs the terminal.
#       Local SRM does not echo.
#       Some of the VT320/VT220 status reports work, not locator or DECXCPR
#       DECUDK works if I press shift.
#       Fails CHT, CNL, CPL
#       Does not honor bce with ECH
#       ERM/SPA does not work
#       REP has 11 +'s except for final 2 +'s, like PuTTY.
#       Fails SL/SR
#       DECRPM does not respond.
#       dtterm modify/report operations do not work
#       Alternate screen works.
#       Mouse:
#               highlight tracking does not work.
#               any event tracking does not work, but
#               button event tracking does work.
#               DEC locator does not work.
#               SGR coordinates does not work.
# ncurses:
#       reset6 does reset to 80-columns
#       ncurses RGB edit does not work.
#       direct colors don't work, probably needs semicolons.
# tack:
#       blink works, but not dim or invis
#       no italics or crossed-out
# scripts:
#       256color handles "-r" option (but test/ncurses menu d does not alter)
#       dynamic colors queries do not work, though it seems some can be set.
#       resize.pl gets no reply, resize.sh needs fix for no reply.
scrt|securecrt|SecureCRT emulating xterm-256color,
        bce@, km@, npc,
        bel@, cvvis@, kcbt=\E[Zuse=vt220+pcedit,
        use=xterm+256setafuse=ecma+indexuse=ansi+rep,
        use=xterm+keypaduse=xterm+pcfkeysuse=xterm-basic,

# Absolute Telnet
# (eval 2021/02/20)
# 11.24 was released 2020/08/13
# Celestial Software
#
# Advertised features:
#       Emacs compatibility mode (Meta Keys can be enabled for left/right ALT)
#       Double-size characters
#       Xterm extensions for mouse support
#       Emulates VT52, VT100, VT220, VT320, ansi, xterm, qnx, scoansi,
#       ANSIBBS, WYSE60, TeleVideo 950.
#
# Default:
#       TERM=xterm
#
# vttest:
#       DA1: \E[?62;1;2;6;7;8;9;15;22c (VT200 with DRCS, UDK, NRCS) 
#       DA2: \E[>1;10;0c 
#       However:
#       + NRCS tests do not work
#       + DECUDK test fails
#       + VT100 double-sized characters work
#       menu-1 autowrap does not work
#       supports blinking text
#       VT220 DECSCA last screen (ignoring ECH, etc), leaves fill on top/left
#       VT220 device status reports fail, except operating status
#       8-bit controls work
#       xterm alternate screen recognized, but cursor restored incorrectly
#       xterm mouse (normal, any event, button event) works
#       xterm highlight-mouse does not work properly, confused with any-event
#       does not recognize SGR-mouse mode
#       supports xterm window-modifiny/reporting controls
#       supports ECMA-48 cursor movement except HPR
#       supports REP and SD, but not ECMA-48 SL, SR, SU
# tack:
#       italics and crossed-out do not work
#       supports xterm-style modified function-keys, using X11R6 F1-F4.
#       does not support modified cursor-keys or editing-keys
#       uses VT220-style Home/End
#       if alt-keys are enabled,
#               meta-mode sends escape rather than shifting, in 7-bit mode
#               meta-mode does the expected shifting in 8-bit mode
# scripts:
#       supports 256-colors, including changing palette (ncurses menu d works)
#       supports UTF-8, but honors VT100 line-drawing
absolute|Absolute Telnet emulating xterm,
        kcbt=\E[Zuse=ecma+indexuse=linux+kbsuse=ansi+rep,
        use=vt220+pcedituse=xterm+keypaduse=xterm+app,
        use=xterm+pcf0use=xterm+256coloruse=xterm+x11mouse,
        use=xterm-basic,

#### PuTTY
http://www.chiark.greenend.org.uk/~sgtatham/putty/
#
# PuTTY 0.78 (September 2020, tested 12 August 2023)
# Testing with tack:
#       implements cross-out text (shortly after 0.74)
#       restore kLFT as kLFT5, etc. (mentioned in October 2021)
#       does not support direct-colors (mentioned in July 2021)
#
# PuTTY 0.74 (27 June 2020)
#       (unchanged)
#
# PuTTY 0.73 (September 2019)
# Testing with tack:
#       does not implement italics
#       does not implement cross-out text
#       its settings dialog allows some of the VT100 line-drawing tests to pass
#       (not the padding test, though)
# Testing with vttest:
#       xterm mouse modes are incomplete: X10, highlight, any-event, and focus in/out modes are not implemented.
#       does not implement protected areas
#       does not implement SL/SR
#
# PuTTY 0.71 (March 2019) provided a workable "rep" capability.  It also
# changed longstanding keypad assignments, so that these no longer apply:
#       kLFT=\E[D, kRIT=\E[C, kb2=\E[G,
#
# PuTTY recognized xterm's 1006 mouse mode in late 2015; subsequent release was
# in 2017 (0.70) -TD
#
# Comparing with 0.51, vttest is much better (only a few problems with the
# cursor position reports and wrapping).
#
# PuTTY 0.51 (14 December 2000)
#
# This emulates VT100 + VT52 (plus a few VT220 features:  ech, SRM, DECTCEM, as
# well as SCO and Atari, color palettes from Linux console).  Reading the code,
# it is intended to be VT102 plus selected features.  By default, it sets $TERM
# to xterm, which is incorrect, since several features are misimplemented:
#
#       Alt+key always sends ESC+key, so 'km' capability is removed.
#
#       Control responses, wrapping and tabs are buggy, failing a couple of
#       screens in vttest.
#
#       xterm mouse support is not implemented (unreleased version may).
#
# Several features such as backspace/delete are optional; this entry documents
# the default behavior.  None of the combinations of keyboard settings match
# those used for xterm -TD
#
# PuTTY recognizes xterm's 1049 mode for switching to/from alternate screen,
# but implements it incorrectly as mentioned here:
#       http://stackoverflow.com/questions/24613237/terminal-retains-bg-color-after-closing-vim-using-color-scheme-and-putty-256co/37869114#37869114
putty|PuTTY terminal emulator,
        ambcebwcccmirmsgrxenlxon, XT,
        it#8ncv#22, U8#1,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^Gcr=\rcub1=^Hcud1=\EDcup=\E[%i%p1%d;%p2%dH,
        cuu1=\EMdch=\E[%p1%dPdch1=\E[P,
        dispc=%?%p1%{8}%=%t\E%%G\342\227\230\E%%@%e%p1%{10}%=%t\E%%G
              \342\227\231\E%%@%e%p1%{12}%=%t\E%%G\342\231\0\E%%@%e
              %p1%{13}%=%t\E%%G\342\231\252\E%%@%e%p1%{14}%=%t\E%%G
              \342\231\253\E%%@%e%p1%{15}%=%t\E%%G\342\230\274\E%%@
              %e%p1%{27}%=%t\E%%G\342\206\220\E%%@%e%p1%{155}%=%t\E
              %%G\340\202\242\E%%@%e%p1%c%;
,
        ech=\E[%p1%dXel1=\E[1Kenacs=\E(B\E)0,
        flash=\E[?5h$<100/>\E[?5lhome=\E[Hhpa=\E[%i%p1%dG,
        ind=\n,
        initc=\E]P%p1%x%p2%{255}%*%{1000}%/%02x%p3%{255}%*%{1000}%/
              %02x%p4%{255}%*%{1000}%/%02x
,
        is2=\E7\E[r\E[m\E[?7h\E[?1;4;6l\E[4l\E8\E>\E]R,
        kbs=^?kcbt=\E[Zkhome=\E[1~kind=\E[Bkri=\E[Akspd=^Z,
        nel=\r\noc=\E]Rop=\E[39;49mri=\EMrmacs=^O,
        rmam=\E[?7lrmir=\E[4lrmkx=\E[?1l\E>rmso=\E[27m,
        rmul=\E[24m,
        rs2=\E<\E["p\E[50;6"p\Ec\E[?3l\E]R\E[?1000l,
        s0ds=\E[10ms1ds=\E[11ms2ds=\E[12m,
        sgr=\E[0%?%p1%p6%|%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5
            %;m%?%p9%t\016%e\017%;
,
        sgr0=\E[m\017smacs=^Nsmam=\E[?7hsmir=\E[4h,
        smkx=\E[?1h\E=vpa=\E[%i%p1%dd, E3=\E[3J,
        use=ansi+apparrowsuse=ansi+csruse=ansi+erase,
        use=ansi+idluse=ansi+localuse=ansi+tabs,
        use=ansi+repuse=bracketed+pasteuse=ecma+index,
        use=ecma+strikeoutuse=klone+coloruse=klone+sgr,
        use=putty+cursoruse=putty+fnkeysuse=vt220+pcedit,
        use=xterm+alt1049use=vt102+enquse=xterm+sm+1006,
        use=xterm+sluse=vt100+fnkeysuse=putty+keypad,
        use=vt220+cvis,

# older versions (e.g., before 0.71) of PuTTY used a shift-modifier to toggle
# between normal- and application-mode for the cursor-keys.  That was dropped,
# and a few years later (after 0.74) restored as the control-modifier.
putty+cursor|PuTTY modified cursor-keys,
        kDN5=\E[B, kLFT5=\E[D, kRIT5=\E[C, kUP5=\E[A,
putty+keypad|PuTTY numeric keypad,
        kp1=\EOq, kp2=\EOr, kp3=\EOs, kp4=\EOt, kp5=\EOu, kp6=\EOv,
        kp7=\EOw, kp8=\EOx, kp9=\EOy, kpADD=\EOl, kpDIV=\EOQ,
        kpDOT=\EOn, kpMUL=\EOR, kpNUM=\EOP, kpSUB=\EOS, kpZRO=\EOp,

vt100-putty|Reset PuTTY to pure VT100,
        rs2=\E<\E["p\Ec\E[?3l\E]R\E[40"p\E[61"p\E[50;1;2"p,
        use=vt100,
putty-256color|PuTTY 0.58 with xterm 256-colors,
        use=xterm+256setafuse=putty,
putty-noapp|putty with cursor keys in normal mode,
        kLFT=\EODkRIT=\EOCkcub1=\E[Dkcud1=\E[Bkcuf1=\E[C,
        kcuu1=\E[Akind=\EOBkri=\EOArmkx=\E>smkx=\E=,
        use=putty,

# One of the keyboard selections is "VT100+".
# pterm (the X11 port) uses shifted F1-F10 as F11-F20
putty-vt100|VT100+ keyboard layout,
        use=putty+fnkeys+vt100use=putty,

putty-sco|putty with SCO function keys,
        use=putty+fnkeys+scouse=putty,

# PuTTY has more than one section in its Keyboard configuration:
# a) backspace/delete, which we ignore since that choice largely depends on
#    whether one matches Unix and BSD or Linux.
# b) home/end keys, also ignored because the "rxvt" setting sends keys which
#    are unrelated to rxvt's actual settings.
# c) function keys and keypad - this is the interesting part.  None of the
#    selections match any of their respective namesakes, but they are shown
#    here to help users who expect that the selections do what is implied.
#
# This is the default setting for PuTTY
putty+fnkeys|fn-keys for PuTTY,
        use=putty+fnkeys+esc,

putty+fnkeys+esc|ESC[n~ fn-keys for PuTTY,
        kf1=\E[11~kf10=\E[21~kf11=\E[23~kf12=\E[24~,
        kf13=\E[25~kf14=\E[26~kf15=\E[28~kf16=\E[29~,
        kf17=\E[31~kf18=\E[32~kf19=\E[33~kf2=\E[12~,
        kf20=\E[34~kf3=\E[13~kf4=\E[14~kf5=\E[15~,
        kf6=\E[17~kf7=\E[18~kf8=\E[19~kf9=\E[20~,

putty+fnkeys+linux|Linux fn-keys for PuTTY,
        kf1=\E[[Akf2=\E[[Bkf3=\E[[Ckf4=\E[[Dkf5=\E[[E,
        use=putty+fnkeys+esc,

putty+fnkeys+xterm|Xterm R6 fn-keys for PuTTY,
        kf1=\EOPkf2=\EOQkf3=\EORkf4=\EOS,
        use=putty+fnkeys+esc,

putty+fnkeys+vt400|VT400 fn-keys for PuTTY,
        use=putty+fnkeys+esc,

# Shifted F1 is F11.  F13-F20 inherit from the defaults, and the last distinct
# key is F20.
putty+fnkeys+vt100|VT100+ fn-keys for PuTTY,
        kf1=\EOPkf10=\EOYkf11=\EOZkf12=\EO[kf2=\EOQ,
        kf3=\EORkf4=\EOSkf5=\EOTkf6=\EOUkf7=\EOVkf8=\EOW,
        kf9=\EOXuse=putty+fnkeys+esc,

# Unlike xterm-sco, this leaves kmous ambiguous with kf1.
#
# Use modifiers to obtain function keys past 12:
# F1-F12 - normal
# F13-F24 - shift
# F25-F36 - control/alt
# F37-F48 - control/shift
#
putty+fnkeys+sco|SCO fn-keys for PuTTY,
        kbeg=\E[Ekcub1=\E[Dkcud1=\E[Bkcuf1=\E[Ckcuu1=\E[A,
        kdch1=^?kend=\E[Fkf1=\E[Mkf10=\E[Vkf11=\E[W,
        kf12=\E[Xkf13=\E[Ykf14=\E[Zkf15=\E[akf16=\E[b,
        kf17=\E[ckf18=\E[dkf19=\E[ekf2=\E[Nkf20=\E[f,
        kf21=\E[gkf22=\E[hkf23=\E[ikf24=\E[jkf25=\E[k,
        kf26=\E[lkf27=\E[mkf28=\E[nkf29=\E[okf3=\E[O,
        kf30=\E[pkf31=\E[qkf32=\E[rkf33=\E[skf34=\E[t,
        kf35=\E[ukf36=\E[vkf37=\E[wkf38=\E[xkf39=\E[y,
        kf4=\E[Pkf40=\E[zkf41=\E[@kf42=\E[[kf43=\E[\\,
        kf44=\E[]kf45=\E[\^kf46=\E[_kf47=\E[`kf48=\E[{,
        kf5=\E[Qkf6=\E[Rkf7=\E[Skf8=\E[Tkf9=\E[Ukhome=\E[H,
        kich1=\E[Lknp=\E[Gkpp=\E[I,

#### mintty
https://github.com/mintty/mintty
#
# Originally a fork (and reduction) of PuTTY, this has grown from 15ksloc in
# 2013 to 41ksloc in 2020.  That is still smaller than PuTTY (160ksloc), but
# larger than rxvt (31ksloc) and slightly smaller than rxvt-unicode (42ksloc).
#
# Version 3.0 responds to DA as a VT400, however it does not implement the
# application keypad.  The assignment of cursor-keys versus modifiers differs
# from xterm (alt-left and alt-right send modifier 7, i.e., alt+control).
#
# Thomas Wolff suggested these extensions:
#       blink2   turn on rapid blinking
#       blink0   turn off blinking
#       norm     turn off bold and half-bright mode
#       opaq     turn off blank mode
#       smul2    begin double underline mode
#       smol     begin overline mode
#       rmol     exit overline mode
#       Font0    use default font
#       Font1    use alternative font 1
#       ...
#       Font10   use alternative font 10
#       setal    set (under)line color
#       ol       set default (under)line color
#       overs    overstrike (print characters over each other)
#
# but see vte-2018 (use Smol/Rmol rather than smol/rmol).
mintty|Cygwin Terminal,
        setal=\E[5%p1%dmuse=xterm+256color,
        use=mintty+common,
mintty-direct|Cygwin Terminal direct-color,
        use=kitty+setaluse=xterm+directuse=mintty+common,
mintty+common|shared capabilities for mintty,
        km@, npc,
        kcbt=\E[Zkent=\EOMrmm@, rmpch=\E[10m,
        rs1=\Ec\E]104\007rshm=\E[22mrsubm=\E[75m,
        rsupm=\E[75msmm@, smpch=\E[11msshm=\E[1:2m,
        ssubm=\E[74mssupm=\E[73m, Rmol=\E[55m, Smol=\E[53m,
        Smulx=\E[4:%p1%dm, blink2=\E[6m, norm=\E[22m,
        opaq=\E[28m, smul2=\E[21muse=linux+kbsuse=ansi+rep,
        use=ecma+strikeoutuse=ecma+indexuse=vt420+lrmm,
        use=xterm+focususe=xterm+sm+1006use=xterm+pcfkeys,
        use=xterm+tmuxuse=ecma+italicsuse=xterm-basic,
        use=bracketed+pasteuse=report+version,
# 2019-06-09: These capabilities are commented-out for compatibility with
# existing releases 5.9-6.1, and may be considered for inclusion after the
# release of ncurses 6.2:
#       Font0=\E[10m,
#       Font1=\E[11m,
#       Font2=\E[12m,
#       Font3=\E[13m,
#       Font4=\E[14m,
#       Font5=\E[15m,
#       Font6=\E[16m,
#       Font7=\E[17m,
#       Font8=\E[18m,
#       Font9=\E[19m,
#       Font10=\E[20m,
#       blink0=\E[25m,
#       ol=\E[59m,
#       overs=\E[8\:7m,

#### TeraTerm

# This entry is for Tera Term Pro version 2.3, for MS-Windows 95/NT written by
# T. Teranishi dated Mar 10, 1998.  It is a free software terminal emulator
# (communication program) which supports:
#
#       - Serial port connections.
#       - TCP/IP (telnet) connections.
#       - VT100 emulation, and selected VT200/300 emulation.
#       - TEK4010 emulation.
#       - File transfer protocols (Kermit, XMODEM, ZMODEM, B-PLUS and
#         Quick-VAN).
#       - Scripts using the "Tera Term Language".
#       - Japanese and Russian character sets.
#
# The program does not come with terminfo or termcap entries.  However, the
# emulation (testing with vttest and ncurses) is reasonably close to VT100 (no
# VT52 or doublesize character support; blinking is done with color).  Besides
# the HPA, VPA extensions it also implements CPL and CNL.
#
# All of the function keys can be remapped.  This description shows the default
# mapping, as installed.  Both VT100 PF1-PF4 keys and quasi-vt220 F1-F4 keys
# are supported.  F13-F20 are obtained by shifting F3-F10.  The editing keypad
# is laid out like VT220, rather than the face codes on the PC keyboard, i.e,
#       kfnd    Insert
#       kslt    Delete
#       kich1   Home
#       kdch1   PageUp
#       kpp     End
#       knp     PageDown
#
# ANSI colors are implemented, but cannot be combined with video attributes
# except for reverse.
#
# No fonts are supplied with the program, so the acsc string is chosen to
# correspond with the default Microsoft terminal font.
#
# Tera Term recognizes some xterm sequences, including those for setting and
# retrieving the window title, and for setting the window size (i.e., using
# "resize -s"), though it does not pass SIGWINCH to the application if the
# user resizes the window with the mouse.
teraterm2.3|Tera Term Pro 2.3,
        km,
        ncv#43vt@,
        acsc=+\020\,\021-\030.^Y0\333`\004a\261f\370g\361h\260i
             \316j\331k\277l\332m\300n\305o~p\304q\304r\304s_t\303u
             \264v\301w\302x\263y\363z\362{\343|\330}\234~\376
,
        blink=\E[5mbold=\E[1mclear=\E[H\E[Jcuf1=\E[C,
        cup=\E[%i%p1%d;%p2%dHcuu1=\E[Adch=\E[%p1%dP,
        dch1=\E[Pech=\E[%p1%dXed=\E[Jel=\E[Kel1=\E[1K,
        flash=\E[?5h$<200/>\E[?5lhpa=\E[%i%p1%dGkf1=\E[11~,
        kf10=\E[21~kf11=\E[23~kf12=\E[24~kf13=\E[25~,
        kf14=\E[26~kf15=\E[28~kf16=\E[29~kf17=\E[31~,
        kf18=\E[32~kf19=\E[33~kf2=\E[12~kf20=\E[34~,
        kf3=\E[13~kf4=\E[14~kf5=\E[15~kf6=\E[17~kf7=\E[18~,
        kf8=\E[19~kf9=\E[20~op=\E[100mrev=\E[7mri=\EM,
        rmso=\E[27mrmul=\E[24msgr0=\E[0m\017smso=\E[7m,
        smul=\E[4mvpa=\E[%i%p1%dduse=ansi+idl,
        use=vt220+vtedituse=vt100+enquse=klone+color,
        use=vt100use=vt220+cvis,

# Version 4.59 has regular VT100 line-drawing (so it is no longer necessary
# to choose a Windows OEM font).
#
# Testing with tack:
#       - it does not have xenl (suppress that)
#       - underline seems to work with color (modify ncv).
# Testing with vttest:
#       - wrapping differs from VT100 (menu 1).
#       - it recognizes xterm's X10 and normal mouse tracking, but none of the
#         other flavors.
#       - it recognizes the dtterm window controls for reporting size in
#         characters and pixels.
#       - it passes SIGWINCH.
teraterm4.59|Tera Term Pro 4.59,
        bcexenl@,
        ncv#41,
        acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        kmous=\E[Muse=teraterm2.3,

# Version 4.97
#
# Testing with tack:
#       - no bell (flash works)
#       - bold is yellow, blink is red.
#       - default keyboard sends ^? for Delete, can be configured for kdch1
#       - no meta mode
# Testing with vttest:
#       + autowrap has problems...
#       + color-tests for bce feature match xterm's behavior
#       + handles most of xterm's mouse-controls other than highlight-tracking.
#         xterm's SGR 1006 works.
#       + partial support for DEC locator-events
#       + implements ECMA-48 SD/SU, but not REP, SL/SR.
#       + has a "Tek" window, but does not work with vttest's examples
#       + supports the dtterm window modify/report controls
#       + responds to DECRQM and DECRQSS controls, but not consistent with DSR
#         e.g., for VT220
#       + VT220 screen-display tests are ok
#       + no VT52 support
# Other tests:
#       + recognizes xterm's original direct-colors sequences, but result is
#         poor.
#       + no UTF-8 apparent when UTF-8 is set, with font Lucida Control
teraterm4.97|Tera Term Pro 4.97,
        XT, use=ecma+coloruse=xterm+sm+1006use=teraterm4.59,
teraterm-256color|TeraTerm with xterm 256-colors,
        use=xterm+256setafuse=teraterm,

teraterm|Tera Term,
        use=teraterm4.97,

#### Command prompt

# Tested with WinNT 4.0, the telnet application assumes the screensize is
# 25x80.  This entry uses the 'Terminal' font, to get line-drawing characters.
#
# Other notes:
# a) Fails tack's cup (cursor-addressing) test, though cup works well enough
#    for casual (occasional) use.  Also fails several of the vttest screens,
#    but that is not unusual for VT100 "emulators".
# b) Does not implement VT100 keypad
# c) Recognizes a subset of VT52 controls.
ms-vt100|MS telnet imitating DEC VT100,
        lines#25,
        acsc=+\020\,\021-\030.^Y0\333`\004a\261f\370g\361h\260i
             \316j\331k\277l\332m\300n\305o~p\304q\304r\304s_t\303u
             \264v\301w\302x\263y\363z\362{\343|\330}\234~\376
,
        ka1@, ka3@, kb2@, kc1@, kc3@, kent@, kf0@, kf1@, kf10@, kf2@, kf3@, kf4@,
        kf5@, kf6@, kf7@, kf8@, kf9@, tbc@, use=vt102+enquse=vt100,

# Tested with Windows 2000, the telnet application runs in a console window,
# also using 'Terminal' font.
#
# Other notes:
# a) This version has no function keys or numeric keypad.  Unlike the older
#    version, the numeric keypad is entirely ignored.
# b) The program sets $TERM to "ansi", which of course is inaccurate.
ms-vt100-color|vtnt|windows 2000 ANSI (sic),
        bce,
        dch=\E[%p1%dPich=\E[%p1%d@use=ecma+color,
        use=ms-vt100,

# Based on comments from Federico Bianchi:
#
#       vt100+ is basically a VT102-noSGR with ANSI.SYS colors and a different
#       scheme for PF keys.
#
# and PuTTY wishlist:
#
#       The modifiers are represented as the codes listed above, prefixed to
#       the normal sequences.  If the modifier is pressed alone, its sequence
#       is transmitted twice in succession.  If multiple modifiers apply,
#       they're transmitted in the order shift, control, alt.
#
#       Shift   \E^S
#       Alt     \E^A,
#       Ctrl    \E^C,
ms-vt100+|vt100+|windows XP VT100+ (sic),
        kdch1=\E-kend=\Ekkf1=\E1kf10=\E0kf11=\E!kf12=\E@,
        kf13=\E\023\E1kf14=\E\023\E2kf15=\E\023\E3,
        kf16=\E\023\E4kf17=\E\023\E5kf18=\E\023\E6,
        kf19=\E\023\E7kf2=\E2kf20=\E\023\E8kf21=\E\023\E9,
        kf22=\E\023\E0kf23=\E\023\E!kf24=\E\023\E@,
        kf25=\E\003\E1kf26=\E\003\E2kf27=\E\003\E3,
        kf28=\E\003\E4kf29=\E\003\E5kf3=\E3kf30=\E\003\E6,
        kf31=\E\003\E7kf32=\E\003\E8kf33=\E\003\E9,
        kf34=\E\003\E0kf35=\E\003\E!kf36=\E\003\E@,
        kf37=\E\001\E1kf38=\E\001\E2kf39=\E\001\E3kf4=\E4,
        kf40=\E\001\E4kf41=\E\001\E5kf42=\E\001\E6,
        kf43=\E\001\E7kf44=\E\001\E8kf45=\E\001\E9,
        kf46=\E\001\E0kf47=\E\001\E!kf48=\E\001\E@kf5=\E5,
        kf6=\E6kf7=\E7kf8=\E8kf9=\E9khome=\Ehkich1=\E+,
        knp=\E/kpp=\E?use=ms-vt100-color,

ms-vt-utf8|vt-utf8|UTF-8 flavor of VT100+,
        use=ms-vt100+,

# VT-UTF-8 and VT100+ Protocols
https://learn.microsoft.com/en-us/openspecs/windows_protocols/ms-vuvp/969416c0-ccd6-4a75-a9b3-597d7713845b
#
# This Microsoft "protocol" adapted the aixterm 16-color feature from xterm's
# documentation in 2015, as seen in successive revisions:
#
# 2013/07/22 has 8 colors
# 2015/10/16 has 16 colors using SGR 90-97, 100-107 as well as SGR 24 and 27,
#            adds "informative" reference to xterm's ctlseqs
#
# The cnorm/civis definitions added in 2015 are unrelated to any standard.
ms-vt100-16color|VT-UTF-8 and VT100+,
        civis=\E[?hcnorm=\E[?lrmso=\E[27mrmul=\E[24m,
        use=ibm+16coloruse=ms-vt100+,

# Based on
https://docs.microsoft.com/en-us/windows/console/console-virtual-terminal-sequences
# We use this scheme to map function keys
#       terminfo        modifier        code    keys
#       kf13-kf24       shift           2       F1 to F12
#       kf25-kf36       alt             3       F1 to F12
#       kf37-kf48       control         4       F1 to F12
#       kf49-kf60       ctrl-alt        7       F1 to F12
#
# Unclear: smam and rmam implemented?
# Unclear: rmkx, smkx, rmir, smir - irrelevant?
#
# TD:
# +     According to tack, tbc and cbt fail.
# +     The line-drawing (acsc) does not work in telnet or ssh.  I added the
#       U8 extension to tell ncurses to use UTF-8 for line-drawing (when the
#       locale uses UTF-8).  That won't work for telnet (which uses ASCII),
#       but seems to work for OpenSSH's ssh.  I set the codepage to 65001,
#       of course.
# +     Function keys... do not work consistently in telnet and ssh.  With
#       telnet, kf1-kf4 are \EOP to \EOS, and kf5-kf12 match the terminfo.
#       But with ssh, it's entirely different (reminds me of rxvt).
winconsole|Windows 10 new console,
        amkmmirmsgrxenl,
        ncv@, U8#1,
        acsc=++\,\,--..00``aaffgghhiijjkkllmmnnooppqqrrssttuuvvwwxxy
             yzz~~
,
        bel=^Gblink@, cr=\rech=\E[%p1%dXel1=\E[0Kich1@, ind=\n,
        invis@, is1=\E[!pkf13=\E[11;2~kf14=\E[12;2~,
        kf15=\E[13;2~kf16=\E[14;2~kf17=\E[15;2~,
        kf18=\E[17;2~kf19=\E[18;2~kf20=\E[19;2~,
        kf21=\E[20;2~kf22=\E[21;2~kf23=\E[24;2~,
        kf24=\E[25;2~kf25=\E[11;3~kf26=\E[12;3~,
        kf27=\E[13;3~kf28=\E[14;3~kf29=\E[15;3~,
        kf30=\E[17;3~kf31=\E[18;3~kf32=\E[19;3~,
        kf33=\E[20;3~kf34=\E[21;3~kf35=\E[24;3~,
        kf36=\E[25;3~kf37=\E[11;4~kf38=\E[12;4~,
        kf39=\E[13;4~kf40=\E[14;4~kf41=\E[15;4~,
        kf42=\E[17;4~kf43=\E[18;4~kf44=\E[19;4~,
        kf45=\E[20;4~kf46=\E[21;4~kf47=\E[24;4~,
        kf48=\E[25;4~kf49=\E[11;7~kf50=\E[12;7~,
        kf51=\E[13;7~kf52=\E[14;7~kf53=\E[15;7~,
        kf54=\E[17;7~kf55=\E[18;7~kf56=\E[19;7~,
        kf57=\E[20;7~kf58=\E[21;7~kf59=\E[24;7~,
        kf60=\E[25;7~khome=\E[1~nel=\r\nri=\E[Trmacs=\E(B,
        rmir@, rmpch@, rs1=\E[!p,
        sgr=\E[0%?%p1%p6%|%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;m%?%p9%t
            \E(0%e\E(B%;
,
        sgr0=\E[0m\E(Bsmacs=\E(0smir@, smpch@, use=ansi+arrows,
        use=ansi+csruse=ansi+cupuse=ansi+eraseuse=ansi+idc,
        use=ansi+idluse=ecma+indexuse=ansi+inittabs,
        use=ansi+localuse=ecma+sgruse=ecma+color,
        use=vt220+cvisuse=vt220+pcedituse=xterm+nopcfkeys,

# Windows Terminal (Preview)
https://github.com/microsoft/terminal
#
# Windows 10 22H2 (also Windows 11)
# Version 1.16.10261.0
#
# - Windows Terminal #1553: "Feature Request:  Mouse/Touch/Pointer Bindings
#   (like middle-click paste, right-click context menu, etc.)", compare to
#   https://learn.microsoft.com/en-us/windows/console/mouse-event-record-str
#   This appears to be related to a problem with its implementation of the
#   Console API; the mouse does not work in a "Command Window" (e.g., as used
#   in the ncurses MinGW driver), although escape sequences work.
#
# Windows 10 21H1
# Version 1.9.1942.0
#
# This has longstanding issues with CR/LF mapping, e.g.,
# - first reported by Juergen Pfeifer August 13, 2020, with workaround
# - Windows Terminal #8303 "Updates to ms-terminal terminal type in terminfo to
#   1.4 from 0.2"
# - Windows Terminal #6733 "Midnight Commander (mc) output is screwed when
#   using the 'ms-terminal' as $TERM"
#
# still seen in testing during May-July 2021.  As a workaround, this terminal
# description sets cud1 to an escape sequence rather than just \r.
#
# Using TERM=xterm-256color shows a number of problems.
# A few are seen only in the WSL2 environment.
#
# tack:
# - flash does not work.
# - video attribute blink does not work.
# - video attribute invis does not work in WSL2.
# - italics sitm/ritm do not work in WSL2.
# - crossed-out smxx/rmxx do not work in WSL2.
# - reloading colors via initp interchanges red/blue.
# - does not implement OSC 104, which is used for resetting colors in xterm.
# - does not support numeric keypad application mode.
# - control-modifier (without alt/shift) does not work for special keys.
# - meta-key sends escape character rather than acting as a meta key.
#
# vttest:
# - identifies itself as a VT100.
# - cursor movement (menu 1) does not work properly, e.g., for wrapping.
# - does not support 8-bit controls.
# - does not support VT420 rectangles.
# - does not support VT420 left/right margins.
# - ECMA-48 cursor-movement works.
# - does not support X10 mouse, or mouse highlight tracking.
# - SGR mouse mode 1006 works.
# - any-event mouse mode shows no focus-in/focus-out events.
# - alternate screen 47/48 modes do not work, nor do 1047/1048.
# - alternate screen 1049 mode works.
# - none of the window report/modify operations work.
# - none of the DECRPM/DECRQM reporting operations work.
#
# xterm:
# - 256colors2.pl -r, -i and -q options work.
# - dynamic colors do not work.
# - paste64.pl does not work, i.e., bracketed-paste.
# - tcapquery.pl does not work.
#
# Windows 10 1903
# Version 0.2.1831.0
#
# The task manager shows this as "OpenConsole.exe", which differs
# from the "Windows Command Processor" used for the command-prompt.
#
# The settings dialog does not work (unless the end user expects to open
# profiles.json in Visual Studio).  There is no documentation, of course.
#
# Testing via an ssh connection, using openssh:
# - the program sets TERM to cygwin if the tab is set to PowerShell,
#   and to xterm-256color if "Legacy".  However, in the latter, more tests
#   fail in vttest, which does not pay attention to TERM.
# vttest:
# - menu 1 (tests for cursor movement) misbehaves like command-prompt
# - primary DA says this is a vanilla VT100
# - does not flush response to primary DA, leaving a ^M on the end when
#   the PowerShell tab is used.  Both the "Legacy" tab and the command-prompt
#   work properly in this test.
# - in the generic VT100 tests, there are problems with character sets
#   (diamond shows as a double-width character, DEL as two replacement-chars).
# - outside of the generic VT100 tests, the program does poorly because most
#   of the features are missing.
# - ECH does not work properly
# - a few generic xterm features are supported (set window title), but
#   others are missing (such as the mouse).
# - the cursor visible/invisible works in the PowerShell tab, not in "Legacy"
# tack:
# - blink, dim, bold, invis, protect do not work
# - bce works (but per vttest, with ED, EL, not ECH)
# - does not support keypad application mode
# - implements most of the xterm modified keys; sometimes modifiers are ignored
#   or simply incorrect
# - sends escape+key rather than implementing meta mode
# other:
# - color palette can be altered, but OSC 104 for resetting does not work
# - crashed with a script used for testing NRCS.
# - does not recognize either xterm+direct or xterm+indirect escapes.
ms-terminal|Windows10 terminal,
        npc,
        cud1=\E[Bkcbt=\E[Zrmkx=\E[?1lrmm@, smkx=\E[?1hsmm@,
        Cr@, Ms@, use=linux+kbsuse=xterm+256color,
        use=xterm+pcfkeysuse=ansi+repuse=xterm+sm+1006,
        use=ecma+indexuse=ecma+italicsuse=ecma+strikeout,
        use=xterm-basicuse=xterm+tmux,

#### Visual Studio
# Visual Studio Code 1.45.0 uses xterm.js 12.8.1 (see https://xtermjs.org/).
#
# vttest:
# - fixes menu 1 problem with wrapping
# - supports DECALN
# - fixes menu 8 problem with delete-character
# - REP, SL/SL work
# - keypad application mode still does not work; PF1-PF4 are not assigned.
# - DECRQM/DECRPM do not work
# - xterm mouse features:
#   - SGR coordinates work; the other modes do not (see vscode #96058)
#   - focus-events are not sent
#   - mouse highlight tracking does not send button event
# tack/other:
# - little or no change since previous review
#
# Visual Studio Code 1.35.1 uses xterm.js (see https://xtermjs.org/).
https://code.visualstudio.com/docs/editor/integrated-terminal
#
# This sets TERM to xterm-256color, which is a little more successful than
# Windows Terminal.
#
# vttest:
# - menu 1 (cursor movement) has problems with wrapping
# - claims to be a VT100 with AVO, but copies xterm #276's secondary response
# - menu 8 (insert/delete char/line) has problem with delete-character
# - like Windows Terminal, fails the ECH test: neither supports DECALN
#   However, the bce test with ECH works.
# - does not support keypad application mode
# - supports most xterm mode controls (except DEC Locator Events)
# - REP, SL/SL do not work, but SD/SU work.
# - the alternate-screen tests fail because it does not support DECALN
# - window modify/report is not supported
# - supports some VT320 presentation reports
# tack:
# - does not support blinking text
# - implements most of the xterm modified keys, with some exceptions:
#   - pageup/pagedown do not send escapes
#   - alt cursor left/right send escape-b and escape-f
# - sends UTF-8 like xterm for meta mode
# other:
# - mouse mode is not reset by reset-sequence
# - supports italics and dim, but not cross-out or double-underline
# - color-palette cannot be changed
vscode|xterm.js|Visual Studio Code terminal using xterm.js,
        npc,
        kcbt=\E[Zrmkx=\E[?1lsmkx=\E[?1huse=linux+kbs,
        use=xterm+256setafuse=ecma+indexuse=xterm+focus,
        use=xterm+sm+1006use=xterm+pcfkeysuse=ecma+italics,
        use=xterm-basicuse=bracketed+paste,
vscode-direct|Visual Studio Code with direct-colors,
        use=xterm+indirectuse=vscode,

######## X TERMINAL EMULATORS
#### XTERM
#
# You can add the following line to your .Xdefaults to change the terminal type
# set by the xterms you start up to my-xterm:
#
# *termName:  my-xterm
#
# System administrators can change the default entry for xterm instances
# by adding a similar line to /usr/X11/lib/X11/app-defaults/XTerm.  In either
# case, xterm will detect and reject an invalid terminal type, falling back
# to the default of xterm.
#

# X10/6.6       11/7/86, minus alternate screen, plus (csr)
# (xterm: ":MT:" changed to ":km:"; added <smam>/<rmam> based on init string;
# removed (hs, eslok, tsl=\E[?E\E[?%i%dT, fsl=\E[?F, dsl=\E[?E)
# as these seem not to work -- esr)
x10term|vs100-x10|xterm terminal emulator (X10 window system),
        OTbs, amkmmirmsgrxenlxon,
        cols#80it#8lines#65,
        bold=\E[1mclear=\E[H\E[2Jcsr=\E[%i%p1%d;%p2%dr,
        cub1=^Hcud1=\ncuf1=\E[Ccup=\E[%i%p1%d;%p2%dH,
        cuu1=\E[Adch=\E[%p1%dPdch1=\E[Ped=\E[Jel=\E[K,
        home=\E[Hht=^Iind=\nis2=\E\E[m\E[?7h\E[?1;4lkbs=^H,
        kcub1=\EODkcud1=\EOBkcuf1=\EOCkcuu1=\EOAkf1=\EOP,
        kf2=\EOQkf3=\EORkf4=\EOSrev=\E[7mri=\EMrmam=\E[?7l,
        rmir=\E[4lrmkx=\E[?1l\E>rmso=\E[mrmul=\E[m,
        sgr0=\E[msmam=\E[?7hsmir=\E[4hsmkx=\E[?1h\E=,
        smso=\E[7msmul=\E[4muse=ansi+idl,

# csl is extension which clears the status line
x10term+sl|status-line for X10 xterm,
        eslokhs,
        dsl=\E[?Hfsl=\E[?Ftsl=\E[?E\E[?%i%p1%dT, csl=\E[?E,

# Compatible with the R5 xterm
# (from the XFree86 3.2 distribution, <blink=@> removed)
# added khome/kend, rmir/smir, rmul/smul, hts based on the R5 xterm code - TD
# corrected typos in rs2 string - TD
# added u6-u9 -TD
xterm-r5|xterm R5 version,
        OTbs, amkmmsgrxenl,
        cols#80it#8lines#24,
        bel=^Gbold=\E[1mclear=\E[H\E[2Jcr=\rcub1=^Hcud1=\n,
        cup=\E[%i%p1%d;%p2%dHed=\E[Jel=\E[Khome=\E[Hht=^I,
        hts=\EHind=\nkdl1=\E[31~kel=\E[8~kf0=\EOq,
        kf1=\E[11~kf10=\E[21~kf11=\E[23~kf12=\E[24~,
        kf2=\E[12~kf3=\E[13~kf4=\E[14~kf5=\E[15~kf6=\E[17~,
        kf7=\E[18~kf8=\E[19~kf9=\E[20~khome=\E[1~,
        kil1=\E[30~kmous=\E[Mrev=\E[7mri=\EMrmkx=\E[?1l\E>,
        rmso=\E[mrmul=\E[m,
        rs2=\E>\E[?1;3;4;5;6l\E[4l\E[?7h\E[m\E[r\E[2J\E[H,
        sgr=\E[%?%p1%t;7%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p6%t;1
            %;m
,
        sgr0=\E[msmkx=\E[?1h\E=smso=\E[7msmul=\E[4m,
        tbc=\E[3guse=xterm+kbsuse=ansi+apparrows,
        use=ansi+csruse=ansi+idcuse=ansi+idluse=ansi+local,
        use=vt220+pcedituse=vt100+enq,

# Compatible with the R6 xterm
# (from XFree86 3.2 distribution, <acsc> and <it> added, <blink@> removed)
# added khome/kend, hts based on the R6 xterm code - TD
# (khome/kend do not actually work in X11R5 or X11R6, but many people use this
# for compatibility with other emulators).
xterm-r6|xterm X11R6 version,
        OTbs, amkmmirmsgrxenl,
        cols#80it#8lines#24,
        acsc=``aaffggiijjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^Gbold=\E[1mclear=\E[H\E[2Jcr=\rcub1=^Hcud1=\n,
        cup=\E[%i%p1%d;%p2%dHcuu1=\E[Adch=\E[%p1%dP,
        dch1=\E[Ped=\E[Jel=\E[Kenacs=\E)0home=\E[Hht=^I,
        hts=\EHind=\n,
        is2=\E[m\E[?7h\E[4l\E>\E7\E[r\E[?1;3;4;6l\E8,
        kcub1=\EODkcud1=\EOBkcuf1=\EOCkcuu1=\EOAkf1=\E[11~,
        kf10=\E[21~kf11=\E[23~kf12=\E[24~kf13=\E[25~,
        kf14=\E[26~kf15=\E[28~kf16=\E[29~kf17=\E[31~,
        kf18=\E[32~kf19=\E[33~kf2=\E[12~kf20=\E[34~,
        kf3=\E[13~kf4=\E[14~kf5=\E[15~kf6=\E[17~kf7=\E[18~,
        kf8=\E[19~kf9=\E[20~kmous=\E[M, meml=\El, memu=\Em,
        rev=\E[7mri=\EMrmacs=^Ormir=\E[4lrmkx=\E[?1l\E>,
        rs2=\E[m\E[?7h\E[4l\E>\E7\E[r\E[?1;3;4;6l\E8,
        sgr0=\E[msmacs=^Nsmir=\E[4hsmkx=\E[?1h\E=tbc=\E[3g,
        use=xterm+alt47use=ansi+csruse=ansi+idl,
        use=ansi+localuse=ansi+sgrsouse=ansi+sgrul,
        use=vt220+vtedituse=xterm+kbsuse=vt100+enq,

xterm-old|antique xterm version,
        use=xterm-r6,
# The monochrome version began as a copy of "xtermm" (from Solaris), and was
# initially part of the xterm sources (in XFree86).  But "xterm" continued to
# grow, while "xterm-mono" had none of the newer features.  Additionally,
# inheriting from "xtermm" runs into several problems, including different
# function keys as well as the fact that the mouse support is not compatible.
# This entry restores the original intent, intentionally not an alias to
# simplify maintenance -TD
xterm-mono|monochrome xterm,
        use=xterm-r6,
# This is the base xterm entry for the xterm supplied with XFree86 3.2 & up.
# The name has been changed and some aliases have been removed.
xterm-xf86-v32|xterm terminal emulator (XFree86 3.2 Window System),
        OTbs, ambcekmmirmsgrxenl, XT,
        cols#80lines#24ncv@,
        acsc=``aaffggiijjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^Gbold=\E[1mclear=\E[H\E[2Jcr=\rcub1=^Hcud1=\n,
        cup=\E[%i%p1%d;%p2%dHech=\E[%p1%dXed=\E[Jel=\E[K,
        el1=\E[1Kenacs=\E(B\E)0flash=\E[?5h$<100/>\E[?5l,
        home=\E[Hhpa=\E[%i%p1%dGind=\n,
        is2=\E7\E[r\E[m\E[?7h\E[?1;3;4;6l\E[4l\E8\E>,
        kbeg=\EOEkbs=^?kdch1=^?kend=\EOFkf1=\E[11~,
        kf10=\E[21~kf11=\E[23~kf12=\E[24~kf13=\E[25~,
        kf14=\E[26~kf15=\E[28~kf16=\E[29~kf17=\E[31~,
        kf18=\E[32~kf19=\E[33~kf2=\E[12~kf20=\E[34~,
        kf3=\E[13~kf4=\E[14~kf5=\E[15~kf6=\E[17~kf7=\E[18~,
        kf8=\E[19~kf9=\E[20~kfnd=\E[1~kmous=\E[Mkslt=\E[4~,
        meml=\El, memu=\Emrev=\E[7mri=\EMrmacs=^Ormam=\E[?7l,
        rmkx=\E[?1l\E>rmso=\E[27mrmul=\E[24mrs1=^O,
        rs2=\E7\E[r\E8\E[m\E[?7h\E[?1;3;4;6l\E[4l\E>,
        setb=\E[4%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}
             %=%t3%e%p1%d%;m
,
        setf=\E[3%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}
             %=%t3%e%p1%d%;m
,
        sgr=\E[0%?%p1%p6%|%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5
            %;m%?%p9%t\016%e\017%;
,
        sgr0=\E[m\017smacs=^Nsmam=\E[?7hsmkx=\E[?1h\E=,
        smso=\E[7msmul=\E[4mvpa=\E[%i%p1%dd,
        use=ansi+apparrowsuse=ansi+csruse=ansi+idc,
        use=ansi+idluse=ansi+inittabsuse=ansi+local,
        use=xterm+alt47use=xterm+kbsuse=vt100+enq,
        use=ecma+coloruse=vt220+cvisuse=vt220+keypad,
        use=vt220+pcedit,

# This is the stock xterm entry supplied with XFree86 3.3, which uses VT100
# codes for F1-F4 except while in VT220 mode.
xterm-xf86-v33|xterm terminal emulator (XFree86 3.3 Window System),
        kf1=\EOPkf2=\EOQkf3=\EORkf4=\EOSuse=xterm-xf86-v32,

# This version was released in XFree86 3.3.3 (November 1998).
# Besides providing printer support, it exploits a new feature that allows
# xterm to use terminfo-based descriptions with the titeInhibit resource.
# -- the distribution contained incorrect khome/kend values -TD
xterm-xf86-v333|xterm terminal emulator (XFree86 3.3.3 Window System),
        blink=\E[5mich1@, invis=\E[8m,
        is2=\E[!p\E[?3;4l\E[4l\E>kdch1=\E[3~kfnd@, kslt@,
        rmcup=\E[?1047l\E[?1048lrs1=\Ec,
        rs2=\E[!p\E[?3;4l\E[4l\E>,
        sgr=\E[0%?%p1%p6%|%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5
            %;%?%p7%t;8%;m%?%p9%t\016%e\017%;
,
        smcup=\E[?1048h\E[?1047huse=ansi+pp,
        use=xterm-xf86-v33,

# This version was released in XFree86 4.0.
xterm-xf86-v40|xterm terminal emulator (XFree86 4.0 Window System),
        npc,
        kDC=\E[3;5~kEND=\EO5FkHOM=\EO5HkIC=\E[2;5~,
        kLFT=\EO5DkNXT=\E[6;5~kPRV=\E[5;5~kRIT=\EO5Cka1@,
        ka3@, kb2=\EOEkc1@, kc3@, kcbt=\E[Zkf13=\EO2Pkf14=\EO2Q,
        kf15=\EO2Rkf16=\EO2Skf17=\E[15;2~kf18=\E[17;2~,
        kf19=\E[18;2~kf20=\E[19;2~kf21=\E[20;2~,
        kf22=\E[21;2~kf23=\E[23;2~kf24=\E[24;2~kf25=\EO5P,
        kf26=\EO5Qkf27=\EO5Rkf28=\EO5Skf29=\E[15;5~,
        kf30=\E[17;5~kf31=\E[18;5~kf32=\E[19;5~,
        kf33=\E[20;5~kf34=\E[21;5~kf35=\E[23;5~,
        kf36=\E[24;5~kf37=\EO6Pkf38=\EO6Qkf39=\EO6R,
        kf40=\EO6Skf41=\E[15;6~kf42=\E[17;6~kf43=\E[18;6~,
        kf44=\E[19;6~kf45=\E[20;6~kf46=\E[21;6~,
        kf47=\E[23;6~kf48=\E[24;6~,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;m%?
            %p9%t\016%e\017%;
,
        use=xterm+alt1049use=xterm-xf86-v333,

# This version was released in XFree86 4.3.
xterm-xf86-v43|xterm terminal emulator (XFree86 4.3 Window System),
        kDC=\E[3;2~kEND=\E[1;2FkHOM=\E[1;2HkIC=\E[2;2~,
        kLFT=\E[1;2DkNXT=\E[6;2~kPRV=\E[5;2~kRIT=\E[1;2C,
        kbeg@,
        sgr=\E[0%?%p6%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;%?
            %p7%t;8%;m%?%p9%t\016%e\017%;
,
        use=xterm-xf86-v40,

# Controlling the cursor-visibility is not a "new" feature, but was generally
# neglected in terminal emulators until the mid-1990s.  These would work for
# the hardware terminals, or for more recent emulators, e.g., xterm.
vt220+cvis|DECTCEM VT220 cursor-visibility,
        civis=\E[?25lcnorm=\E[?25h,