mirror of
https://git.hardenedbsd.org/hardenedbsd/HardenedBSD.git
synced 2024-11-15 06:42:51 +01:00
2221 lines
69 KiB
HTML
2221 lines
69 KiB
HTML
<!--
|
|
$Id: announce.html,v 1.64 2020/10/19 08:18:48 tom Exp $
|
|
****************************************************************************
|
|
* Copyright 2018-2019,2020 Thomas E. Dickey *
|
|
* *
|
|
* 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. *
|
|
****************************************************************************
|
|
-->
|
|
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN">
|
|
|
|
<html>
|
|
<head>
|
|
<meta name="generator" content=
|
|
"HTML Tidy for HTML5 for Linux version 5.2.0">
|
|
|
|
<title>Announcing ncurses 6.2</title>
|
|
<link rel="author" href="mailto:bug-ncurses@gnu.org">
|
|
<meta http-equiv="Content-Type" content=
|
|
"text/html; charset=us-ascii">
|
|
<style type="text/css">
|
|
p,li { max-width:700px; }
|
|
dd { max-width:630px; }
|
|
*.main-name {
|
|
font-style: italic;
|
|
font-variant: small-caps;
|
|
}
|
|
*.part-name {
|
|
font-family: "Andale Mono", "Monotype.com", monospace;
|
|
font-size: 12pt;
|
|
font-weight: bold;
|
|
}
|
|
*.demo-name {
|
|
font-family: "Andale Mono", "Monotype.com", monospace;
|
|
font-size: 10pt;
|
|
}
|
|
</style>
|
|
</head>
|
|
|
|
<body>
|
|
<h1 class="no-header">Announcing ncurses 6.2</h1>
|
|
|
|
<h2><a name="h2-overview" id="h2-overview">Overview</a></h2>
|
|
|
|
<p>The <span class="main-name">ncurses</span> (new curses)
|
|
library is a free software emulation of curses in System V
|
|
Release 4.0 (SVr4), and more. It uses terminfo format, supports
|
|
pads and color and multiple highlights and forms characters and
|
|
function-key mapping, and has all the other SVr4-curses
|
|
enhancements over BSD curses. SVr4 curses became the basis of
|
|
X/Open Curses.</p>
|
|
|
|
<p>In mid-June 1995, the maintainer of 4.4BSD curses declared
|
|
that he considered 4.4BSD curses obsolete, and encouraged the
|
|
keepers of <span class="main-name">unix</span> releases such as
|
|
BSD/OS, FreeBSD and NetBSD to switch over to <span class=
|
|
"main-name">ncurses</span>.</p>
|
|
|
|
<p>Since 1995, <span class="main-name">ncurses</span> has been
|
|
ported to many systems:</p>
|
|
|
|
<ul>
|
|
<li>It is used in almost every system based on the Linux kernel
|
|
(aside from some embedded applications).</li>
|
|
|
|
<li>It is used as the system curses library on OpenBSD, FreeBSD
|
|
and MacOS.</li>
|
|
|
|
<li>It is used in environments such as Cygwin and MinGW. The
|
|
first of these was EMX on OS/2 Warp.</li>
|
|
|
|
<li>It is used (though usually not as the <em>system</em>
|
|
curses) on all of the vendor <span class=
|
|
"main-name">unix</span> systems, e.g., AIX, HP-UX, IRIX64, SCO,
|
|
Solaris, Tru64.</li>
|
|
|
|
<li>It should work readily on any ANSI/POSIX-conforming
|
|
<span class="main-name">unix</span>.</li>
|
|
</ul>
|
|
|
|
<p>The distribution includes the library and support utilities,
|
|
including</p>
|
|
|
|
<ul>
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/captoinfo.1m.html"><span class="part-name">
|
|
captoinfo</span></a>, a termcap conversion tool</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/clear.1.html"><span class="part-name">
|
|
clear</span></a>, utility for clearing the screen</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/infocmp.1m.html"><span class="part-name">
|
|
infocmp</span></a>, the terminfo decompiler</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/tabs.1.html"><span class="part-name">
|
|
tabs</span></a>, set tabs on a terminal</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/tic.1m.html"><span class="part-name">
|
|
tic</span></a>, the terminfo compiler</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/toe.1m.html"><span class="part-name">
|
|
toe</span></a>, list (table of) terminfo entries</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/tput.1.html"><span class="part-name">
|
|
tput</span></a>, utility for retrieving terminal capabilities
|
|
in shell scripts</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/tset.1.html"><span class="part-name">
|
|
tset</span></a>, to initialize the terminal</li>
|
|
</ul>
|
|
|
|
<p>Full manual pages are provided for the library and tools.</p>
|
|
|
|
<p>The <span class="main-name">ncurses</span> distribution is
|
|
available at <span class="main-name">ncurses</span>' <a href=
|
|
"https://invisible-island.net/ncurses/">homepage</a>:</p>
|
|
|
|
<blockquote>
|
|
<p><a href=
|
|
"ftp://ftp.invisible-island.net/ncurses/">ftp://ftp.invisible-island.net/ncurses/</a>
|
|
or<br>
|
|
<a href=
|
|
"https://invisible-mirror.net/archives/ncurses/">https://invisible-mirror.net/archives/ncurses/</a> .</p>
|
|
</blockquote>
|
|
|
|
<p>It is also available via anonymous FTP at the GNU distribution
|
|
site</p>
|
|
|
|
<blockquote>
|
|
<p><a href=
|
|
"ftp://ftp.gnu.org/gnu/ncurses/">ftp://ftp.gnu.org/gnu/ncurses/</a> .</p>
|
|
</blockquote>
|
|
|
|
<h2><a name="h2-release-notes" id="h2-release-notes">Release
|
|
Notes</a></h2>
|
|
|
|
<p>These notes are for <span class="main-name">ncurses</span>
|
|
6.2, released <strong>February 12, 2020</strong>.</p>
|
|
|
|
<p>This release is designed to be source-compatible with
|
|
<span class="main-name">ncurses</span> 5.0 through 6.1; providing
|
|
extensions to the application binary interface (ABI). Although
|
|
the source can still be configured to support the <span class=
|
|
"main-name">ncurses</span> 5 ABI, the reason for the release is
|
|
to reflect improvements to the <span class=
|
|
"main-name">ncurses</span> 6 ABI and the supporting utility
|
|
programs.</p>
|
|
|
|
<p>There are, of course, numerous other improvements, listed in
|
|
this announcement.</p>
|
|
|
|
<p>The most <a href="#h3-bug-fixes">important
|
|
bug-fixes/improvements</a> dealt with user-defined capabilities
|
|
in terminal descriptions. The release notes also mention some
|
|
other bug-fixes, but are focused on new features and improvements
|
|
to existing features since <span class="main-name">ncurses</span>
|
|
6.1 release.</p>
|
|
|
|
<h3><a name="h3-library" id="h3-library">Library improvements</a></h3>
|
|
|
|
<h4><a name="h4-new-library" id="h4-new-library">New features</a></h4>
|
|
|
|
<p>There are several new features:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p><a href=
|
|
"https://invisible-island.net/ncurses/man/form_field_opts.3x.html">
|
|
O_EDGE_INSERT_STAY</a> tells the form library to optionally
|
|
delay cursor movement on a field edge/boundary</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p><a href=
|
|
"https://invisible-island.net/ncurses/man/form_field_opts.3x.html">
|
|
O_INPUT_FIELD</a> extension to form library allows a dynamic
|
|
field to shrink if the new limit is smaller than the current
|
|
field size.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>added <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_memleaks.3x.html">
|
|
exit_curses</a> and <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_memleaks.3x.html">
|
|
exit_terminfo</a> to replace internal symbols for
|
|
leak-checking.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>added <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_trace.3x.html#h3-Functions">
|
|
curses_trace</a>, to replace trace().</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>Additionally, to improve performance other changes (and
|
|
extensions) are provided in this release:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>mouse decoding now handles shift/control/alt logic when
|
|
decoding xterm's 1006 mode</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>ncurses now defines a limit for <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_getstr.3x.html">
|
|
wgetnstr</a>, <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_get_wstr.3x.html">
|
|
wgetn_wstr</a> when length is negative or “too
|
|
large”.</p>
|
|
</li>
|
|
|
|
<li>reordered loop-limit checks in <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_insstr.3x.html">winsnstr</a>
|
|
in case the string has no terminating null and only the number
|
|
of characters is used.</li>
|
|
|
|
<li>
|
|
<p>there is now no buffer-size limit when reading the
|
|
<a href="https://invisible-island.net/ncurses/man/ncurses.3x.html#h3-TERMCAP">
|
|
<tt>$TERMCAP</tt></a> variable.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>the <a href=
|
|
"https://invisible-island.net/ncurses/man/ncurses.3x.html#h3-TERMCAP">
|
|
<tt>$TERMCAP</tt></a> variable may be interpreted as a
|
|
fallback to a terminfo entry</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_terminfo.3x.html#h3-Output-Functions">
|
|
<tt>mvcur</tt></a> now decides whether to use hard-tabs,
|
|
using <strong><tt>xt</tt></strong>,
|
|
<strong><tt>tbc</tt></strong> and
|
|
<strong><tt>hts</tt></strong> as clues.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>extended colors are improved by modifying an internal call
|
|
to <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_terminfo.3x.html#h3-Output-Functions">
|
|
<tt>vid_puts</tt></a> to pass extended color pairs e.g., from
|
|
<tt>tty_update.c</tt> and <tt>lib_mvcur.c</tt></p>
|
|
</li>
|
|
|
|
<li>
|
|
<p id="getenv-fixes">the initialization functions now avoid
|
|
relying upon persistent data for the result from <a href=
|
|
"#getenv-check"><tt>getenv</tt></a></p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>scrolling is improved:</p>
|
|
|
|
<ul>
|
|
<li>a limit check in <tt>newline_forces_scroll</tt> handles
|
|
the case where the row is inside scroll-margins, but not at
|
|
the end.</li>
|
|
|
|
<li>
|
|
<p>improved loop limits in <tt>_nc_scroll_window</tt>
|
|
handle a case where the scrolled data is a pad which is
|
|
taller than the window.</p>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
|
|
<h4><a name="h4-fixes-library" id="h4-fixes-library">Other
|
|
improvements</a></h4>
|
|
|
|
<p>These are revised features:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>used “<tt>const</tt>” in some prototypes
|
|
rather than <tt>NCURSES_CONST</tt> where X/Open Curses was
|
|
updated to do this, e.g., <tt>wscanw</tt>, <tt>newterm</tt>,
|
|
the terminfo interface. Also use “<tt>const</tt>”
|
|
for consistency in the termcap interface, which was withdrawn
|
|
by X/Open Curses in Issue 5 (2007). As of Issue 7, X/Open
|
|
Curses still lacks “<tt>const</tt>” for certain
|
|
return values, e.g., <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_util.3x.html#h3-keyname_key_name">
|
|
keyname</a>.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>modified <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_bkgd.3x.html#h3-bkgd">
|
|
<tt>wbkgd</tt></a> and <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_bkgrnd.3x.html#h3-bkgrnd">
|
|
<tt>wbkgrnd</tt></a> to improve compatibility with SVr4
|
|
curses, changing the way the window rendition is updated when
|
|
the background character is modified</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>improved terminfo write/read by modifying the fourth item
|
|
of the extended header to denote the number of valid strings
|
|
in the extended string table (see <a href=
|
|
"https://invisible-island.net/ncurses/man/term.5.html#h3-EXTENDED-STORAGE-FORMAT">
|
|
term(5)</a>).</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>modified the initialization checks for mouse so that the
|
|
<a href=
|
|
"/ncurses/terminfo.src.html#tic-xterm_sm_1006"><tt>xterm+sm+1006</tt></a>
|
|
block will work with terminal descriptions not mentioning
|
|
<em>xterm</em>.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>These were done to limit or ultimately deprecate features:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>deprecated <a href=
|
|
"https://invisible-island.net/ncurses/NEWS.html#t970831">safe-sprintf</a>,
|
|
since the <tt>vsnprintf</tt> function, which does what was
|
|
needed, was standardized long ago.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>marked <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_printw.3x.html#h2-PORTABILITY">
|
|
<tt>vwprintw</tt></a> and <tt>vwscanw</tt> as deprecated;
|
|
recommend using <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_printw.3x.html">
|
|
<tt>vw_printw</tt></a> and <tt>vw_scanw</tt>,
|
|
respectively.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>added deprecation warnings for internal functions called
|
|
by older versions of <a href=
|
|
"https://invisible-island.net/ncurses/tack.html">tack</a>.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>removed unused <tt>_nc_import_termtype2</tt> function.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>These are improvements to existing features:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>check parameter of <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_threads.3x.html">
|
|
set_escdelay</a>, return ERR if negative.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>check parameter of <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_threads.3x.html">
|
|
set_tabsize</a>, return ERR if not greater than zero</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>correct a status-check in _nc_read_tic_entry() so that if
|
|
reading a hex/b64 <a href=
|
|
"https://invisible-island.net/ncurses/man/ncurses.3x.html#h3-TERMINFO">
|
|
<tt>$TERMINFO</tt></a>, and the <a href=
|
|
"https://invisible-island.net/ncurses/man/ncurses.3x.html#h3-TERM">
|
|
<tt>$TERM</tt></a> does not match, fall-through to the
|
|
compiled-in search list.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>amend check for <a href=
|
|
"https://invisible-island.net/ncurses/man/terminfo.5.html#h3-Predefined-Capabilities">
|
|
<tt>repeat_char</tt></a> to handle a case where setlocale()
|
|
was called after <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_initscr.3x.html">
|
|
<tt>initscr</tt></a></p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>move macro for <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_touch.3x.html">
|
|
<tt>is_linetouched</tt></a> inside
|
|
<strong><tt>NCURSES_NOMACROS</tt></strong>
|
|
<em><tt>ifndef</tt></em>.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>use <tt>_nc_copy_termtype2</tt> rather than direct
|
|
assignment in <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_terminfo.3x.html#h3-Initialization">
|
|
setupterm</a>, in case it is called repeatedly using fallback
|
|
terminfo descriptions</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>improve workaround for Solaris wcwidth versus line-drawing
|
|
characters</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>add checks in <a href=
|
|
"https://invisible-island.net/ncurses/man/resizeterm.3x.html">
|
|
<tt>repair_subwindows</tt></a> to keep the current position
|
|
and scroll-margins inside the resized subwindow.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>correct a buffer-limit in <tt>write_entry.c</tt> for
|
|
systems that use caseless filenames.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>improved build-time utility <em>report_offsets</em>:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>add categories, e.g., "w" for wide-character, "t" for
|
|
threads to make the report more readable. Reorganized the
|
|
structures reported to make the categories more
|
|
apparent.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>add <tt>NCURSES_GLOBALS</tt> and
|
|
<tt>NCURSES_PRESCREEN</tt> to report to show how similar
|
|
the different <em>libtinfo</em> configurations are.</p>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<p>modified some header files to ensure that those include
|
|
necessary files except for the previously-documented
|
|
cases</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>added some traces in initialization to show whether a
|
|
fallback entry is used.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>made minor optimization to reduce calls to
|
|
_nc_reserve_pairs</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>These are corrections to existing features:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>fix a special case in <tt>PutAttrChar</tt> where a cell is
|
|
marked as alternate-character set, but the terminal does not
|
|
actually support the given graphic character. This would
|
|
happen in an older terminal such as <em>vt52</em>, which
|
|
lacks most line-drawing capability.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>corrected flag for "seq" method of db 1.8.5 interface,
|
|
needed by toe on some of the BSDs.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>modify comparison in make_hash.c to correct a special case
|
|
in collision handling for Caps-hpux11</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>add extended_slk_color{,_sp} symbols to the appropriate
|
|
package/*.{map,sym} files</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>modify lib_setup to avoid calling pthread_self() without
|
|
first verifying that the address is valid, i.e., for weak
|
|
symbols</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>add a couple of broken-linker symbols to the list of
|
|
versioned symbols to help with link-time optimization versus
|
|
weak symbols.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="h3-programs" id="h3-programs">Program
|
|
improvements</a></h3>
|
|
|
|
<p id="h4-utilities">Several improvements were made to the
|
|
utility programs:</p>
|
|
|
|
<dl>
|
|
<dt><span class="part-name">clear</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>improved logic for clearing with the <em>E3</em>
|
|
extension, in case the terminal scrolls content onto its
|
|
saved-lines before actually clearing the display, by
|
|
clearing the saved-lines after clearing the display</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">infocmp</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>omit filtering of “<tt>OTxx</tt>” names
|
|
which are used for obsolete capabilities, when the output
|
|
is sorted by long-names. This change helps when making a
|
|
table of the short/long capability names.</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">tic</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>added check for consistent alternate character set
|
|
capabilities.</li>
|
|
|
|
<li>added check for paired <tt>indn</tt>/<tt>rin</tt>.</li>
|
|
|
|
<li>added check for terminals with <tt>parm_dch</tt> vs
|
|
<tt>parm_ich</tt>.</li>
|
|
|
|
<li>added check for the case where
|
|
<tt>setf</tt>/<tt>setb</tt> are given using different
|
|
strings, but provide identical results to
|
|
<tt>setaf</tt>/<tt>setab</tt>.</li>
|
|
|
|
<li>corrected check for <tt>ich1</tt>.</li>
|
|
|
|
<li>changed a too-large terminal entry from a fatal error
|
|
to a warning.</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">toe</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>ignores any hex/b64 <tt>$TERMINFO</tt> value in the
|
|
list of terminfo databases.</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">tset</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>replace check in <span class="part-name">reset</span>
|
|
command for obsolete “<tt>pt</tt>” capability
|
|
using <tt>tbc</tt> and <tt>hts</tt> capabilities as
|
|
clues</li>
|
|
|
|
<li>modify <span class="part-name">reset</span> to allow
|
|
for tabstops at intervals other than 8.</li>
|
|
|
|
<li>change <span class="part-name">reset</span>'s behavior
|
|
for margins to simply clear soft-margins if possible,
|
|
rather than clearing and then setting them according to the
|
|
terminal's width.</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">tput</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>add “<tt>x</tt>” to <tt>getopt</tt> string
|
|
so that “<tt>tput -x clear</tt>”
|
|
works.</li>
|
|
</ul>
|
|
</dd>
|
|
</dl>
|
|
|
|
<p>Several changes were made to the generated ncurses*config
|
|
scripts and the analogous “<tt>.pc</tt>” files to
|
|
reduce differences between the configurations they report:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>modified the ncurse*-config and pc-files to more closely
|
|
match for the <tt>-I</tt> and <tt>-l</tt> options.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>filtered out linker-specs from the <tt>--libs</tt>
|
|
report.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>amended the ncurses*-config and pc-files to take into
|
|
account the rpath hack which differed between those
|
|
files.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>modified generated ncurses*config and ncurses.pc,
|
|
ncursesw.pc, etc., to list helper libraries such as gpm for
|
|
static linking.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h4><a name="h4-examples" id="h4-examples">Examples</a></h4>
|
|
|
|
<p>Along with the library and utilities, improvements were made
|
|
to the <a href=
|
|
"https://invisible-island.net/ncurses/ncurses-examples.html">ncurses-examples</a>.
|
|
Most of this activity aimed at improving the test-packages. A few
|
|
changes are more generally useful, e.g., for the main ncurses
|
|
test-program, and for analyzing traces using the
|
|
<em>tracemunch</em> script:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>improve recovery from error when reading command-character
|
|
in <tt>test/ncurses.c</tt>, showing the relevant error
|
|
message and not exiting on EINTR.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>improve <em>tracemunch</em>, by keeping track of
|
|
<tt>TERMINAL*</tt> values, and if tracing was first turned on
|
|
after initialization, attempt to show distinct screen, window
|
|
and terminal names anyway.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>modify <em>tracemunch</em> to accept filename parameters
|
|
in addition to use as a pipe/filter.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>update <em>tracemunch</em> to work with <em>perl
|
|
5.26.2</em>, which changed the rules for escaping regular
|
|
expressions.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>add some checks in <em>tracemunch</em> for undefined
|
|
variables.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>modify <tt>TurnOn</tt>/<tt>TurnOff</tt> macros (in
|
|
lib_vidattr.c and lib_vid_attr.c) to avoid expansion of
|
|
“<tt>CUR</tt>” in trace.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>There are other new demo/test programs and reusable
|
|
examples:</p>
|
|
|
|
<dl>
|
|
<dt><span class="part-name">color_content</span>
|
|
</dt>
|
|
|
|
<dd>Demonstrate the <tt>color_content</tt> and
|
|
<tt>extended_color_content</tt> functions.</dd>
|
|
|
|
<dt><span class="part-name">demo_tabs</span>
|
|
</dt>
|
|
|
|
<dd>A simple demo of tabs in curses.</dd>
|
|
|
|
<dt><span class="part-name">dump_window</span>
|
|
</dt>
|
|
|
|
<dd>A portable curses screen-dump, used to compare ncurses
|
|
screen contents with Solaris.</dd>
|
|
|
|
<dt><span class="part-name">pair_content</span>
|
|
</dt>
|
|
|
|
<dd>Demonstrate the <tt>pair_content</tt> and
|
|
<tt>extended_pair_content</tt> functions.</dd>
|
|
|
|
<dt><span class="part-name">report_hashing</span>
|
|
</dt>
|
|
|
|
<dd>Check hash-tables used for terminfo and termcap names.</dd>
|
|
|
|
<dt><span class="part-name">parse_rgb</span>
|
|
</dt>
|
|
|
|
<dd>Sample implementation of the ncurses RGB extension from
|
|
<a href=
|
|
"https://invisible-island.net/ncurses/man/user_caps.5.html">user_caps.5</a>,
|
|
used in <em>picsmap</em> and <em>savescreen</em> programs.</dd>
|
|
</dl>
|
|
|
|
<p>A variety of improvements were made to existing programs, both
|
|
new features as well as options added to make the set of programs
|
|
more consistent.</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>add “<tt>-l</tt>” option to test/background,
|
|
to dump screen contents in a form that lets different curses
|
|
implementations be compared.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>add “<tt>@</tt>” command to test/ncurses
|
|
F-test, to allow rapid jump to different character pages.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>added enum, regex examples to test/demo_forms</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>amend Scaled256() macro in test/picsmap.c to cover the
|
|
full range 0..1000</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>corrected pathname used in Ada95 sample programs for
|
|
<tt>explain.txt</tt>, to work with test-packages, and used an
|
|
awk script to split the resulting pathname when it would be
|
|
too long for a single line.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>ignore interrupted system-call in test/ncurses's
|
|
command-line, e.g., if the terminal were resized.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>improved ifdef's for <tt>TABSIZE</tt> variable, to help
|
|
with AIX/HPUX ports.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="h3-database" id="h3-database">Terminal database</a></h3>
|
|
|
|
<p>There are several new terminal descriptions:</p>
|
|
|
|
<blockquote style="word-break:keep-all">
|
|
<p><tt>alacritty</tt>, <tt>domterm</tt>, <tt>kitty</tt>,
|
|
<tt>mintty</tt>, <tt>mintty-direct</tt>, <tt>ms-terminal</tt>,
|
|
<tt>n7900</tt>, <tt>nsterm-build309</tt>,
|
|
<tt>nsterm-direct</tt>, <tt>screen5</tt>, <tt>ti703</tt>,
|
|
<tt>ti707</tt>, <tt>ti703-w</tt>, <tt>ti707-w</tt>
|
|
<tt>vscode</tt>, <tt>vscode-direct</tt>, <tt>xterm-mono</tt>,
|
|
<tt>xterm.js</tt></p>
|
|
</blockquote>
|
|
|
|
<p>There are many changes to existing terminal descriptions. Some
|
|
were updates to several descriptions:</p>
|
|
|
|
<ul>
|
|
<li>use <a href=
|
|
"/ncurses/terminfo.src.html#tic-ansi_rep"><tt>ansi+rep</tt></a>
|
|
in a dozen places</li>
|
|
|
|
<li>add rs1 to konsole, mlterm</li>
|
|
|
|
<li>improve several flash capabilities with trailing mandatory
|
|
delays</li>
|
|
|
|
<li>drop <tt>ich1</tt> from <tt>rxvt-basic</tt>, <tt>Eterm</tt>
|
|
and <tt>mlterm</tt> to improve compatibility with old
|
|
non-curses programs</li>
|
|
|
|
<li>add/use <a href=
|
|
"/ncurses/terminfo.src.html#tic-xterm_keypad"><tt>xterm+keypad</tt></a>
|
|
in <tt>xterm-new</tt></li>
|
|
|
|
<li>use <a href=
|
|
"/ncurses/terminfo.src.html#tic-xterm_sl-twm"><tt>xterm+sl-twm</tt></a>
|
|
for consistency, nine places</li>
|
|
|
|
<li>improve <em>xm</em> example in <a href=
|
|
"/ncurses/terminfo.src.html#tic-xterm_x11mouse">xterm+x11mouse</a>
|
|
and <a href=
|
|
"/ncurses/terminfo.src.html#tic-xterm_sm_1006">xterm+sm_1006</a>.</li>
|
|
</ul>
|
|
|
|
<p>while others affected specific descriptions. These were
|
|
retested, to take into account changes by their developers:</p>
|
|
|
|
<blockquote>
|
|
<p><tt>terminator</tt>, <tt>st</tt></p>
|
|
</blockquote>
|
|
|
|
<p>while these are specific fixes based on reviewing
|
|
documentation, user reports, or warnings from <span class=
|
|
"part-name">tic</span>:</p>
|
|
|
|
<dl>
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-adds200">adds200</a>:</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>fix typo</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-gnome-256color">gnome-256color</a>
|
|
</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>base entry on "gnome", not "vte", for consistency</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-interix">interix</a>
|
|
</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>trim unnecessary setf/setb</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-linux-16color">linux-16color</a>
|
|
</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>accommodate <a href=
|
|
"https://lists.gnu.org/archive/html/bug-ncurses/2019-10/msg00061.html">
|
|
Linux console driver</a> incompatibility introduced in
|
|
early 2018</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-nsterm-256color">nsterm-256color</a>:</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>add nsterm-build309 to replace nsterm-256color,
|
|
assigning the latter as an alias of nsterm, to make mouse
|
|
work with nsterm-256color</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-regent40">regent40</a>:</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>renumber function-keys to match manual</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-regent60">regent60</a>:</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>add cd (clr_eos)</li>
|
|
|
|
<li>corrected acsc</li>
|
|
|
|
<li>add shifted function-keys</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-tvi950">tvi950</a>:</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>added function-key definitions to agree with Televideo
|
|
950 manual</li>
|
|
|
|
<li>corrected acsc</li>
|
|
|
|
<li>remove bogus kf0</li>
|
|
|
|
<li>add bel</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-tvi955">tvi955</a>:</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>fix typo</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-vi200">vi200</a>:</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>add acsc string, including right/down-arrow</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-wy50">wy50</a>:</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>corrected acsc</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href="/ncurses/terminfo.src.html#tic-wy50">wy50</a> and
|
|
<a href="/ncurses/terminfo.src.html#tic-wy60">wy60</a>:</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>add shifted function-keys as kF1 to kF16</li>
|
|
</ul>
|
|
</dd>
|
|
|
|
<dt><a href=
|
|
"/ncurses/terminfo.src.html#tic-xterm_x11hilite">xterm+x11hilite</a>:</dt>
|
|
|
|
<dd>
|
|
<ul>
|
|
<li>eliminate unused <em>p5</em> parameter.</li>
|
|
</ul>
|
|
</dd>
|
|
</dl>
|
|
|
|
<p>A few entries use extensions (user-defined terminal
|
|
capabilities):</p>
|
|
|
|
<ul>
|
|
<li>use <a href=
|
|
"/ncurses/terminfo.src.html#tic-xterm_sm_1006"><tt>xterm+sm+1006</tt></a>
|
|
(aka “SGR 1006 mouse”) for konsole-base and
|
|
putty</li>
|
|
|
|
<li>add <em><tt>Smol/Rmol</tt></em> user-defined capability to
|
|
<tt>tmux</tt> and <tt>vte-2018</tt></li>
|
|
|
|
<li>add <em><tt>Smulx</tt></em> user-defined capability to
|
|
<tt>tmux</tt>, <tt>vte-2018</tt></li>
|
|
</ul>
|
|
|
|
<h3><a name="h3-documentation" id=
|
|
"h3-documentation">Documentation</a></h3>
|
|
|
|
<p>As usual, this release</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>improves documentation by describing new features,</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>attempts to improve the description of features which
|
|
users have found confusing</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>fills in overlooked descriptions of features which were
|
|
described in the <a href=
|
|
"https://invisible-island.net/ncurses/NEWS.html">NEWS</a>
|
|
file but treated sketchily in manual pages.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>In addition to providing background information to explain
|
|
these features and show how they evolved, there are corrections,
|
|
clarifications, etc.:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>Corrections:</p>
|
|
|
|
<ul>
|
|
<li>correct error-returns listed in manual pages for a few
|
|
form functions</li>
|
|
|
|
<li>corrected prototypes in several manpages using script
|
|
to extract those in compilable form.</li>
|
|
|
|
<li>fix typo in <a href=
|
|
"https://invisible-island.net/ncurses/man/term.5.html#h3-EXTENDED-NUMBER-FORMAT">
|
|
term.5</a>, improve explanation of format</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Clarify in manual pages that <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_printw.3x.html#h2-PORTABILITY">
|
|
vwprintw</a> and <a href=
|
|
"https://invisible-island.net/ncurses/man/curs_scanw.3x.html#h2-PORTABILITY">
|
|
vwscanw</a> are obsolete.<br>
|
|
They have not been part of X/Open Curses since 2007.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>New/improved history and portability sections:</p>
|
|
|
|
<ul>
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_addch.3x.html#h3-ACS-Symbols">
|
|
curs_addch.3x</a> gives some background for ACS
|
|
symbols.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_getcchar.3x.html#h2-PORTABILITY">
|
|
curs_getcchar.3x</a> explains a difference between ncurses
|
|
and X/Open Curses.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_getstr.3x.html#h2-PORTABILITY">
|
|
curs_getstr.3x</a> gives historical/portability background
|
|
for the length parameter of <tt>wgetnstr</tt>.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_slk.3x.html">
|
|
curs_slk.3x</a> lists a few differences between SVr4 curses
|
|
and X/Open Curses for soft-keys.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_terminfo.3x.html">
|
|
curs_terminfo.3x</a> explains that the initial
|
|
implementation of terminfo in SVr2 was mostly replaced by
|
|
other developers in SVr3.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/infocmp.1m.html">infocmp.1</a>
|
|
explains that the initial version of terminfo had no tool
|
|
for decompiling descriptions. That came later, with SVr3,
|
|
with a different developer.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/tabs.1.html">tabs.1</a>
|
|
tells more than you wanted to know about the tool.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/tic.1m.html">tic.1</a>
|
|
explains that the initial version of terminfo had a
|
|
rudimentary tool (based on termcap) for compiling entries.
|
|
The tool used with Unix was developed by others for
|
|
SVr3.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/toe.1m.html">toe.1</a>
|
|
explains the origin of this tool.</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Improvements for <a href=
|
|
"https://invisible-island.net/ncurses/man/user_caps.5.html">user_caps.5</a>:</p>
|
|
|
|
<ul>
|
|
<li>mention <tt>meml</tt>, <tt>memu</tt> and
|
|
<tt>box1</tt></li>
|
|
|
|
<li>expanded description of <tt>XM</tt></li>
|
|
|
|
<li>add a clarification regarding the <tt>RGB</tt>
|
|
capability.</li>
|
|
|
|
<li>mention user_caps.5 in the tic and infocmp manual
|
|
pages.</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Other improvements:</p>
|
|
|
|
<ul>
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_add_wch.3x.html#h3-Line-Graphics">
|
|
curs_add_wch.3x</a> adds note about Unicode terminology for
|
|
the line-drawing characters.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_color.3x.html#h2-RETURN-VALUE">
|
|
curs_color.3x</a> improves discussion of error returns and
|
|
extensions.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_mouse.3x.html">
|
|
curs_mouse.3x</a> explains how the <tt>kmous</tt> and
|
|
<tt>XM</tt> capabilities are used for xterm-mouse
|
|
input.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_refresh.3x.html#h3-wnoutrefresh_doupdate">
|
|
curs_refresh.3x</a> improves documentation regarding the
|
|
virtual and physical screens.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_util.3x.html">
|
|
curs_util.3x</a> mentions a difference between SVr4 and
|
|
X/Open Curses for <tt>unctrl.h</tt></li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/curs_variables.3x.html#h2-PORTABILITY">
|
|
curs_variables.3x</a> improves description of the
|
|
<em>init_tabs</em> capability and <tt>TABSIZE</tt>
|
|
variable.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/ncurses.3x.html#h2-ALTERNATE-CONFIGURATIONS">
|
|
ncurses.3x</a> improves documentation regarding
|
|
feature-test macros in curses.h</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/resizeterm.3x.html#h3-resize_term">
|
|
resizeterm.3x</a> about top-level windows which touch the
|
|
screen's borders.</li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/man/tput.1.html#h3-Terminal-Size">
|
|
tput.1</a> clarifies how <em>tput</em> determines the
|
|
terminal size.</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>There are no new manual pages (all of the manual page updates
|
|
are to existing pages).</p>
|
|
|
|
<p>Some of the improvements are more subtle, relating to the way
|
|
the information is presented. For instance, the generated
|
|
terminfo.5 file uses a different table layout, allowing it to use
|
|
space on wide terminals more effectively.</p>
|
|
|
|
<h3><a name="h3-bug-fixes" id="h3-bug-fixes">Interesting
|
|
bug-fixes</a></h3>
|
|
|
|
<p>While there were many bugs fixed during development of ncurses
|
|
6.2, only a few (the reason for this release) were both important
|
|
and interesting. Most of the bug-fixes were for local issues
|
|
which did not affect compatibility across releases. Since those
|
|
are detailed in the NEWS file no elaboration is needed here.</p>
|
|
|
|
<p>The interesting bugs were in tic/infocmp's handling of
|
|
user-defined capabilities. These were not recent bugs. Initially
|
|
it was a simple problem:</p>
|
|
|
|
<ul>
|
|
<li>The user-defined capabilities can be any type (boolean,
|
|
number or string), but once given a type all uses of the name
|
|
must conform to that type—unless some special support for
|
|
a particular multi-typed name is built into ncurses.</li>
|
|
|
|
<li>
|
|
<p>One of simpleterm's contributors copied some definitions
|
|
for using <em>tmux</em>'s user-defined capabilities in
|
|
<a href=
|
|
"https://git.suckless.org/st/commit/06f8cf8ca87a81db15816658c40b2afcd1ad5332.html">
|
|
late in 2016</a>.</p>
|
|
|
|
<blockquote>
|
|
<pre class="demo-name">
|
|
diff --git a/st.info b/st.info
|
|
@@ -185,7 +185,10 @@ st| simpleterm,
|
|
tsl=\E]0;,
|
|
xenl,
|
|
vpa=\E[%i%p1%dd,
|
|
-
|
|
+# Tmux unofficial extensions, see TERMINFO EXTENSIONS in tmux(1)
|
|
+ Se,
|
|
+ Ss,
|
|
+ Tc,
|
|
|
|
st-256color| simpleterm with 256 colors,
|
|
use=st,
|
|
</pre>
|
|
</blockquote>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Later, in (referring to a version from <a href=
|
|
"https://git.suckless.org/st/commit/c0882f2ed1d7a2dd0fa2efa52157e6fc6fde3652.html">
|
|
mid-2017</a>), a user asked to have it updated in
|
|
ncurses.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>However, it had an error from the change in late 2016. The
|
|
terminal description made what <em>tmux</em> expected to be
|
|
<strong>string</strong> actually a
|
|
<strong>boolean</strong>.</p>
|
|
|
|
<p>Over the years, there were problems with each of
|
|
simpleterm's terminal descriptions. I repaired those, and
|
|
usually dealt with the problem.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>The difference in this case was that when compiling the
|
|
terminal database, <em>tic</em> may have in memory the
|
|
definitions for more than one terminal description (so that
|
|
it can resolve “<tt>use=</tt>” clauses). Seeing
|
|
two different types for the same name, in certain situations
|
|
it would incorrectly merge the symbol tables for the two
|
|
terminal descriptions.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>On simpleterm's side, their bug was finally fixed in
|
|
<a href=
|
|
"https://git.suckless.org/st/commit/83866428de031300eab03fbb116bcf7d2b1d4f60.html">
|
|
late 2019</a>, three years after the bug was created.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>For ncurses, the elapsed time to fix this bug was less than
|
|
three years. Someone reported a problem with the terminal
|
|
description a few weeks after releasing ncurses 6.1 (in <a href=
|
|
"https://github.com/tmux/tmux/issues/1264">tmux #1264</a>), and
|
|
the terminal description was updated that week (ncurses patch
|
|
<a href=
|
|
"https://invisible-island.net/ncurses/NEWS.html#t20180224">20180224</a>):</p>
|
|
|
|
<blockquote>
|
|
<pre class="demo-name">
|
|
20180224
|
|
+ modify _nc_resolve_uses2() to detect incompatible types when merging
|
|
a "use=" clause of extended capabilities. The problem was seen in a
|
|
defective terminfo integrated from simpleterm sources in 20171111,
|
|
compounded by repair in 20180121.
|
|
+ correct Ss/Ms interchange in st-0.7 entry (tmux #1264) -TD
|
|
</pre>
|
|
</blockquote>
|
|
|
|
<p>The larger part of that change added a check to prevent a
|
|
simple merge of terminal descriptions where the same user-defined
|
|
name was used with different types. But it raised some
|
|
questions:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>Was there a reliable way to manage terminal descriptions
|
|
which used the same extended name in different ways?</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Should ncurses provide a registry of well-known extended
|
|
names, with their types?</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>Since the correction to <a href=
|
|
"https://invisible-island.net/ncurses/ncurses.html#download_database">
|
|
<tt>terminfo.src</tt></a> could have been readily adopted by
|
|
packagers, there was nothing more to be done from ncurses'
|
|
standpoint on that part. But improving ncurses to prevent issues
|
|
like that is the reason for making a release.</p>
|
|
|
|
<p>Nothing more (constructive) was mentioned with regard to
|
|
simpleterm. But a few problems were found in the handling of
|
|
user-defined capabilities:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>Forward-references to user-defined capabilities in a
|
|
“<tt>use=</tt>” clause did not allocate new data
|
|
for each use. In <em>tic</em>, successive compilation of
|
|
terminal entries could add user-defined capabilities to the
|
|
wrong terminal entry.</p>
|
|
|
|
<p>This was not noticed before, since xterm's terminal
|
|
descriptions were the main users of the feature, and almost
|
|
all of the uses of the building-blocks which contained
|
|
user-defined capabilities were backward-references.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>There is one (documented) case where ncurses 6.1 supports
|
|
a user-defined capability that could be any type (i.e.,
|
|
“RGB”). The check added in February 2018 to guard
|
|
against mismatches did not handle all of the combinations
|
|
needed.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>Both of these issues dated from the original implementation of
|
|
user-defined capabilities. Fixing them does not change the
|
|
terminal database, but a older <em>tic</em> without the fixes
|
|
will not be able to handle terminfo sources which rely upon those
|
|
fixes. Starting in June 2019, the download link for the terminfo
|
|
source file was capped at that date. The development sources have
|
|
an up-to-date copy of the file, for people with a legitimate need
|
|
for it.</p>
|
|
|
|
<p>The “<tt>-c</tt>” (check) option of <em>tic</em>
|
|
is not very useful if it cannot offer advice on parameters needed
|
|
for user-defined capabilities. The various <em>Caps</em> files
|
|
were reorganized to reduce redundancy, and in the common portion
|
|
(<a href=
|
|
"https://github.com/ThomasDickey/ncurses-snapshots/blob/master/include/Caps-ncurses">Caps-ncurses</a>),
|
|
a registry of user-defined capabilities is provided for use by
|
|
<em>tic</em>. While users can still define their own custom
|
|
capabilities, <em>tic</em> will not offer any advice when their
|
|
parameters do not match.</p>
|
|
|
|
<p>In ncurses 6.2, <em>tic</em> makes a special check to allow
|
|
any type for <em>RGB</em>, but its being able to do this relies
|
|
upon fixes made in the ncurses library in mid-2019.</p>
|
|
|
|
<h3><a name="h3-config-config" id=
|
|
"h3-config-config">Configuration changes</a></h3>
|
|
|
|
<h4><a name="h4-config-major" id="h4-config-major">Major
|
|
changes</a></h4>
|
|
|
|
<p>There are no major changes. Several new options were added to
|
|
ease integration of packages with systems using different
|
|
versions of <em>GNAT</em> and <em>ncurses</em>. Also,
|
|
improvements were made to configure checks.</p>
|
|
|
|
<h4><a name="h4-config-options" id=
|
|
"h4-config-options">Configuration options</a></h4>
|
|
|
|
<p>There are a few new/modified configure options:</p>
|
|
|
|
<dl>
|
|
<dt><tt>--with-config-suffix</tt>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>helps work around a filename conflict with Debian packages
|
|
versus test-packages.</p>
|
|
</dd>
|
|
|
|
<dt><tt>--with-ada-libname</tt>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>allows one to rename the “AdaCurses” library
|
|
(at least one packager prefers a lowercase name).</p>
|
|
</dd>
|
|
|
|
<dt><tt>--with-fallbacks</tt>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>now ensures there is a value, and adds the fallback
|
|
information to top-level Makefile summary.</p>
|
|
</dd>
|
|
|
|
<dt><tt>--with-pcre2</tt>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>check for pcre-posix library to help with MinGW port.</p>
|
|
</dd>
|
|
|
|
<dt><tt>--with-tic-path</tt> and<br></dt>
|
|
|
|
<dt><tt>--with-infocmp-path</tt>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>help work around problems building fallback source using
|
|
pre-6.0 tic/infocmp.</p>
|
|
</dd>
|
|
|
|
<dt><tt>--with-versioned-syms</tt>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>option value can now be a relative pathname.</p>
|
|
</dd>
|
|
</dl>
|
|
|
|
<h3><a name="h3-portability" id="h3-portability">Portability</a></h3>
|
|
|
|
<p>Many of the portability changes are implemented via the
|
|
configure script:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>ignore <a href=
|
|
"/ncurses/man/ncurses.3x.html#h3-TERMINFO"><tt>$TERMINFO</tt></a>
|
|
as a default value in configure script if it came from the
|
|
<tt>infocmp</tt> <strong><tt>-Q</tt></strong> option.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>distinguish gcc from icc and clang when the
|
|
<tt>--enable-warnings</tt> option is not used, to avoid
|
|
unnecessary warnings about unrecognized inline options</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>consistently prepend new libraries as they are found
|
|
during configuration, rather than relying upon the linker to
|
|
resolve order dependencies of libraries.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>modified configure scripts to reduce relinking/ranlib
|
|
during library install :</p>
|
|
|
|
<ul>
|
|
<li>use “<tt>install -p</tt>” when available,
|
|
to avoid need for ranlib of static libraries.</li>
|
|
|
|
<li>scripts which use
|
|
“<tt>--disable-relink</tt>;” add a 1-second
|
|
sleep to work around tools which use whole-second
|
|
timestamps, e.g., in <tt>utime</tt> rather than the actual
|
|
file system resolution.</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<p id="getenv-check">add configure check for <a href=
|
|
"#getenv-fixes"><tt>getenv</tt></a> to work around
|
|
implementation shown in Emscripten which overwrites the
|
|
previous return value on each call.</p>
|
|
|
|
<p>Use that to optionally suppress <tt>START_TRACE</tt>
|
|
macro, whose call to <tt>getenv</tt> may not work
|
|
properly</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>change target configure level for <tt>_XOPEN_SOURCE</tt>
|
|
to 600 to address use of <tt>vsscanf</tt> and
|
|
<tt>setenv</tt>.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>reduce use of <tt>_GNU_SOURCE</tt> for current glibc where
|
|
<tt>_DEFAULT_SOURCE</tt> combines with
|
|
<tt>_XOPEN_SOURCE</tt></p>
|
|
|
|
<p>Allow for Cygwin's newlib when checking for the
|
|
_DEFAULT_SOURCE symbol.</p>
|
|
|
|
<p>MidnightBSD is now checked for the
|
|
<tt>_XOPEN_SOURCE</tt>-related definitions.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>If the check for <tt>va_copy</tt> or <tt>__va_copy</tt>
|
|
fails,</p>
|
|
|
|
<ul>
|
|
<li>configure now tries copying the pointers for
|
|
<tt>va_list</tt>, or as an array.</li>
|
|
|
|
<li>alternatively, it checks for
|
|
<tt>__builtin_va_copy</tt>(), which could be used with AIX
|
|
<tt>xlc</tt> in <em>c89</em> mode.</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<p>several changes to support a port to Ultrix 3.1:</p>
|
|
|
|
<ul>
|
|
<li>check if "b" binary feature of fopen works</li>
|
|
|
|
<li>check for missing feature of locale.h</li>
|
|
|
|
<li>add fallback for strstr() in test-programs</li>
|
|
|
|
<li>add fallback for STDOUT_FILENO in test-programs</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<p>The <em>test/configure</em> script (used for <a href=
|
|
"/ncurses/ncurses-examples.html"><em>ncurses-examples</em></a>)
|
|
is improved:</p>
|
|
|
|
<ul>
|
|
<li>work around non-ncurses termcap.h file, e.g., in
|
|
Slackware.</li>
|
|
|
|
<li>check for <a href=
|
|
"/ncurses/man/curs_variables.3x.html#h3-TABSIZE"><tt>TABSIZE</tt></a>
|
|
variable.</li>
|
|
|
|
<li>checks for the X11/Intrinsic.h header, accommodate
|
|
recent MacOS changes which largely emptied
|
|
<tt>/usr/include</tt>.</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>Here are some of the other portability fixes:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>added dummy "check" rule in top-level and test-Makefile to
|
|
simplify building test-packages for ArchLinux.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>dropped library-dependency on psapi for MinGW port, since
|
|
win_driver.c defines <tt>PSAPI_VERSION</tt> to 2, making it
|
|
use <tt>GetProcessImageFileName</tt> from kernel32.dll</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>made build-fixes for configuration using --program-suffix
|
|
with Ada95, noticed with MacOS but applicable to other
|
|
platforms without libpanelw, etc.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>modified ncurses/Makefile.in to fix a case where
|
|
Debian/testing changes to the ld --as-needed configuration
|
|
broke ncurses-examples test packages.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>used <tt>_WIN32</tt>/<tt>_WIN64</tt> in preference to
|
|
<tt>__MINGW32__</tt>/<tt>__MINGW64__</tt> symbols to simplify
|
|
building with Microsoft Visual C++, since the former are
|
|
defined in both compiler configurations.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<hr>
|
|
|
|
<h2><a name="h2-features" id="h2-features">Features of
|
|
<span class="main-name">ncurses</span></a></h2>
|
|
|
|
<p>The <span class="main-name">ncurses</span> package is fully
|
|
upward-compatible with SVr4 (System V Release 4) curses:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>All of the SVr4 calls have been implemented (and are
|
|
documented).</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p><span class="main-name">ncurses</span> supports all of the
|
|
for SVr4 curses features including keyboard mapping, color,
|
|
forms-drawing with ACS characters, and automatic recognition
|
|
of keypad and function keys.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p><span class="main-name">ncurses</span> provides these SVr4
|
|
add-on libraries (not part of X/Open Curses):</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>the panels library, supporting a stack of windows with
|
|
backing store.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>the menus library, supporting a uniform but flexible
|
|
interface for menu programming.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>the form library, supporting data collection through
|
|
on-screen forms.</p>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<p><span class="main-name">ncurses</span>'s terminal database
|
|
is fully compatible with that used by SVr4 curses.</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p><span class="main-name">ncurses</span> supports
|
|
user-defined capabilities which it can see, but which are
|
|
hidden from SVr4 curses applications using the
|
|
<em>same</em> terminal database.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>It can be optionally configured to match the format
|
|
used in related systems such as AIX and Tru64.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Alternatively, <span class="main-name">ncurses</span>
|
|
can be configured to use hashed databases rather than the
|
|
directory of files used by SVr4 curses.</p>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<p>The <span class="main-name">ncurses</span> utilities have
|
|
options to allow you to filter terminfo entries for use with
|
|
less capable <em>curses</em>/<em>terminfo</em> versions such
|
|
as the HP/UX and AIX ports.</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>The <span class="main-name">ncurses</span> package also has
|
|
many useful extensions over SVr4:</p>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>The API is 8-bit clean and base-level conformant with the
|
|
X/OPEN curses specification, XSI curses (that is, it
|
|
implements all BASE level features, and most EXTENDED
|
|
features). It includes many function calls not supported
|
|
under SVr4 curses (but portability of all calls is documented
|
|
so you can use the SVr4 subset only).</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Unlike SVr3 curses, <span class="main-name">ncurses</span>
|
|
can write to the rightmost-bottommost corner of the screen if
|
|
your terminal has an insert-character capability.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Ada95 and C++ bindings.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Support for mouse event reporting with X Window xterm and
|
|
FreeBSD and OS/2 console windows.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Extended mouse support via Alessandro Rubini's gpm
|
|
package.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>The function <code>wresize</code> allows you to resize
|
|
windows, preserving their data.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>The function <code>use_default_colors</code> allows you to
|
|
use the terminal's default colors for the default color pair,
|
|
achieving the effect of transparent colors.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>The functions <code>keyok</code> and
|
|
<code>define_key</code> allow you to better control the use
|
|
of function keys, e.g., disabling the <span class=
|
|
"main-name">ncurses</span> KEY_MOUSE, or by defining more
|
|
than one control sequence to map to a given key code.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Support for 256-color terminals, such as modern xterm.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Support for 16-color terminals, such as <em>aixterm</em>
|
|
and <em>modern xterm</em>.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Better cursor-movement optimization. The package now
|
|
features a cursor-local-movement computation more efficient
|
|
than either BSD's or System V's.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Super hardware scrolling support. The screen-update code
|
|
incorporates a novel, simple, and cheap algorithm that
|
|
enables it to make optimal use of hardware scrolling,
|
|
line-insertion, and line-deletion for screen-line movements.
|
|
This algorithm is more powerful than the 4.4BSD curses
|
|
<code>quickch</code> routine.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Real support for terminals with the magic-cookie glitch.
|
|
The screen-update code will refrain from drawing a highlight
|
|
if the magic- cookie unattributed spaces required just before
|
|
the beginning and after the end would step on a non-space
|
|
character. It will automatically shift highlight boundaries
|
|
when doing so would make it possible to draw the highlight
|
|
without changing the visual appearance of the screen.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>It is possible to generate the library with a list of
|
|
pre-loaded fallback entries linked to it so that it can serve
|
|
those terminal types even when no terminfo tree or termcap
|
|
file is accessible (this may be useful for support of
|
|
screen-oriented programs that must run in single-user
|
|
mode).</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>The <a href=
|
|
"https://invisible-island.net/ncurses/man/tic.1m.html"><span class="part-name">
|
|
tic</span></a>/<a href=
|
|
"https://invisible-island.net/ncurses/man/captoinfo.1m.html">captoinfo</a>
|
|
utility provided with <span class="main-name">ncurses</span>
|
|
has the ability to translate many termcaps from the XENIX,
|
|
IBM and AT&T extension sets.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>A BSD-like <a href=
|
|
"https://invisible-island.net/ncurses/man/tset.1.html"><span class="part-name">
|
|
tset</span></a> utility is provided.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>The <span class="main-name">ncurses</span> library and
|
|
utilities will automatically read terminfo entries from
|
|
$HOME/.terminfo if it exists, and compile to that directory
|
|
if it exists and the user has no write access to the system
|
|
directory. This feature makes it easier for users to have
|
|
personal terminfo entries without giving up access to the
|
|
system terminfo directory.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>You may specify a path of directories to search for
|
|
compiled descriptions with the environment variable
|
|
TERMINFO_DIRS (this generalizes the feature provided by
|
|
TERMINFO under stock System V.)</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>In terminfo source files, use capabilities may refer not
|
|
just to other entries in the same source file (as in System
|
|
V) but also to compiled entries in either the system terminfo
|
|
directory or the user's $HOME/.terminfo directory.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>The table-of-entries utility <a href=
|
|
"https://invisible-island.net/ncurses/man/toe.1m.html"><span class="part-name">
|
|
toe</span></a> makes it easy for users to see exactly what
|
|
terminal types are available on the system.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>The library meets the XSI requirement that every macro
|
|
entry point have a corresponding function which may be linked
|
|
(and will be prototype-checked) if the macro definition is
|
|
disabled with <code>#undef</code>.</p>
|
|
</li>
|
|
|
|
<li>
|
|
<p>Extensive documentation is provided (see the <em><a href=
|
|
"https://invisible-island.net/ncurses/ncurses.faq.html#additional_reading">
|
|
Additional Reading</a></em> section of the <em><a href=
|
|
"https://invisible-island.net/ncurses/ncurses.faq.html"><span class="main-name">
|
|
ncurses</span> FAQ</a></em> for online documentation).</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h2><a name="h2-who-uses" id="h2-who-uses">Applications using
|
|
<span class="main-name">ncurses</span></a></h2>
|
|
|
|
<p>The <span class="main-name">ncurses</span> distribution
|
|
includes a selection of test programs (including a few games).
|
|
These are available separately as <a href=
|
|
"https://invisible-island.net/ncurses/ncurses-examples.html">ncurses-examples</a></p>
|
|
|
|
<p>The ncurses library has been tested with a wide variety of
|
|
applications including:</p>
|
|
|
|
<blockquote>
|
|
<dl>
|
|
<dt><span class="part-name">aptitude</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>FrontEnd to Apt, the debian package manager</p>
|
|
|
|
<p><a href=
|
|
"https://wiki.debian.org/Aptitude">https://wiki.debian.org/Aptitude</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">cdk</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>Curses Development Kit</p>
|
|
|
|
<p><a href=
|
|
"https://invisible-island.net/cdk/">https://invisible-island.net/cdk/</a><br>
|
|
|
|
</p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">ded</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>directory-editor</p>
|
|
|
|
<p><a href=
|
|
"https://invisible-island.net/ded/">https://invisible-island.net/ded/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">dialog</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>the underlying application used in Slackware's setup,
|
|
and the basis for similar install/configure applications on
|
|
many systems.</p>
|
|
|
|
<p><a href=
|
|
"https://invisible-island.net/dialog/">https://invisible-island.net/dialog/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">lynx</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>the text WWW browser</p>
|
|
|
|
<p><a href=
|
|
"https://lynx.invisible-island.net/">https://lynx.invisible-island.net/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">mutt</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>mail utility</p>
|
|
|
|
<p><a href="http://www.mutt.org/">http://www.mutt.org/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">ncftp</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>file-transfer utility</p>
|
|
|
|
<p><a href=
|
|
"https://www.ncftp.com/">https://www.ncftp.com/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">nvi</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>New vi uses ncurses.</p>
|
|
|
|
<p><a href=
|
|
"https://sites.google.com/a/bostic.com/keithbostic/vi">https://sites.google.com/a/bostic.com/keithbostic/vi</a><br>
|
|
|
|
</p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">ranger</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>A console file manager with VI key bindings in
|
|
<em>Python</em>.</p>
|
|
|
|
<p><a href=
|
|
"https://ranger.github.io/">https://ranger.github.io/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">tin</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>newsreader, supporting color, MIME</p>
|
|
|
|
<p><a href="http://www.tin.org/">http://www.tin.org/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">vifm</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>File manager with vi like keybindings</p>
|
|
|
|
<p><a href="https://vifm.info/">https://vifm.info/</a></p>
|
|
</dd>
|
|
</dl>
|
|
</blockquote>
|
|
|
|
<p>as well as some that use <span class=
|
|
"main-name">ncurses</span> for the terminfo support alone:</p>
|
|
|
|
<blockquote>
|
|
<dl>
|
|
<dt><span class="part-name">minicom</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>terminal emulator for serial modem connections</p>
|
|
|
|
<p><a href=
|
|
"https://alioth.debian.org/projects/minicom/">https://alioth.debian.org/projects/minicom/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">mosh</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>a replacement for <code>ssh</code>.</p>
|
|
|
|
<p><a href=
|
|
"https://mosh.mit.edu/">https://mosh.mit.edu/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">tack</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>terminfo action checker</p>
|
|
|
|
<p><a href=
|
|
"https://invisible-island.net/ncurses/tack.html">https://invisible-island.net/ncurses/tack.html</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">tmux</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>terminal multiplexor</p>
|
|
|
|
<p><a href=
|
|
"https://github.com/tmux/tmux/wiki">https://github.com/tmux/tmux/wiki</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">vile</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p><em>vi-like-emacs</em> may be built to use the terminfo,
|
|
termcap or curses interfaces.</p>
|
|
|
|
<p><a href=
|
|
"https://invisible-island.net/vile/">https://invisible-island.net/vile/</a></p>
|
|
</dd>
|
|
</dl>
|
|
</blockquote>
|
|
|
|
<p>and finally, those which use only the termcap interface:</p>
|
|
|
|
<blockquote>
|
|
<dl>
|
|
<dt><span class="part-name">emacs</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>text editor</p>
|
|
|
|
<p><a href=
|
|
"https://www.gnu.org/software/emacs/">https://www.gnu.org/software/emacs/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">less</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>The most commonly used <em>pager</em> (a program that
|
|
displays text files).</p>
|
|
|
|
<p><a href=
|
|
"http://www.greenwoodsoftware.com/less/">http://www.greenwoodsoftware.com/less/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">screen</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>terminal multiplexor</p>
|
|
|
|
<p><a href=
|
|
"https://www.gnu.org/software/screen/">https://www.gnu.org/software/screen/</a></p>
|
|
</dd>
|
|
|
|
<dt><span class="part-name">vim</span>
|
|
</dt>
|
|
|
|
<dd>
|
|
<p>text editor</p>
|
|
|
|
<p><a href="https://www.vim.org/">https://www.vim.org/</a></p>
|
|
</dd>
|
|
</dl>
|
|
</blockquote>
|
|
|
|
<h2><a name="h2-development" id="h2-development">Development
|
|
activities</a></h2>
|
|
|
|
<p>Zeyd Ben-Halim started <span class="main-name">ncurses</span>
|
|
from a previous package pcurses, written by Pavel Curtis. Eric S.
|
|
Raymond continued development. Jürgen Pfeifer wrote most of
|
|
the form and menu libraries.</p>
|
|
|
|
<p>Ongoing development work is done by <a href=
|
|
"mailto:dickey@invisible-island.net">Thomas E. Dickey</a>. Thomas
|
|
E. Dickey has acted as the maintainer for the Free Software
|
|
Foundation, which holds a <a href=
|
|
"https://invisible-island.net/ncurses/ncurses-license.html">copyright
|
|
on ncurses</a> for releases 4.2 through 6.1. Following the
|
|
release of ncurses 6.1, effective as of release 6.2, copyright
|
|
for ncurses reverted to Thomas E. Dickey (see the <a href=
|
|
"https://invisible-island.net/ncurses/ncurses.faq.html#relicensed">
|
|
ncurses FAQ</a> for additional information).</p>
|
|
|
|
<p>Contact the current maintainers at</p>
|
|
|
|
<blockquote>
|
|
<a href="mailto:bug-ncurses@gnu.org">bug-ncurses@gnu.org</a>
|
|
</blockquote>
|
|
|
|
<p>To join the ncurses mailing list, please write email to</p>
|
|
|
|
<blockquote>
|
|
<a href=
|
|
"mailto:bug-ncurses-request@gnu.org">bug-ncurses-request@gnu.org</a>
|
|
</blockquote>
|
|
containing the line:
|
|
|
|
<blockquote>
|
|
<p><code>subscribe</code>
|
|
<em><name>@<host.domain></em></p>
|
|
</blockquote>
|
|
|
|
<p>This list is open to anyone interested in helping with the
|
|
development and testing of this package.</p>
|
|
|
|
<p>Beta versions of <span class="main-name">ncurses</span> are
|
|
made available at</p>
|
|
|
|
<blockquote>
|
|
<p><a href=
|
|
"ftp://ftp.invisible-island.net/ncurses/current/">ftp://ftp.invisible-island.net/ncurses/current/</a>
|
|
and<br>
|
|
<a href=
|
|
"https://invisible-mirror.net/archives/ncurses/current/">https://invisible-mirror.net/archives/ncurses/current/</a> .</p>
|
|
</blockquote>
|
|
|
|
<p>Patches to the current release are made available at</p>
|
|
|
|
<blockquote>
|
|
<p><a href=
|
|
"ftp://ftp.invisible-island.net/ncurses/6.1/">ftp://ftp.invisible-island.net/ncurses/6.1/</a>
|
|
and<br>
|
|
<a href=
|
|
"https://invisible-mirror.net/archives/ncurses/6.1/">https://invisible-mirror.net/archives/ncurses/6.1/</a> .</p>
|
|
</blockquote>
|
|
|
|
<p>There is an archive of the mailing list here:</p>
|
|
|
|
<blockquote>
|
|
<p><a href=
|
|
"http://lists.gnu.org/archive/html/bug-ncurses">http://lists.gnu.org/archive/html/bug-ncurses</a>
|
|
(also <a href=
|
|
"https://lists.gnu.org/archive/html/bug-ncurses">https</a>)</p>
|
|
</blockquote>
|
|
|
|
<h2><a name="h2-this-stuff" id="h2-this-stuff">Related
|
|
resources</a></h2>
|
|
|
|
<p>The release notes make scattered references to these pages,
|
|
which may be interesting by themselves:</p>
|
|
|
|
<ul>
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/ncurses-license.html"><span class="main-name">
|
|
ncurses</span> licensing</a></li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/ncurses-mapsyms.html">Symbol
|
|
versioning in <span class="main-name">ncurses</span></a></li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/ncurses-slang.html">Comments
|
|
on <span class="main-name">ncurses</span> versus <span class=
|
|
"main-name">slang</span> (S-Lang)</a></li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/tack.html">tack –
|
|
terminfo action checker</a></li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/tctest.html">tctest
|
|
– termcap library checker</a></li>
|
|
|
|
<li><a href=
|
|
"https://invisible-island.net/ncurses/ncurses.html#download_database">
|
|
Terminal Database</a></li>
|
|
</ul>
|
|
|
|
<h2><a name="h2-other-stuff" id="h2-other-stuff">Other
|
|
resources</a></h2>
|
|
|
|
<p>The distribution provides a newer version of the
|
|
terminfo-format terminal description file once maintained by
|
|
<a href="http://www.catb.org/~esr/terminfo/">Eric
|
|
Raymond</a> . Unlike the older version, the termcap and
|
|
terminfo data are provided in the same file, which also provides
|
|
several user-definable extensions beyond the X/Open
|
|
specification.</p>
|
|
|
|
<p>You can find lots of information on terminal-related topics
|
|
not covered in the terminfo file at <a href=
|
|
"http://web.archive.org/web/*/http://www.cs.utk.edu/~shuford/terminal">
|
|
Richard Shuford's archive</a> . The collection of computer
|
|
manuals at <a href=
|
|
"http://www.bitsavers.org/pdf/">bitsavers.org</a> has also been
|
|
useful.</p>
|
|
|
|
<div class="nav">
|
|
<ul>
|
|
<li><a href="#h2-overview">Overview</a></li>
|
|
|
|
<li>
|
|
<a href="#h2-release-notes">Release Notes</a>
|
|
|
|
<ul>
|
|
<li>
|
|
<a href="#h3-library">Library improvements</a>
|
|
|
|
<ul>
|
|
<li><a href="#h4-new-library">New features</a></li>
|
|
|
|
<li><a href="#h4-fixes-library">Other
|
|
improvements</a></li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<a href="#h3-programs">Program improvements</a>
|
|
|
|
<ul>
|
|
<li><a href="#h4-utilities">Utilities</a></li>
|
|
|
|
<li><a href="#h4-examples">Examples</a></li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li><a href="#h3-database">Terminal database</a></li>
|
|
|
|
<li><a href="#h3-documentation">Documentation</a></li>
|
|
|
|
<li><a href="#h3-bug-fixes">Interesting bug-fixes</a></li>
|
|
|
|
<li>
|
|
<a href="#h3-config-config">Configuration changes</a>
|
|
|
|
<ul>
|
|
<li><a href="#h4-config-major">Major changes</a></li>
|
|
|
|
<li><a href="#h4-config-options">Configuration
|
|
options</a></li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li><a href="#h3-portability">Portability</a></li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li><a href="#h2-features">Features of <span class=
|
|
"main-name">ncurses</span></a></li>
|
|
|
|
<li><a href="#h2-who-uses">Applications using <span class=
|
|
"main-name">ncurses</span></a></li>
|
|
|
|
<li><a href="#h2-development">Development activities</a></li>
|
|
|
|
<li><a href="#h2-this-stuff">Related resources</a></li>
|
|
|
|
<li><a href="#h2-other-stuff">Other resources</a></li>
|
|
</ul>
|
|
</div>
|
|
</body>
|
|
</html>
|