1999-08-24 01:06:48 +00:00
|
|
|
'\" t
|
|
|
|
.\"***************************************************************************
|
2020-02-19 16:58:06 +00:00
|
|
|
.\" Copyright 2018-2019,2020 Thomas E. Dickey *
|
|
|
|
.\" Copyright 1998-2017,2018 Free Software Foundation, Inc. *
|
1999-08-24 01:06:48 +00:00
|
|
|
.\" *
|
|
|
|
.\" Permission is hereby granted, free of charge, to any person obtaining a *
|
|
|
|
.\" copy of this software and associated documentation files (the *
|
|
|
|
.\" "Software"), to deal in the Software without restriction, including *
|
|
|
|
.\" without limitation the rights to use, copy, modify, merge, publish, *
|
|
|
|
.\" distribute, distribute with modifications, sublicense, and/or sell *
|
|
|
|
.\" copies of the Software, and to permit persons to whom the Software is *
|
|
|
|
.\" furnished to do so, subject to the following conditions: *
|
|
|
|
.\" *
|
|
|
|
.\" The above copyright notice and this permission notice shall be included *
|
|
|
|
.\" in all copies or substantial portions of the Software. *
|
|
|
|
.\" *
|
|
|
|
.\" THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS *
|
|
|
|
.\" OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF *
|
|
|
|
.\" MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *
|
|
|
|
.\" IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, *
|
|
|
|
.\" DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR *
|
|
|
|
.\" OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *
|
|
|
|
.\" THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
|
|
|
|
.\" *
|
|
|
|
.\" Except as contained in this notice, the name(s) of the above copyright *
|
|
|
|
.\" holders shall not be used in advertising or otherwise to promote the *
|
|
|
|
.\" sale, use or other dealings in this Software without prior written *
|
|
|
|
.\" authorization. *
|
|
|
|
.\"***************************************************************************
|
|
|
|
.\"
|
2020-02-19 16:58:06 +00:00
|
|
|
.\" $Id: infocmp.1m,v 1.76 2020/02/02 23:34:34 tom Exp $
|
2007-12-30 11:08:14 +00:00
|
|
|
.TH @INFOCMP@ 1M ""
|
2020-02-07 08:36:41 +00:00
|
|
|
.ie \n(.g .ds `` \(lq
|
|
|
|
.el .ds `` ``
|
|
|
|
.ie \n(.g .ds '' \(rq
|
|
|
|
.el .ds '' ''
|
1999-08-24 01:06:48 +00:00
|
|
|
.ds n 5
|
2014-03-01 00:40:26 +00:00
|
|
|
.de bP
|
2020-02-07 08:36:41 +00:00
|
|
|
.ie n .IP \(bu 4
|
|
|
|
.el .IP \(bu 2
|
|
|
|
..
|
|
|
|
.de NS
|
|
|
|
.ie n .sp
|
|
|
|
.el .sp .5
|
|
|
|
.ie n .in +4
|
|
|
|
.el .in +2
|
|
|
|
.nf
|
|
|
|
.ft C \" Courier
|
|
|
|
..
|
|
|
|
.de NE
|
|
|
|
.fi
|
|
|
|
.ft R
|
|
|
|
.ie n .in -4
|
|
|
|
.el .in -2
|
2014-03-01 00:40:26 +00:00
|
|
|
..
|
2000-10-11 07:31:01 +00:00
|
|
|
.ds d @TERMINFO@
|
1999-08-24 01:06:48 +00:00
|
|
|
.SH NAME
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB@INFOCMP@\fR \- compare or print out \fIterminfo\fR descriptions
|
1999-08-24 01:06:48 +00:00
|
|
|
.SH SYNOPSIS
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB@INFOCMP@\fR [\fB\-\
|
2007-01-20 07:32:02 +00:00
|
|
|
1\
|
|
|
|
C\
|
2014-03-01 00:40:26 +00:00
|
|
|
D\
|
2007-01-20 07:32:02 +00:00
|
|
|
E\
|
|
|
|
F\
|
|
|
|
G\
|
|
|
|
I\
|
2014-03-01 00:40:26 +00:00
|
|
|
K\
|
2007-01-20 07:32:02 +00:00
|
|
|
L\
|
|
|
|
T\
|
|
|
|
U\
|
|
|
|
V\
|
2020-02-07 08:36:41 +00:00
|
|
|
W\
|
2007-01-20 07:32:02 +00:00
|
|
|
c\
|
|
|
|
d\
|
|
|
|
e\
|
|
|
|
g\
|
|
|
|
i\
|
|
|
|
l\
|
|
|
|
n\
|
|
|
|
p\
|
|
|
|
q\
|
|
|
|
r\
|
|
|
|
t\
|
|
|
|
u\
|
|
|
|
x\
|
|
|
|
\fR]
|
|
|
|
.br
|
2020-02-07 08:36:41 +00:00
|
|
|
[\fB\-v\fR \fIn\fR] [\fB\-s d\fR| \fBi\fR| \fBl\fR| \fBc\fR] [\fB\-Q\fR \fIn\fR] [\fB\-R \fR\fBsubset\fR]
|
1999-08-24 01:06:48 +00:00
|
|
|
.br
|
2014-02-28 19:18:07 +00:00
|
|
|
[\fB\-w\fR\ \fIwidth\fR] [\fB\-A\fR\ \fIdirectory\fR] [\fB\-B\fR\ \fIdirectory\fR]
|
1999-08-24 01:06:48 +00:00
|
|
|
.br
|
|
|
|
[\fItermname\fR...]
|
|
|
|
.SH DESCRIPTION
|
2007-12-30 11:08:14 +00:00
|
|
|
\fB@INFOCMP@\fR can be used to compare a binary \fBterminfo\fR entry with other
|
1999-08-24 01:06:48 +00:00
|
|
|
terminfo entries, rewrite a \fBterminfo\fR description to take advantage of the
|
|
|
|
\fBuse=\fR terminfo field, or print out a \fBterminfo\fR description from the
|
2014-03-01 00:40:26 +00:00
|
|
|
binary file (\fBterm\fR) in a variety of formats.
|
|
|
|
In all cases, the boolean
|
1999-08-24 01:06:48 +00:00
|
|
|
fields will be printed first, followed by the numeric fields, followed by the
|
|
|
|
string fields.
|
|
|
|
.SS Default Options
|
|
|
|
If no options are specified and zero or one \fItermnames\fR are specified, the
|
2014-03-01 00:40:26 +00:00
|
|
|
\fB\-I\fR option will be assumed.
|
|
|
|
If more than one \fItermname\fR is specified,
|
2014-02-28 19:18:07 +00:00
|
|
|
the \fB\-d\fR option will be assumed.
|
|
|
|
.SS Comparison Options [\-d] [\-c] [\-n]
|
2007-12-30 11:08:14 +00:00
|
|
|
\fB@INFOCMP@\fR compares the \fBterminfo\fR description of the first terminal
|
1999-08-24 01:06:48 +00:00
|
|
|
\fItermname\fR with each of the descriptions given by the entries for the other
|
2014-03-01 00:40:26 +00:00
|
|
|
terminal's \fItermnames\fR.
|
|
|
|
If a capability is defined for only one of the
|
2020-02-07 08:36:41 +00:00
|
|
|
terminals, the value returned depends on the type of the capability:
|
|
|
|
.bP
|
|
|
|
\fBF\fR for missing boolean variables
|
|
|
|
.bP
|
|
|
|
\fBNULL\fR for missing integer or string variables
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
2020-02-07 08:36:41 +00:00
|
|
|
Use the \fB\-q\fP option to show the distinction between
|
|
|
|
\fIabsent\fP and \fIcancelled\fP capabilities.
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
2020-02-07 08:36:41 +00:00
|
|
|
These options produce a list which you can use to compare two
|
|
|
|
or more terminal descriptions:
|
|
|
|
.TP 5
|
|
|
|
\fB\-d\fR
|
|
|
|
produces a list of each capability that is \fIdifferent\fP
|
|
|
|
between two entries.
|
|
|
|
Each item in the list shows \*(``:\*('' after the capability name,
|
|
|
|
followed by the capability values, separated by a comma.
|
|
|
|
.TP
|
|
|
|
\fB\-c\fR
|
|
|
|
produces a list of each capability that is \fIcommon\fP between
|
2014-03-01 00:40:26 +00:00
|
|
|
two or more entries.
|
2020-02-07 08:36:41 +00:00
|
|
|
Missing capabilities are ignored.
|
|
|
|
Each item in the list shows \*(``=\*('' after the capability name,
|
|
|
|
followed by the capability value.
|
|
|
|
.IP
|
|
|
|
The \fB\-u\fR option provides a related output,
|
|
|
|
showing the first terminal description rewritten to use the second
|
|
|
|
as a building block via the \*(``use=\*('' clause.
|
|
|
|
.TP
|
|
|
|
\fB\-n\fR
|
|
|
|
produces a list of each capability that is in \fInone\fP of the given entries.
|
|
|
|
Each item in the list shows \*(``!\*('' before the capability name.
|
|
|
|
.IP
|
|
|
|
Normally only the conventional capabilities are shown.
|
|
|
|
Use the \fB\-x\fP option to add the BSD-compatibility
|
|
|
|
capabilities (names prefixed with \*(``OT\*('').
|
|
|
|
.IP
|
|
|
|
If no \fItermnames\fR are given,
|
|
|
|
\fB@INFOCMP@\fR uses the environment variable \fBTERM\fR
|
|
|
|
for each of the \fItermnames\fR.
|
2014-02-28 19:18:07 +00:00
|
|
|
.SS Source Listing Options [\-I] [\-L] [\-C] [\-r]
|
2020-02-07 08:36:41 +00:00
|
|
|
The \fB\-I\fR, \fB\-L\fR, and \fB\-C\fR options will produce
|
|
|
|
a source listing for each terminal named.
|
2007-01-20 07:32:02 +00:00
|
|
|
.
|
1999-08-24 01:06:48 +00:00
|
|
|
.TS
|
|
|
|
center tab(/) ;
|
|
|
|
l l .
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-I\fR/use the \fBterminfo\fR names
|
|
|
|
\fB\-L\fR/use the long C variable name listed in <\fBterm.h\fR>
|
|
|
|
\fB\-C\fR/use the \fBtermcap\fR names
|
|
|
|
\fB\-r\fR/when using \fB\-C\fR, put out all capabilities in \fBtermcap\fR form
|
2014-03-01 00:40:26 +00:00
|
|
|
\fB\-K\fR/modifies the \fB\-C\fP option, improving BSD-compatibility.
|
1999-08-24 01:06:48 +00:00
|
|
|
.TE
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
1999-08-24 01:06:48 +00:00
|
|
|
If no \fItermnames\fR are given, the environment variable \fBTERM\fR will be
|
|
|
|
used for the terminal name.
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
2014-02-28 19:18:07 +00:00
|
|
|
The source produced by the \fB\-C\fR option may be used directly as a
|
1999-08-24 01:06:48 +00:00
|
|
|
\fBtermcap\fR entry, but not all parameterized strings can be changed to
|
2014-03-01 00:40:26 +00:00
|
|
|
the \fBtermcap\fR format.
|
|
|
|
\fB@INFOCMP@\fR will attempt to convert most of the
|
1999-08-24 01:06:48 +00:00
|
|
|
parameterized information, and anything not converted will be plainly marked in
|
2014-03-01 00:40:26 +00:00
|
|
|
the output and commented out.
|
|
|
|
These should be edited by hand.
|
|
|
|
.PP
|
|
|
|
For best results when converting to \fBtermcap\fP format,
|
|
|
|
you should use both \fB\-C\fP and \fB\-r\fP.
|
|
|
|
Normally a termcap description is limited to 1023 bytes.
|
2020-02-07 08:36:41 +00:00
|
|
|
\fB@INFOCMP@\fP trims away less essential parts to make it fit.
|
2014-03-01 00:40:26 +00:00
|
|
|
If you are converting to one of the (rare) termcap implementations
|
|
|
|
which accept an unlimited size of termcap,
|
|
|
|
you may want to add the \fB\-T\fP option.
|
|
|
|
More often however, you must help the termcap implementation,
|
|
|
|
and trim excess whitespace (use the \fB\-0\fP option for that).
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
1999-08-24 01:06:48 +00:00
|
|
|
All padding information for strings will be collected together and placed
|
2014-03-01 00:40:26 +00:00
|
|
|
at the beginning of the string where \fBtermcap\fR expects it.
|
|
|
|
Mandatory
|
2020-02-07 08:36:41 +00:00
|
|
|
padding (padding information with a trailing \*(``/\*('') will become optional.
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
1999-08-24 01:06:48 +00:00
|
|
|
All \fBtermcap\fR variables no longer supported by \fBterminfo\fR, but which
|
2014-03-01 00:40:26 +00:00
|
|
|
are derivable from other \fBterminfo\fR variables, will be output.
|
|
|
|
Not all
|
1999-08-24 01:06:48 +00:00
|
|
|
\fBterminfo\fR capabilities will be translated; only those variables which were
|
2014-03-01 00:40:26 +00:00
|
|
|
part of \fBtermcap\fR will normally be output.
|
|
|
|
Specifying the \fB\-r\fR option
|
1999-08-24 01:06:48 +00:00
|
|
|
will take off this restriction, allowing all capabilities to be output in
|
|
|
|
\fItermcap\fR form.
|
2014-03-01 00:40:26 +00:00
|
|
|
Normally you would use both the \fB\-C\fP and \fB\-r\fP options.
|
|
|
|
The actual format used incorporates some improvements for escaped characters
|
|
|
|
from terminfo format.
|
|
|
|
For a stricter BSD-compatible translation, use the \fB\-K\fR option
|
|
|
|
rather than \fB\-C\fP.
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
1999-08-24 01:06:48 +00:00
|
|
|
Note that because padding is collected to the beginning of the capability, not
|
2014-03-01 00:40:26 +00:00
|
|
|
all capabilities are output.
|
|
|
|
Mandatory padding is not supported.
|
|
|
|
Because
|
1999-08-24 01:06:48 +00:00
|
|
|
\fBtermcap\fR strings are not as flexible, it is not always possible to convert
|
2014-03-01 00:40:26 +00:00
|
|
|
a \fBterminfo\fR string capability into an equivalent \fBtermcap\fR format.
|
2020-02-07 08:36:41 +00:00
|
|
|
A subsequent conversion of the \fBtermcap\fR file
|
|
|
|
back into \fBterminfo\fR format
|
|
|
|
will not necessarily reproduce the original \fBterminfo\fR source.
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
1999-08-24 01:06:48 +00:00
|
|
|
Some common \fBterminfo\fR parameter sequences, their \fBtermcap\fR
|
|
|
|
equivalents, and some terminal types which commonly have such sequences, are:
|
2007-01-20 07:32:02 +00:00
|
|
|
.
|
1999-08-24 01:06:48 +00:00
|
|
|
.TS
|
|
|
|
center tab(/) ;
|
|
|
|
l c l
|
|
|
|
l l l.
|
|
|
|
\fBterminfo/termcap\fR/Representative Terminals
|
|
|
|
=
|
|
|
|
\fB%p1%c/%.\fR/adm
|
|
|
|
\fB%p1%d/%d\fR/hp, ANSI standard, vt100
|
|
|
|
\fB%p1%'x'%+%c/%+x\fR/concept
|
|
|
|
\fB%i/%i\fRq/ANSI standard, vt100
|
|
|
|
\fB%p1%?%'x'%>%t%p1%'y'%+%;/%>xy\fR/concept
|
|
|
|
\fB%p2\fR is printed before \fB%p1/%r\fR/hp
|
|
|
|
.TE
|
2014-02-28 19:18:07 +00:00
|
|
|
.SS Use= Option [\-u]
|
|
|
|
The \fB\-u\fR option produces a \fBterminfo\fR source description of the first
|
1999-08-24 01:06:48 +00:00
|
|
|
terminal \fItermname\fR which is relative to the sum of the descriptions given
|
2014-03-01 00:40:26 +00:00
|
|
|
by the entries for the other terminals \fItermnames\fR.
|
|
|
|
It does this by
|
1999-08-24 01:06:48 +00:00
|
|
|
analyzing the differences between the first \fItermname\fR and the other
|
|
|
|
\fItermnames\fR and producing a description with \fBuse=\fR fields for the
|
2014-03-01 00:40:26 +00:00
|
|
|
other terminals.
|
|
|
|
In this manner, it is possible to retrofit generic terminfo
|
|
|
|
entries into a terminal's description.
|
|
|
|
Or, if two similar terminals exist, but
|
1999-08-24 01:06:48 +00:00
|
|
|
were coded at different times or by different people so that each description
|
2020-02-07 08:36:41 +00:00
|
|
|
is a full description, using \fB@INFOCMP@\fR
|
|
|
|
will show what can be done to change
|
1999-08-24 01:06:48 +00:00
|
|
|
one description to be relative to the other.
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
1999-08-24 01:06:48 +00:00
|
|
|
A capability will get printed with an at-sign (@) if it no longer exists in the
|
|
|
|
first \fItermname\fR, but one of the other \fItermname\fR entries contains a
|
2014-03-01 00:40:26 +00:00
|
|
|
value for it.
|
|
|
|
A capability's value gets printed if the value in the first
|
1999-08-24 01:06:48 +00:00
|
|
|
\fItermname\fR is not found in any of the other \fItermname\fR entries, or if
|
|
|
|
the first of the other \fItermname\fR entries that has this capability gives a
|
|
|
|
different value for the capability than that in the first \fItermname\fR.
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
2014-03-01 00:40:26 +00:00
|
|
|
The order of the other \fItermname\fR entries is significant.
|
|
|
|
Since the
|
|
|
|
terminfo compiler \fB@TIC@\fR does a left-to-right scan of the capabilities,
|
1999-08-24 01:06:48 +00:00
|
|
|
specifying two \fBuse=\fR entries that contain differing entries for the same
|
|
|
|
capabilities will produce different results depending on the order that the
|
2014-03-01 00:40:26 +00:00
|
|
|
entries are given in.
|
|
|
|
\fB@INFOCMP@\fR will flag any such inconsistencies between
|
1999-08-24 01:06:48 +00:00
|
|
|
the other \fItermname\fR entries as they are found.
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
1999-08-24 01:06:48 +00:00
|
|
|
Alternatively, specifying a capability \fIafter\fR a \fBuse=\fR entry that
|
|
|
|
contains that capability will cause the second specification to be ignored.
|
2007-12-30 11:08:14 +00:00
|
|
|
Using \fB@INFOCMP@\fR to recreate a description can be a useful check to make
|
1999-08-24 01:06:48 +00:00
|
|
|
sure that everything was specified correctly in the original source
|
|
|
|
description.
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
1999-08-24 01:06:48 +00:00
|
|
|
Another error that does not cause incorrect compiled files, but will slow down
|
|
|
|
the compilation time, is specifying extra \fBuse=\fR fields that are
|
2014-03-01 00:40:26 +00:00
|
|
|
superfluous.
|
|
|
|
\fB@INFOCMP@\fR will flag any other \fItermname use=\fR fields that
|
1999-08-24 01:06:48 +00:00
|
|
|
were not needed.
|
2014-02-28 19:18:07 +00:00
|
|
|
.SS Changing Databases [\-A \fIdirectory\fR] [\-B \fIdirectory\fR]
|
2014-03-01 00:40:26 +00:00
|
|
|
Like other \fBncurses\fP utilities,
|
2020-02-07 08:36:41 +00:00
|
|
|
\fB@INFOCMP@\fP looks for the terminal descriptions in several places.
|
2014-03-01 00:40:26 +00:00
|
|
|
You can use the \fBTERMINFO\fP and \fBTERMINFO_DIRS\fP environment variables
|
|
|
|
to override the compiled-in default list of places to search
|
|
|
|
(see \fBcurses\fP(3X) for details).
|
|
|
|
.PP
|
|
|
|
You can also use the options \fB\-A\fR
|
|
|
|
and \fB\-B\fR to override the list of places to search
|
|
|
|
when comparing terminal descriptions:
|
|
|
|
.bP
|
|
|
|
The \fB\-A\fR option sets the location for the first \fItermname\fR
|
|
|
|
.bP
|
|
|
|
The \fB\-B\fR option sets the location for the other \fItermnames\fR.
|
|
|
|
.PP
|
|
|
|
Using these options, it is possible to
|
1999-08-24 01:06:48 +00:00
|
|
|
compare descriptions for a terminal with the same name located in two different
|
2014-03-01 00:40:26 +00:00
|
|
|
databases.
|
|
|
|
For instance,
|
|
|
|
you can use this feature for comparing descriptions for the same terminal
|
1999-08-24 01:06:48 +00:00
|
|
|
created by different people.
|
2007-01-20 07:32:02 +00:00
|
|
|
.SS Other Options
|
1999-08-24 01:06:48 +00:00
|
|
|
.TP 5
|
2014-03-01 00:40:26 +00:00
|
|
|
\fB\-0\fR
|
|
|
|
causes the fields to be printed on one line, without wrapping.
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-1\fR
|
2014-03-01 00:40:26 +00:00
|
|
|
causes the fields to be printed out one to a line.
|
|
|
|
Otherwise,
|
1999-08-24 01:06:48 +00:00
|
|
|
the fields will be printed several to a line to a maximum width
|
|
|
|
of 60 characters.
|
2000-07-03 09:24:12 +00:00
|
|
|
.TP
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-a\fR
|
2020-02-07 08:36:41 +00:00
|
|
|
tells \fB@INFOCMP@\fP to retain commented-out capabilities
|
|
|
|
rather than discarding them.
|
2014-03-01 00:40:26 +00:00
|
|
|
Capabilities are commented by prefixing them with a period.
|
|
|
|
.TP
|
|
|
|
\fB\-D\fR
|
2020-02-07 08:36:41 +00:00
|
|
|
tells \fB@INFOCMP@\fP to print the database locations that it knows about,
|
|
|
|
and exit.
|
2000-07-03 09:24:12 +00:00
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-E\fR
|
1999-08-24 01:06:48 +00:00
|
|
|
Dump the capabilities of the given terminal as tables, needed in
|
|
|
|
the C initializer for a
|
|
|
|
TERMTYPE structure (the terminal capability structure in the \fB<term.h>\fR).
|
|
|
|
This option is useful for preparing versions of the curses library hardwired
|
|
|
|
for a given terminal type.
|
|
|
|
The tables are all declared static, and are named according to the type
|
|
|
|
and the name of the corresponding terminal entry.
|
|
|
|
.sp
|
2014-02-28 19:18:07 +00:00
|
|
|
Before ncurses 5.0, the split between the \fB\-e\fP and \fB\-E\fP
|
1999-08-24 01:06:48 +00:00
|
|
|
options was not needed; but support for extended names required making
|
|
|
|
the arrays of terminal capabilities separate from the TERMTYPE structure.
|
2007-01-20 07:32:02 +00:00
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-e\fR
|
2007-01-20 07:32:02 +00:00
|
|
|
Dump the capabilities of the given terminal as a C initializer for a
|
|
|
|
TERMTYPE structure (the terminal capability structure in the \fB<term.h>\fR).
|
|
|
|
This option is useful for preparing versions of the curses library hardwired
|
|
|
|
for a given terminal type.
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-F\fR
|
2014-03-01 00:40:26 +00:00
|
|
|
compare terminfo files.
|
|
|
|
This assumes that two following arguments are filenames.
|
|
|
|
The files are searched for pairwise matches between
|
2007-01-20 07:32:02 +00:00
|
|
|
entries, with two entries considered to match if any of their names do.
|
|
|
|
The report printed to standard output lists entries with no matches in
|
2014-03-01 00:40:26 +00:00
|
|
|
the other file, and entries with more than one match.
|
|
|
|
For entries
|
|
|
|
with exactly one match it includes a difference report.
|
|
|
|
Normally,
|
2007-01-20 07:32:02 +00:00
|
|
|
to reduce the volume of the report, use references are
|
|
|
|
not resolved before looking for differences, but resolution can be forced
|
2014-02-28 19:18:07 +00:00
|
|
|
by also specifying \fB\-r\fR.
|
2007-01-20 07:32:02 +00:00
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-f\fR
|
1999-08-24 01:06:48 +00:00
|
|
|
Display complex terminfo strings which contain if/then/else/endif expressions
|
|
|
|
indented for readability.
|
2007-01-20 07:32:02 +00:00
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-G\fR
|
2007-01-20 07:32:02 +00:00
|
|
|
Display constant literals in decimal form
|
|
|
|
rather than their character equivalents.
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-g\fR
|
1999-08-24 01:06:48 +00:00
|
|
|
Display constant character literals in quoted form
|
|
|
|
rather than their decimal equivalents.
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-i\fR
|
1999-08-24 01:06:48 +00:00
|
|
|
Analyze the initialization (\fBis1\fR, \fBis2\fR, \fBis3\fR), and reset
|
2020-02-07 08:36:41 +00:00
|
|
|
(\fBrs1\fR, \fBrs2\fR, \fBrs3\fR), strings in the entry,
|
|
|
|
as well as those used for starting/stopping cursor-positioning mode
|
|
|
|
(\fBsmcup\fP, \fBrmcup\fP) as well as starting/stopping keymap mode
|
|
|
|
(\fBsmkx\fP, \fBrmkx\fP).
|
|
|
|
.IP
|
2014-03-01 00:40:26 +00:00
|
|
|
For each string, the
|
1999-08-24 01:06:48 +00:00
|
|
|
code tries to analyze it into actions in terms of the other capabilities in the
|
2014-02-28 19:18:07 +00:00
|
|
|
entry, certain X3.64/ISO 6429/ECMA\-48 capabilities, and certain DEC VT-series
|
1999-08-24 01:06:48 +00:00
|
|
|
private modes (the set of recognized special sequences has been selected for
|
2014-03-01 00:40:26 +00:00
|
|
|
completeness over the existing terminfo database).
|
|
|
|
Each report line consists
|
1999-08-24 01:06:48 +00:00
|
|
|
of the capability name, followed by a colon and space, followed by a printable
|
|
|
|
expansion of the capability string with sections matching recognized actions
|
2014-03-01 00:40:26 +00:00
|
|
|
translated into {}-bracketed descriptions.
|
2020-02-07 08:36:41 +00:00
|
|
|
.IP
|
2014-03-01 00:40:26 +00:00
|
|
|
Here is a list of the DEC/ANSI
|
1999-08-24 01:06:48 +00:00
|
|
|
special sequences recognized:
|
|
|
|
.TS
|
|
|
|
center tab(/) ;
|
|
|
|
l l
|
|
|
|
l l.
|
|
|
|
Action/Meaning
|
|
|
|
=
|
|
|
|
RIS/full reset
|
|
|
|
SC/save cursor
|
|
|
|
RC/restore cursor
|
|
|
|
LL/home-down
|
|
|
|
RSR/reset scroll region
|
2007-01-20 07:32:02 +00:00
|
|
|
=
|
|
|
|
DECSTR/soft reset (VT320)
|
|
|
|
S7C1T/7-bit controls (VT220)
|
|
|
|
=
|
1999-08-24 01:06:48 +00:00
|
|
|
ISO DEC G0/enable DEC graphics for G0
|
|
|
|
ISO UK G0/enable UK chars for G0
|
|
|
|
ISO US G0/enable US chars for G0
|
|
|
|
ISO DEC G1/enable DEC graphics for G1
|
|
|
|
ISO UK G1/enable UK chars for G1
|
|
|
|
ISO US G1/enable US chars for G1
|
2007-01-20 07:32:02 +00:00
|
|
|
=
|
1999-08-24 01:06:48 +00:00
|
|
|
DECPAM/application keypad mode
|
|
|
|
DECPNM/normal keypad mode
|
|
|
|
DECANSI/enter ANSI mode
|
2007-01-20 07:32:02 +00:00
|
|
|
=
|
2014-02-28 19:18:07 +00:00
|
|
|
ECMA[+\-]AM/keyboard action mode
|
|
|
|
ECMA[+\-]IRM/insert replace mode
|
|
|
|
ECMA[+\-]SRM/send receive mode
|
|
|
|
ECMA[+\-]LNM/linefeed mode
|
2007-01-20 07:32:02 +00:00
|
|
|
=
|
2014-02-28 19:18:07 +00:00
|
|
|
DEC[+\-]CKM/application cursor keys
|
|
|
|
DEC[+\-]ANM/set VT52 mode
|
|
|
|
DEC[+\-]COLM/132-column mode
|
|
|
|
DEC[+\-]SCLM/smooth scroll
|
|
|
|
DEC[+\-]SCNM/reverse video mode
|
|
|
|
DEC[+\-]OM/origin mode
|
|
|
|
DEC[+\-]AWM/wraparound mode
|
|
|
|
DEC[+\-]ARM/auto-repeat mode
|
1999-08-24 01:06:48 +00:00
|
|
|
.TE
|
|
|
|
.sp
|
|
|
|
It also recognizes a SGR action corresponding to ANSI/ISO 6429/ECMA Set
|
|
|
|
Graphics Rendition, with the values NORMAL, BOLD, UNDERLINE, BLINK, and
|
2014-03-01 00:40:26 +00:00
|
|
|
REVERSE.
|
2020-02-07 08:36:41 +00:00
|
|
|
All but NORMAL may be prefixed with
|
|
|
|
.RS
|
|
|
|
.bP
|
|
|
|
\*(``+\*('' (turn on) or
|
|
|
|
.bP
|
|
|
|
\*(``\-\*('' (turn off).
|
|
|
|
.RE
|
|
|
|
.IP
|
1999-08-24 01:06:48 +00:00
|
|
|
An SGR0 designates an empty highlight sequence (equivalent to {SGR:NORMAL}).
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-l\fR
|
2007-01-20 07:32:02 +00:00
|
|
|
Set output format to terminfo.
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-p\fR
|
1999-08-24 01:06:48 +00:00
|
|
|
Ignore padding specifications when comparing strings.
|
|
|
|
.TP 5
|
2020-02-07 08:36:41 +00:00
|
|
|
\fB\-Q\fR \fIn\fR
|
|
|
|
Rather than show source in terminfo (text) format,
|
|
|
|
print the compiled (binary) format in hexadecimal or base64 form,
|
|
|
|
depending on the option's value:
|
|
|
|
.RS 8
|
|
|
|
.TP 3
|
|
|
|
1
|
|
|
|
hexadecimal
|
|
|
|
.TP 3
|
|
|
|
2
|
|
|
|
base64
|
|
|
|
.TP 3
|
|
|
|
3
|
|
|
|
hexadecimal and base64
|
|
|
|
.RE
|
|
|
|
.IP
|
|
|
|
For example, this prints the compiled terminfo value as a string
|
|
|
|
which could be assigned to the \fBTERMINFO\fP environment variable:
|
|
|
|
.NS
|
|
|
|
@INFOCMP@ -0 -q -Q2
|
|
|
|
.NE
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-q\fR
|
2020-02-07 08:36:41 +00:00
|
|
|
This makes the output a little shorter:
|
|
|
|
.RS
|
|
|
|
.bP
|
2007-01-20 07:32:02 +00:00
|
|
|
Make the comparison listing shorter by omitting subheadings, and using
|
2020-02-07 08:36:41 +00:00
|
|
|
\*(``\-\*('' for absent capabilities, \*(``@\*(''
|
|
|
|
for canceled rather than \*(``NULL\*(''.
|
|
|
|
.bP
|
|
|
|
However, show differences between absent and cancelled capabilities.
|
|
|
|
.bP
|
|
|
|
Omit the \*(``Reconstructed from\*('' comment for source listings.
|
|
|
|
.RE
|
2007-01-20 07:32:02 +00:00
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-R\fR\fIsubset\fR
|
2014-03-01 00:40:26 +00:00
|
|
|
Restrict output to a given subset.
|
|
|
|
This option is for use with archaic
|
2007-01-20 07:32:02 +00:00
|
|
|
versions of terminfo like those on SVr1, Ultrix, or HP/UX that do not support
|
|
|
|
the full set of SVR4/XSI Curses terminfo; and variants such as AIX
|
2014-03-01 00:40:26 +00:00
|
|
|
that have their own extensions incompatible with SVr4/XSI.
|
2020-02-07 08:36:41 +00:00
|
|
|
.RS
|
|
|
|
.bP
|
2014-03-01 00:40:26 +00:00
|
|
|
Available terminfo
|
2020-02-07 08:36:41 +00:00
|
|
|
subsets are \*(``SVr1\*('', \*(``Ultrix\*('', \*(``HP\*('', and \*(``AIX\*('';
|
|
|
|
see \fBterminfo\fR(\*n) for details.
|
|
|
|
.bP
|
|
|
|
You can also choose the subset \*(``BSD\*('' which selects only capabilities
|
2007-01-20 07:32:02 +00:00
|
|
|
with termcap equivalents recognized by 4.4BSD.
|
2020-02-07 08:36:41 +00:00
|
|
|
The \fB\-C\fP option sets the \*(``BSD\*('' subset as a side-effect.
|
|
|
|
.bP
|
|
|
|
If you select any other value for \fB\-R\fP,
|
|
|
|
it is the same as no subset, i.e., all capabilities are used.
|
|
|
|
The \fB\-I\fP option likewise selects no subset as a side-effect.
|
|
|
|
.RE
|
2007-01-20 07:32:02 +00:00
|
|
|
.TP
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-s \fR\fI[d|i|l|c]\fR
|
|
|
|
The \fB\-s\fR option sorts the fields within each type according to the argument
|
2007-01-20 07:32:02 +00:00
|
|
|
below:
|
|
|
|
.br
|
|
|
|
.RS 5
|
|
|
|
.TP 5
|
|
|
|
\fBd\fR
|
|
|
|
leave fields in the order that they are stored in the \fIterminfo\fR database.
|
|
|
|
.TP 5
|
|
|
|
\fBi\fR
|
|
|
|
sort by \fIterminfo\fR name.
|
|
|
|
.TP 5
|
|
|
|
\fBl\fR
|
|
|
|
sort by the long C variable name.
|
|
|
|
.TP 5
|
|
|
|
\fBc\fR
|
|
|
|
sort by the \fItermcap\fR name.
|
|
|
|
.RE
|
|
|
|
.IP
|
2014-02-28 19:18:07 +00:00
|
|
|
If the \fB\-s\fR option is not given, the fields printed out will be
|
2007-01-20 07:32:02 +00:00
|
|
|
sorted alphabetically by the \fBterminfo\fR name within each type,
|
2014-02-28 19:18:07 +00:00
|
|
|
except in the case of the \fB\-C\fR or the \fB\-L\fR options, which cause the
|
2007-01-20 07:32:02 +00:00
|
|
|
sorting to be done by the \fBtermcap\fR name or the long C variable
|
|
|
|
name, respectively.
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-T\fR
|
2007-01-20 07:32:02 +00:00
|
|
|
eliminates size-restrictions on the generated text.
|
|
|
|
This is mainly useful for testing and analysis, since the compiled
|
|
|
|
descriptions are limited (e.g., 1023 for termcap, 4096 for terminfo).
|
|
|
|
.TP
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-t\fR
|
2014-03-01 00:40:26 +00:00
|
|
|
tells \fB@TIC@\fP to discard commented-out capabilities.
|
2007-01-20 07:32:02 +00:00
|
|
|
Normally when translating from terminfo to termcap,
|
|
|
|
untranslatable capabilities are commented-out.
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-U\fR
|
2020-02-07 08:36:41 +00:00
|
|
|
tells \fB@INFOCMP@\fP to not post-process the data
|
|
|
|
after parsing the source file.
|
2007-01-20 07:32:02 +00:00
|
|
|
This feature helps when comparing the actual contents of two source files,
|
2007-12-30 11:08:14 +00:00
|
|
|
since it excludes the inferences that \fB@INFOCMP@\fP makes to fill in missing
|
2007-01-20 07:32:02 +00:00
|
|
|
data.
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-V\fR
|
2007-01-20 07:32:02 +00:00
|
|
|
reports the version of ncurses which was used in this program, and exits.
|
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-v\fR \fIn\fR
|
1999-08-24 01:06:48 +00:00
|
|
|
prints out tracing information on standard error as the program runs.
|
2020-02-07 08:36:41 +00:00
|
|
|
.IP
|
|
|
|
The optional parameter \fIn\fR is a number from 1 to 10, inclusive,
|
|
|
|
indicating the desired level of detail of information.
|
|
|
|
If ncurses is built without tracing support, the optional parameter is ignored.
|
|
|
|
.TP
|
|
|
|
\fB\-W\fR
|
|
|
|
By itself, the \fB\-w\fP option will not force long strings to be wrapped.
|
|
|
|
Use the \fB\-W\fP option to do this.
|
1999-08-24 01:06:48 +00:00
|
|
|
.TP 5
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-w\fR \fIwidth\fR
|
1999-08-24 01:06:48 +00:00
|
|
|
changes the output to \fIwidth\fR characters.
|
2007-01-20 07:32:02 +00:00
|
|
|
.TP
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-x\fR
|
2020-02-07 08:36:41 +00:00
|
|
|
print information for user-defined capabilities (see \fBuser_caps(\*n)\fP.
|
2007-01-20 07:32:02 +00:00
|
|
|
These are extensions to the terminfo repertoire which can be loaded
|
2014-03-01 00:40:26 +00:00
|
|
|
using the \fB\-x\fR option of \fB@TIC@\fP.
|
1999-08-24 01:06:48 +00:00
|
|
|
.SH FILES
|
|
|
|
.TP 20
|
|
|
|
\*d
|
|
|
|
Compiled terminal description database.
|
2020-02-07 08:36:41 +00:00
|
|
|
.SH HISTORY
|
|
|
|
Although System V Release 2 provided a terminfo library,
|
|
|
|
it had no documented tool for decompiling the terminal descriptions.
|
|
|
|
Tony Hansen (AT&T) wrote the first \fBinfocmp\fP in early 1984,
|
|
|
|
for System V Release 3.
|
|
|
|
.PP
|
|
|
|
Eric Raymond used the AT&T documentation in 1995 to provide an equivalent
|
|
|
|
\fB@INFOCMP@\fP for ncurses.
|
|
|
|
In addition, he added a few new features such as:
|
|
|
|
.bP
|
|
|
|
the \fB\-e\fP option, to support \fIfallback\fP
|
|
|
|
(compiled-in) terminal descriptions
|
|
|
|
.bP
|
|
|
|
the \fB\-i\fP option, to help with analysis
|
|
|
|
.PP
|
|
|
|
Later, Thomas Dickey added the \fB\-x\fP (user-defined capabilities)
|
|
|
|
option, and the \fB\-E\fP option to support fallback entries with
|
|
|
|
user-defined capabilities.
|
|
|
|
.PP
|
|
|
|
For a complete list, see the \fIEXTENSIONS\fP section.
|
|
|
|
.PP
|
|
|
|
In 2010, Roy Marples provided an \fBinfocmp\fP program for NetBSD.
|
|
|
|
It is less capable than the SVr4 or ncurses versions
|
|
|
|
(e.g., it lacks the sorting options documented in X/Open),
|
|
|
|
but does include the \fB\-x\fP option adapted from ncurses.
|
|
|
|
.SH PORTABILITY
|
|
|
|
X/Open Curses, Issue 7 (2009) provides a description of \fBinfocmp\fP.
|
|
|
|
It does not mention the options used for converting to termcap format.
|
1999-08-24 01:06:48 +00:00
|
|
|
.SH EXTENSIONS
|
|
|
|
The
|
2014-03-01 00:40:26 +00:00
|
|
|
\fB\-0\fR,
|
|
|
|
\fB\-1\fR,
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-E\fR,
|
|
|
|
\fB\-F\fR,
|
|
|
|
\fB\-G\fR,
|
2020-02-07 08:36:41 +00:00
|
|
|
\fB\-Q\fR,
|
2014-02-28 19:18:07 +00:00
|
|
|
\fB\-R\fR,
|
|
|
|
\fB\-T\fR,
|
|
|
|
\fB\-V\fR,
|
|
|
|
\fB\-a\fR,
|
|
|
|
\fB\-e\fR,
|
|
|
|
\fB\-f\fR,
|
|
|
|
\fB\-g\fR,
|
|
|
|
\fB\-i\fR,
|
|
|
|
\fB\-l\fR,
|
|
|
|
\fB\-p\fR,
|
|
|
|
\fB\-q\fR and
|
|
|
|
\fB\-t\fR
|
1999-08-24 01:06:48 +00:00
|
|
|
options are not supported in SVr4 curses.
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
2020-02-07 08:36:41 +00:00
|
|
|
SVr4 infocmp does not distinguish between absent and cancelled capabilities.
|
|
|
|
Also, it shows missing integer capabilities as \fB\-1\fP
|
|
|
|
(the internal value used to represent missing integers).
|
|
|
|
This implementation shows those as \*(``NULL\*('',
|
|
|
|
for consistency with missing strings.
|
|
|
|
.PP
|
|
|
|
The \fB\-r\fR option's notion of \*(``termcap\*('' capabilities
|
|
|
|
is System V Release 4's.
|
2014-03-01 00:40:26 +00:00
|
|
|
Actual BSD curses versions will have a more restricted set.
|
|
|
|
To see only the
|
2014-02-28 19:18:07 +00:00
|
|
|
4.4BSD set, use \fB\-r\fR \fB\-RBSD\fR.
|
1999-08-24 01:06:48 +00:00
|
|
|
.SH BUGS
|
2014-02-28 19:18:07 +00:00
|
|
|
The \fB\-F\fR option of \fB@INFOCMP@\fR(1M) should be a \fB@TOE@\fR(1M) mode.
|
1999-08-24 01:06:48 +00:00
|
|
|
.SH SEE ALSO
|
2007-01-20 07:32:02 +00:00
|
|
|
\fB@CAPTOINFO@\fR(1M),
|
|
|
|
\fB@INFOTOCAP@\fR(1M),
|
|
|
|
\fB@TIC@\fR(1M),
|
|
|
|
\fB@TOE@\fR(1M),
|
|
|
|
\fBcurses\fR(3X),
|
|
|
|
\fBterminfo\fR(\*n).
|
2020-02-07 08:36:41 +00:00
|
|
|
\fBuser_caps\fR(\*n).
|
2014-03-01 00:40:26 +00:00
|
|
|
.sp
|
2020-02-07 08:36:41 +00:00
|
|
|
https://invisible-island.net/ncurses/tctest.html
|
2007-01-20 07:32:02 +00:00
|
|
|
.PP
|
|
|
|
This describes \fBncurses\fR
|
|
|
|
version @NCURSES_MAJOR@.@NCURSES_MINOR@ (patch @NCURSES_PATCH@).
|
1999-08-24 01:06:48 +00:00
|
|
|
.SH AUTHOR
|
|
|
|
Eric S. Raymond <esr@snark.thyrsus.com>
|
|
|
|
and
|
2007-01-20 07:32:02 +00:00
|
|
|
.br
|
|
|
|
Thomas E. Dickey <dickey@invisible-island.net>
|