The ncurses (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.
In mid-June 1995, the maintainer of 4.4BSD curses declared that he considered 4.4BSD curses obsolete, and encouraged the keepers of unix releases such as BSD/OS, FreeBSD and NetBSD to switch over to ncurses.
Since 1995, ncurses has been ported to many systems:
The distribution includes the library and support utilities, including
Full manual pages are provided for the library and tools.
The ncurses distribution is available at ncurses' homepage:
ftp://ftp.invisible-island.net/ncurses/ or
https://invisible-mirror.net/archives/ncurses/ .
It is also available via anonymous FTP at the GNU distribution site
These notes are for ncurses @VERSION@, released January 27, 2018.
This release is designed to be source-compatible with ncurses 5.0 through 6.0; providing extensions to the application binary interface (ABI). Although the source can still be configured to support the ncurses 5 ABI, the intent of the release is to provide extensions to the ncurses 6 ABI:
improve integration of tput and tset
provide support for extended numeric capabilities.
There are, of course, numerous other improvements, listed in this announcement.
The release notes also mention some bug-fixes, but are focused on new features and improvements to existing features since ncurses 6.0 release.
The improved integration of tput and tset made only small changes to the libraries. However, supporting extended numeric capabilities required a few changes:
The TERMINAL
structure in
<term.h>
is now opaque. Doing that allowed
making the structure larger, to hold the extended numeric
data.
A few applications required changes during development of ncurses 6.1 because those applications misused the members of that structure, e.g., directly modifying it rather than using def_prog_mode.
Having made TERMINAL
opaque (and because none
of the library functions use anything except a pointer to
TERMINAL
), it was possible to increase the size
of the structure, adding to the end.
Existing applications which were linked to the
ncurses 6.0 high-level
(ncurses, ncursesw) and low-level
(tinfo, tinfo) libraries should not require
re-linking since the binary interface did not change, nor did
the structure offsets with TERMINAL
change.
A few applications use the inner TERMTYPE
structure's offsets to refer to terminfo capabilities within
that structure. Again, those do not require modification
because their offsets within TERMINAL
did not
change.
When configured for wide-characters, i.e.,
“ncursesw” the TERMINAL
structure is
extended.
The new data in TERMINAL
holds the same
information as TERMTYPE
, but with larger numbers
(“int” versus “short”). It is named
TERMTYPE2
.
The library uses this structure internally in preference
to TERMTYPE
, referring to TERMTYPE
only to initialize it for applications that use the
capabilities defined in <term.h>
When configured for 8-bit (narrow) characters, the
TERMTYPE2
structure is not used.
The motivation for making this extension came from noticing that termcap applications could (though not realistically) use larger numbers than would fit in 16-bits, and the fact that the number of color pairs for a 256-color xterm could not be expressed in terminfo (i.e., 32767 versus 65536). Also, a few terminals support direct-colors, which could use the extension.
Generally speaking, applications that use internal details of
a library are unsupported. There was exactly one exception for
ncurses: the tack program used the internal
details of TERMINAL
, because it provides an
ncurses-specific feature for interactively modifying a terminfo
description and writing the updated description to a text-file.
It was possible to not only separate tack from these internal
details of ncurses, but to
generalize it so that the program works with Unix curses
(omitting the ncurses-specific feature). That was released as
tack 1.08 in July
2017.
While making changes to tack to eliminate its dependency upon ncurses internals, the publicly-visible details of those internals were reviewed, and some symbols were moved to private header files, while others were marked explicitly as ncurses internals. Future releases of ncurses may eliminate some of those symbols (such as those used by tack 1.07) because they are neither part of the API or the ABI.
Using the TERMTYPE2
extended numeric
capabilities, it is possible to support both color pair values
and color values past 32767. Taking compatibility into account,
developers readily understand that neither function signatures
nor structure offsets change. Also, existing functions have to
operate with the extended numbers. Most of that work is internal
to the library. For the external interfaces, a hybrid approach
was used:
X/Open Curses defined function prototypes such as
wattr_set
with an unused parameter, for
“future” use. After 25 years, the future is here:
ncurses uses the parameter to
augment color pair values as described in the
manual page.
Other functions such as those defining color pairs did not
have a corresponding reserved parameter. For those,
ncurses defines extended
versions such as init_extended_pair
(versus
init_pair
), init_extended_color
(versus init_color
).
Additionally, to improve performance other changes (and extensions) are provided in this release:
Several new functions simplify management of large sets of
color pairs: reset_color_pairs
,
alloc_pair
, find_pair
and
free_pair
.
New "RGB" extension capability for direct-color support is
used to improve performance of
color_content
.
The internal colorpair_t
is now a struct,
eliminating an internal 8-bit limit on colors
Allocation for SCREEN
's color-pair table
starts small, grows on demand up to the limit given in the
terminal description.
setcchar
and getcchar
now treat
a negative color-pair as an error.
These are new or revised features:
modify c++/etip.h.in
to accommodate
deprecation of throw and throws in c++17
add new function unfocus_current_field
add option to preserve leading whitespace in form fields
add a macro for is_linetouched
and adjust the
function's return value to make it possible for most
applications to check for an error-return.
add build-time utility report_offsets
to help
show when the various configurations of tinfo library are
compatible or not.
These were done to limit or ultimately deprecate features:
drop two symbols obsoleted in 2004:
_nc_check_termtype
, and
_nc_resolve_uses
move _nc_tracebits
, _tracedump
and _tracemouse
to curses.priv.h
,
since they are not part of the suggested ABI6.
mark some structs in form/menu/panel libraries as potentially opaque without modifying API/ABI.
ifdef'd header-file definition of mouse_trafo
with NCURSES_NOMACROS
remove initialization-check for calling napms
in the term-driver configuration; none is needed.
modify trace
to avoid overwriting existing
file
These are improvements to existing features:
modify make_hash
to allow building with
address-sanitizer, assuming that --disable-leaks
is configured.
move SCREEN
field for use_tioctl
data before the ncursesw fields, and limit that to the
sp-funcs configuration to improve termlib compatibility
modify db-iterator:
ignore zero-length files in db-iterator; these are
useful for instance to suppress
$HOME/.terminfo
when not wanted.
modify update_getenv
to ensure that
environment variables which are not initially set will be
checked later if an application happens to set them
modify _nc_outc_wrapper
to use the standard
output if the screen was not initialized, rather than
returning an error.
improve checks for low-level terminfo functions when the terminal has not been initialized.
modify set_curterm
to update
ttytype[]
data used by longname/p>
modify _nc_get_screensize
to allow for
use_env
and use_tioctl
state to be
per-screen when sp-funcs are configured, better matching the
behavior when using the term-driver configuration.
remove an early-return from _nc_do_color,
which can interfere with data needed by bkgd
when ncurses is configured
with extended colors
incorporate A_COLOR
mask into
COLOR_PAIR
, in case user application provides an
out-of-range pair number
modify logic for endwin
-state to be able to
detect the case where the screen was never initialized, using
that to trigger a flush of ncurses' buffer for mvcur
,
e.g., in the sample program dots_mvcur for the term-driver
configuration.
These are corrections to existing features:
fixes for writing extended color pairs in
putwin
.
modify no-leaks code for lib_cur_term.c
to
account for the tgetent
cache.
amend handling of the repeat_char
capability
in EmitRange
to avoid scope creep: translate the
character to the alternate character set when the alternate
character set is enabled, and do not use
repeat_char
for characters past 255.
improve wide-character implementation of
myADDNSTR
in frm_driver.c
, which
was inconsistent with the normal implementation.
modify winnstr
and winchnstr
to
return error if the output pointer is null, as well as adding
a null pointer check of the window pointer for better
compatibility with other implementations.
modify setupterm
to save original tty-modes
so that erasechar
works as expected. Also modify
_nc_setupscreen
to avoid redundant calls to get
original tty-modes.
modify wattr_set
and wattr_get
to return ERR
if win-parameter is null,
as documented.
correct order of initialization for traces in
use_env
and use_tioctl
versus first
_tracef
calls.
correct parameters for copywin
call in
_nc_Synchronize_Attributes
flush the standard output in _nc_flush
for
the case where SP
is zero, e.g., when called via
putp
. This fixes a scenario where
“tput flash” did not work after changes in
20130112.
amend internal use of tputs
to consistently
use the number of lines affected, e.g., for insert/delete
character operations. While merging terminfo source early in
1995, several descriptions used the
“*
” proportional delay for these
operations, prompting a change in doupdate
.
correct return-value of extended putwin
.
double-width multibyte characters were not counted
properly in winsnstr
and
wins_nwstr
.
amend fix for _nc_ripoffline
from 20091031 to
make test/ditto.c
work in threaded
configuration.
modify _nc_viscbuf2
and
_tracecchar_t2
to trace wide-characters as a
whole rather than their multibyte equivalents.
minor fix in wadd_wchnstr
to ensure that each
cell has nonzero width.
move PUTC_INIT
calls next to
wcrtomb
calls, to avoid carry-over of error
status when processing Unicode values which are not
mapped.
add missing assignment in lib_getch.c
to make
notimeout
work
While reviewing user feedback, it became apparent that the differences between reset (an alias for tset) and “tput reset” were confusing:
On further investigation, it turned out that the differences were largely an accident due to the way those programs had evolved.
This release eliminates the unnecessary differences, using the same approach for tput's init (initialization), reset and clear operations as the separate reset and clear programs. Doing this does not change the command-line options; existing scripts are unaffected.
These are the user-visible changes for the three programs (tput, tset and clear):
add the terminal-mode parts of “reset” (aka tset) to the “tput
reset
” command, making the two almost the same
except for window-size.
improve tput's check for being called as “init” or “reset” to allow for transformed names.
add “clear” as a possible link/alias to tput.
amend changes for tput to reset tty modes to “sane” if the program is run as “reset”, like tset. Likewise, ensure that tset sends either reset- or init-strings.
add -x
option to clear/tput
to make the E3
extension optional
add functionality of
“tset -w
” to tput, like the
“-c
” feature this is not optional in
tput.
add options -T
and -V
to
clear command for
compatibility with tput.
drop long-obsolete “-n
” option
from tset.
modify tset's assignment to
TERM
in its output to reflect the name by which
the terminal description is found, rather than the primary
name. That was an unnecessary part from the initial
conversion of tset from
termcap to terminfo. The termcap library in 4.3BSD did this
to avoid using the short 2-character name
remove a restriction in tput's support for termcap names which omitted capabilities normally not shown in termcap translations
add usage message to clear command
improve usage messages for tset and tput.
Other user-visible improvements and new features include:
modify tic/infocmp display of numeric values to use hexadecimal when they are "close" to a power of two, making the result more readable.
add “-W
” option to tic/infocmp
to force long strings to wrap.
This is in addition to the
“-w
” option which attempts to
fit capabilities into a given line-length.
If “-f
” option splits line,
do not further split it with
“-W
”.
Begin a new line when adding
“use=
” after a wrapped line.
add “-q
” option to infocmp to suppress the
“Reconstructed from
” comment from
the header, and a corresponding option to tic to suppress all comments from the
“tic -I
” output.
Sorted options in usage message for infocmp, to make it simpler to see unused letters.
Updated usage message for tic, adding “-0
”
option.
add infocmp/tic “-Q
” option,
which allows one to dump the compiled form of the terminal
entry, in hexadecimal or base64:
b64:
” prefix in the
TERMINFO
variable tells the terminfo reader to
use base64 according to RFC-3548 as well as RFC-4648
url/filename-safe format.hex:
” prefix tells the
terminfo reader to accept hexadecimal data as generated by
“infocmp -0qQ1
”.Other less-visible improvements and new features include:
modify utility headers such as tic.h
to make
it clearer which are externals that are used by tack.
add “reset
” to list of programs
whose names might change in manpages due to
program-transformation configure options.
modify “-T
” option of
clear and tput to call use_tioctl
to
obtain the operating system's notion of the screensize if
possible.
add check in tput for init/reset operands to ensure those use a terminal.
modify programs clear, tabs, tput and tset to pass the actual tty file descriptor to setupterm rather than the standard output or error, making padding work.
change tset's
initialization to allow it to get settings from the standard
input as well as /dev/tty
, to be more effective
when output or error are redirected.
amend check in tput,
tabs and clear to allow those to use the
database-only features in cron
if a “-T
” option gives a suitable
terminal name.
improve error message from tset/reset when both stderr/stdout are redirected to a file or pipe.
Several of the less apparent features deal with translation of terminfo to termcap (and the reverse), with corresponding checks by tic:
modify check in fmt_entry
to handle a
cancelled reset string. Make similar fixes in other parts of
dump_entry.c
and tput.c
correct read of terminfo entry in which all strings are absent or explicitly cancelled. Before this fix, the result was that all were treated as only absent.
modify infocmp to suppress
mixture of absent/cancelled capabilities that would only show
as “NULL, NULL
”, unless the
“-q
” option is used, e.g., to show
“-, @
” or “@,
-
”.
correct a warning from tic about keys which are the same, to skip over missing/cancelled values.
add check in tic for use of
bold, etc., video attributes in the color capabilities,
accounting whether the feature is listed in
ncv
.
add check in tic for
unnecessary use of “2
” to denote a
shifted special key.
improve check in tic for delays by also warning about beep/flash when a delay is not embedded, or if those use the VT100 reverse video escape without using a delay.
improve checks in trim_sgr0
, comp_parse.c and
parse_entry.c, for cancelled string capabilities.
add check in tic for some syntax errors of delays, as well as use of proportional delays for non-line capabilities.
add check in tic for
conflict between ritm
, rmso
,
rmul
versus sgr0
.
add check in _nc_parse_entry
for invalid
entry name, setting the name to
“invalid
” to avoid problems storing
entries.
improve _nc_tparm_analyze
, using that to
extend the checks made by tic
for reporting inconsistencies between the expected number of
parameters for a capability and the actual.
remove tic warning about
“^?
” in string capabilities, which
was marked as an extension; however all Unix implementations
support this and X/Open Curses does not address it. On the
other hand,
BSD termcap did not support this feature (until the
mid-1990s).
in _nc_infotocap
, added a check to ensure
that terminfo “^?
” is not written to
termcap.
modify sscanf
calls in
_nc_infotocap
for patterns
“%{number}%+%c
” and
“%'char'%+%c
” to check that the
final character is really “c
”,
avoiding a case in icl6404 which cannot be converted to
termcap.
in _nc_tic_expand
and
_nc_infotocap
, improved string-length check when
deciding whether to use “^X
” or
“\xxx
” format for control
characters, to make the output of tic/infocmp
more predictable.
limited termcap “%d
” width to 2
digits on input, and use “%2
” in
preference to “%02
” on output.
correct terminfo/termcap conversion of
“%02
” and
“%03
” into
“%2
” and
“%3
”; the result repeated the last
character.
Along with the library and utilities, many improvements were made to the ncurses-examples.
These changes were made to demonstrate new extensions in ncurses:
add demo_new_pair program,
to demonstrate
alloc_pair
,
find_pair
and
free_pair
functions.
This program iterates over the possible color combinations, allocating or initializing color pairs. For best results, choose screen-width dividing evenly into the number of colors. e.g.,
32x64,32x128
256 colors 24x44,24x88
88 colors 32x64,24x128
16 colors
add extended_color program, like the older color_set program, but using the extended color functions, with and without the SP-functions interface.
add picsmap program to fill in some testing issues not met by dots, using this as the third example in a comparison of the ncurses versus slang libraries.
The program can directly read X bitmap and pixmap files, displaying a picture. It can read other image files using ImageMagick's convert program to translate the image into text.
For 16-, 88- and 256-color terminal descriptions,
picsmap can load a palette
file which tells it which color palette entries to use. For
direct-colors, the terminal descriptions use the
RGB
extension capability.
There are other new example programs and a few scripts:
add dots_xcurses program to illustrate a different approach used for extended colors which can be contrasted with dots_curses.
add list_keys program show function keys for one or more terminal descriptions. It uses ncurses's convention of modifiers for special keys, based on xterm.
add padview program, to compare pads with direct updates in the view program.
add sp_tinfo program to exercise the SP-functions extension of the low-level terminfo library.
add test-programs for termattrs
and
term_attrs
functions.
add test_sgr program to exercise all combinations of the sgr capability.
add tput-colorcube demo script, imitating xterm's 88- and 256-color scripts using tput.
add tput-initc script to demonstrate how tput may be used to initialize a color palette from a data file.
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.
The ncurses program is the largest; a proportionately large number of changes were made to it:
modify a/A screens to make exiting on an escape character depend on the start of keypad and timeout modes, to allow better testing of function-keys.
add “t
” toggle for
notimeout
function.
modify layout of b/B screens to allow for additional annotation on the right margin; some terminals with partial support did not display well.
modify c/C screens to allow for extended color pairs.
add z/Z zoom feature to make extended color pairs easier to test.
modify test-screens to take advantage of wide screens, reducing the number of lines used for 88- and 256-colors.
modify “d
” edit-color screen to
optionally read xterm color palette directly from terminal,
as well as handling KEY_RESIZE
and
screen-repainting with control/L and control/R.
add examples to “F
” screen for
WACS_D_PLUS
and WACS_T_PLUS
.
improve “g
” screen, correcting
ifdef which made the legend not reflect changes to keypad-
and scroll-modes. Added check for return-value of
putwin
.
make “s
” test easier to
understand which subtests are available
add a corresponding “S
”
wide-character overlap test-screen.
add “v
” screen to show
baudrate
and other values.
These changes were made to the other examples:
modify blue program to use Unicode values for card-glyphs when available, as well as improving the check for CP437 and CP850.
improve demo_menus program,
allowing mouse-click on the menu-headers to switch the active
menu. This requires a new extension option
O_MOUSE_MENU
to tell the menu driver to put
mouse events which do not apply to the active menu back into
the queue so that the application can handle the event.
correct logic in demo_terminfo program for
“-f
” option
modify ditto program to
allow $XTERM_PROG
environment variable to
override "xterm" as the name of the program to run in the
threaded configuration.
add several options to the “dots” test-programs.
modify filter program:
getnstr
, that
polls for input while updating a clock on the right margin
as well as responding to window size-changes.--keep-tite
” option for
filter program as the "-a"
option. When set, filter
attempts to suppress the alternate screen.modify knight program to
provide the "slow" solution for small screens using
“R
”, noting that Warnsdorf's method
is easily done with “a
”.
modify the savescreen program to add test patterns that exercise 88-, 256-, etc., colors.
add options to test_arrays, for selecting termcap vs terminfo, etc.
modify the view program:
-n
” option by
simply reading the whole file.SIGWINCH
example; just
use KEY_RESIZE
.improve animation in xmas
program by adding a time-delay in blinkit
.
modify several test-programs which call
use_default_colors
to consistently do this only
if the “-d
” option is given.
modify the install-rule for ncurses-examples to put the
data files in the data directory, e.g.,
/usr/share/ncurses-examples
.
modify several test programs to use new
popup_msgs
function, adapted from the
help-screen used in the edit_field
program.
modify test data for xterm palettes to use the newer color4/color12 values.
improve the tracemunch script:
add_wch
,
color_content
and pair_content
to
dummy parameters.There are several new terminal descriptions:
dumb-emacs-ansi
,dvtm
,dvtm-256color
,fbterm
,iterm2
,linux-m1
minitel entries,putty-noapp
,viewdata
, andvt100+4bsd
building-block.
xterm+noalt
,xterm+titlestack
,xterm+alt1049
,xterm+alt+title
building blocks andxterm+direct
,xterm+indirect
,xterm-direct
. from xterm patch #331.several other “
-direct
” descriptions to address the differences of other terminal emulators versusxterm-direct
.
There are many changes to existing terminal descriptions. Some were updates to several descriptions:
xterm+sm+1006
in several terminal
descriptions which were validated as supporting the extended
mouse feature for their respective terminal emulators.while others affected specific descriptions. These were retested, to take into account new/undocumented changes by their developers:
iterm
,minitel
,st
,viewdata
,nsterm
while these are specific fixes based on user reports, or warnings from tic:
ansi
building blocksansi+idc
to better match original
ansiterm+idc
, add alias
ansiterm
icl6402
icl6402
and
m2-nam
interix
^?
for kdch1linux
linux3.0
entry the default
linux
entrylinux2.6
entry to improve
line-drawing so that the linux3.0
entry can be
used in non-UTF-8 modelinux
and wyse
entries to put the delay between the
reverse/normal escapes rather than afterlinux-16color
to not mask dim,
standout or reverse with the ncv capabilitypccon
entriespccon*
entriespccon+sgr+acs
and
pccon-base
pccon+keys
tmux
screen
's "standout" code rather than the
standard code.xterm-keys
option to reflect upcoming change to make that option
"on" by defaultvt100
vt100
rs2 string to reset
vt52 mode and scrolling regionsvt100-nam
vt100+4bsd
, e.g.,
delay in sgr for consistencyvte
vte-2014
to
vte-2012
xterm
xterm-new
, available
since
late 1996.xterm+256color
and
xterm+256setaf
to use correct number of color
pairs.xterm-16color
,
xterm-88color
and xterm-256color
to reset palette using oc string as in
linux
entry.xterm-256color
xterm+256color
, allowing palette reset for
xtermxterm+256setaf
xterm-r5
, xterm-r6
and
xterm-xf86-v32
to use xterm+kbs
to match
xterm #272, reflecting packager's changesxterm-new
, to reflect vt220-style responses
that could be returned.xterm-pcolor
sgr consistent
with other capabilitiesA few entries use extensions (user-defined terminal capabilities):
tmux
and xterm-basic
As usual, this release
improves documentation by describing new features,
attempts to improve the description of features which users have found confusing
fills in overlooked descriptions of features which were described in the NEWS file but treated sketchily in manual pages.
In particular,
Since the underlying features for tset, tput, and clear have been better integrated, the documentation now includes information on how those tools evolved.
In addition to explaining the improved integration of the tools, the manual pages made it easier to see how the tools are similar and how they are different.
The addch
manual page has additional
information on
portability and differences from other
implementations.
The discussion of color-pairs in the attributes manual page is improved in its history section.
The documentation of the chtype
,
cchar_t
types and the attribute values which can
be stored in those types, in particular the
history and
portability sections of the attributes manual
page, has been improved.
improve discussion of portability in the mouse manual.
The pad manual page has a section on the origin and portability of pads.
Differences between SVr4 and X/Open Curses soft-keys are discussed in a new section on portability.
There are updated/improved notes on portability in the resizeterm and wresize manual pages.
In addition to providing background information to explain these features and show how they evolved, there are corrections, clarifications, etc.:
add note in the addch manual about line-drawing when it depends upon UTF-8.
improve discussion of line-drawing characters in the add_wch manual.
explain in clear's manual page that it writes to the standard output.
improve description of endwin.
improve discussion of field validation in the form driver manual page.
clarify the use of wint_t
vs
wchar_t
in
get_wstr manual page.
clarify in the
getch manual that the keypad mode affects an
application's ability to read KEY_MOUSE
codes,
but does not affect KEY_RESIZE
.
trim some obsolete/incorrect wording about
EINTR
from the getch manual page
improve manual pages for
getch and
get_wch to point out that they might return
user-defined values which have no predefined names in
<curses.h>
improve description of the -R
option in the
infocmp manual page
clarify in the
resizeterm manual page how
KEY_RESIZE
is pushed onto the input stream.
document return value of
use_extended_names
document differences in
ESCDELAY
versus AIX's implementation in the
variables manual page.
The _nc_free_tinfo
function is now documented
in the
memory-leaks manual page, because it could be
used in tack for memory-leak
checking.
add a note to the tic manual page about -W versus -f options.
improve terminfo manual description of terminfo syntax.
improve terminfo manual page discussion of control- and graphics- characters.
improve color-handling section in terminfo manual page
clarify description in tput manual page regarding support for termcap names
update tput manual page to reflect changes to manipulate terminal modes by sharing functions with tset.
clarify in manual pages that the optional verbose option level of tic and infocmp is available only when ncurses is configured for tracing.
improve manual page description of tset/reset versus window-size.
improve description of tgoto parameters
There are new manual pages:
scr_dump documents the screen-dump format.
Some of the improvements are more subtle, relating to the way the information is presented:
Made minor fixes to manpage NAME/SYNOPSIS sections to consistently use rule that either all functions which are prototyped in SYNOPSIS are listed in the NAME section, or the manual-page name is the sole item listed in the NAME section. The latter is used to reduce clutter, e.g., for the top-level library manual pages as well as for certain feature-pages such as SP-funcs and threading.
improve manual pages for utilities with respect to POSIX versus X/Open Curses.
improve organization of the attributes and color manual pages.
modify toe to not exit if unable to read a terminal description, e.g., if there is a permission problem.
correct 20100515 change for weak signals versus sigprocmask
gprconfig
to specify the C compiler to be
used by gnatmake
, and conditionally suppressing
Library_Options
line for static libraries.There were, as well, several bug-fixes to handle illegal input for tic. Because those did not correspond to useful terminal descriptions, most users are unaffected.
This release provides a new binary format for terminal descriptions that use extended numeric capabilities. Applications built with the wide-character ncursesw library can use these extended numbers.
This includes utilities such as tic and infocmp, because (as noted in New features), the feature relies upon an extension to the low-level tinfo library.
A few software packagers use a configuration option of ncurses which allows the low-level tinfo library to be shared between the high-level ncurses and ncursesw libraries. This new feature was designed to work in that configuration as well.
Other applications (i.e., using the 8-bit ncurses library) which read the extended terminal descriptions see those numeric capabilities set to the maximum value for a signed 16-bit number.
Older versions of ncurses' tic accept out-of-range numeric capabilities, storing those as the maximum value for a signed 16-bit number. Other implementations of curses (mentioned in the discussion of picsmap) give zero for these out-of-range capabilities.
These changes provide support for tack 1.08, released in July 2017:
add --without-tack
configure option to refine
--with-progs
configure option. Normally
tack is built outside the
ncurses tree, but a few
packagers combine it during the build. If
term_entry.h
is installed, there is no advantage
to in-tree builds.
adjust configure-script to define
HAVE_CURSES_DATA_BOOLNAMES
symbol needed for
tack 1.08 when built in-tree.
Rather than relying upon internal "_nc_" functions,
tack now uses the boolean,
number and string capability name-arrays provided by
ncurses and SVr4 Unix curses.
It still uses term_entry.h
for the definitions
of the extended capability arrays.
add dependency upon ncurses_cfg.h to tic's header-files; any program using tic-library will have to supply this file. Legacy tack versions supply this file; ongoing tack development has dropped the dependency upon tic-library and new releases will not be affected.
Other changes to the configure-script and generated files include
add configure options to disable checks for form, menu and panel libraries so that ncurses-examples can be built with non-SVr4 curses implementations.
add configure option --enable-opaque-curses
for ncurses library and similar options for the
other libraries.
add configure option --disable-wattr-macros
for use in cases where one wants to use the same headers for
ncurses5/ncurses6 development, by suppressing the
wattr* macros which differ due to the introduction
of extended colors
modify configure macro for shared-library rules to use
-Wl,-rpath
rather than -rpath
to
work around a bug in scons
improve ncurses-examples' configure script to define as
needed NCURSES_WIDECHAR
for platforms where
_XOPEN_SOURCE_EXTENDED
does not work. Also
modified the test program to ensure that if building with
ncurses, that the
cchar_t
type is checked, since that is normally
(since 20111030)
ifdef'd depending on this test.
modify configure script to handle the case where
tic-library is renamed, but
the --with-debug
option is used by itself
without normal or shared libraries
modify editing script which generates resulting.map to work with the clang configuration on recent FreeBSD, which gives an error on an empty "local" section.
improve configure check for setting the
WILDCARD_SYMS
variable; on ppc64 the variable is
in the Data section rather than
Text.
correct result of configure option
--without-fallbacks
, which caused FALLBACK_LIST
to be set to "no"
modify --with-pkg-config-libdir
option to
make it possible to install “.pc” files even if
pkg-config is not found. Limit
this change, to suppress the actual install if it is not
overridden to a valid directory at install time.
disallow “no” as a possible value for
--with-shlib-version
option, overlooked in
cleanup-changes for 20000708.
Many of the portability changes are implemented via the configure script:
improve configure script's CF_CC_ENV_FLAGS
macro to allow for compiler wrappers such as ccache. This change moves only the
preprocessor, optimization and warning flags to
CPPFLAGS
and CFLAGS
, leaving the
residue in CC
. That happens to work for
gcc's various
“model” options, but may require tuning for other
compilers.
modify ncurses-examples' configure script to use pkg-config for the extra form/menu/panel libraries, to be more consistent with the handling of the curses/ncurses library.
add configuration checks to build with NetBSD
curses, which for example lacks
use_env
.
change ncurses-examples to use attr_t
vs
chtype
to follow X/Open documentation more
closely since Solaris xpg4-curses uses different values for
WA_xxx
vs A_xxx
that rely on attr_t being an unsigned short. Tru64 aka OSF1,
HPUX, AIX did as ncurses does,
equating the two sets.
modify several test programs to reflect that ncurses honors existing signal handlers in initscr, while other implementations do not.
add configure check for openpty
to
ncurses-examples' configure script, for ditto.
improve check for working poll
function by
using posix_openpt
as a fallback in case there
is no valid terminal on the standard input
modify ncurses-examples' configure script to check for pthread dependency of ncursest or ncursestw library when building the ncurses examples, e.g., in case weak symbols are used.
add checks in ncurses-examples' configure script for some functions neither in 4.3BSD curses, nor based on X/Open Curses:
modify a loop limit in firework.c to work around absense of limit checks in some libraries.
fill the last row of a window with
“?
” in firstlast if waddch does
not return ERR
on the lower-right
corner.
build-fixes for the Portland Group (PGI) compilers
accept whitespace in sed expression for generating expanded.c
modify configure check that g++ compiler warnings are not used.
add configure check for -fPIC option needed for shared libraries.
modify configure script for clang as used on FreeBSD, to work around clang's differences in exit codes vs gcc.
fixes for configure/build using clang on OSX
do not redefine “inline” in
ncurses_cfg.h
; this was originally to solve
a problem with gcc/g++, but is aggravated by clang's
misuse of symbols to pretend it is gcc.
add braces to configure script to prevent unwanted
addition of “-lstdc++
” option to
the CXXLIBS
symbol.
improve/update test-program used for checking existence of stdc++ library.
if $CXXLIBS
is set, the linkage test uses
that in addition to $LIBS
.
fixes for OS/2:
use button instead of kbuf[0]
in
EMX-specific part of lib_mouse.c
support building with libtool on OS/2
use stdc++ library with OS/2 kLIBC
clear configure script's cf_XOPEN_SOURCE
for OS/2, to work with its header files
add “newer” baudrate symbols to the
baudrate
function in the ncurses library as
well as to a corresponding table in tset.
modify ncurses-examples savescreen to work with AIX and HPUX.
define WIN32_LEAN_AND_MEAN
for MinGW port,
making builds faster.
add a configure check for wcwidth versus the ncurses line-drawing characters, to use in special-casing systems such as Solaris. Solaris, however, requires a special case that maps Unicode line-drawing characters into the acsc string for non-Unicode locales. Solaris also has a misconfigured wcwidth which marks all of the line drawing characters as double-width.
string-hacks (non-standard):
fix configure script to record when
strlcat
is found on OpenBSD.
add --enable-string-hacks
option to
ncurses-examples' configure script.
completed string-hacks for sprintf, etc., including the ncurses-examples programs.
make --enable-string-hacks
option work
with Debian by checking for the "bsd" library and its
associated "<bsd/string.h>" header.
workaround for Debian's antique/unmaintained version of mawk:
see Debian #65617, which was fixed in mawk's upstream releases in 2009.
related fixes when building link_test.
The ncurses package is fully upward-compatible with SVr4 (System V Release 4) curses:
All of the SVr4 calls have been implemented (and are documented).
ncurses 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.
ncurses provides these SVr4 add-on libraries (not part of X/Open Curses):
the panels library, supporting a stack of windows with backing store.
the menus library, supporting a uniform but flexible interface for menu programming.
the form library, supporting data collection through on-screen forms.
ncurses's terminal database is fully compatible with that used by SVr4 curses.
ncurses supports user-defined capabilities which it can see, but which are hidden from SVr4 curses applications using the same terminal database.
It can be optionally configured to match the format used in related systems such as AIX and Tru64.
Alternatively, ncurses can be configured to use hashed databases rather than the directory of files used by SVr4 curses.
The ncurses utilities have options to allow you to filter terminfo entries for use with less capable curses/terminfo versions such as the HP/UX and AIX ports.
The ncurses package also has many useful extensions over SVr4:
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).
Unlike SVr3 curses, ncurses can write to the rightmost-bottommost corner of the screen if your terminal has an insert-character capability.
Ada95 and C++ bindings.
Support for mouse event reporting with X Window xterm and FreeBSD and OS/2 console windows.
Extended mouse support via Alessandro Rubini's gpm package.
The function wresize
allows you to resize
windows, preserving their data.
The function use_default_colors
allows you to
use the terminal's default colors for the default color pair,
achieving the effect of transparent colors.
The functions keyok
and
define_key
allow you to better control the use
of function keys, e.g., disabling the ncurses KEY_MOUSE, or by defining more
than one control sequence to map to a given key code.
Support for 256-color terminals, such as modern xterm.
Support for 16-color terminals, such as aixterm and modern xterm.
Better cursor-movement optimization. The package now features a cursor-local-movement computation more efficient than either BSD's or System V's.
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
quickch
routine.
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.
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).
The tic/captoinfo utility provided with ncurses has the ability to translate many termcaps from the XENIX, IBM and AT&T extension sets.
A BSD-like tset utility is provided.
The ncurses 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.
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.)
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.
The table-of-entries utility toe makes it easy for users to see exactly what terminal types are available on the system.
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 #undef
.
Extensive documentation is provided (see the Additional Reading section of the ncurses FAQ for online documentation).
The ncurses distribution includes a selection of test programs (including a few games). These are available separately as ncurses-examples
The ncurses library has been tested with a wide variety of applications including:
- aptitude
FrontEnd to Apt, the debian package manager
- cdk
Curses Development Kit
- ded
directory-editor
- dialog
the underlying application used in Slackware's setup, and the basis for similar install/configure applications on many systems.
- lynx
the text WWW browser
- mutt
mail utility
- ncftp
file-transfer utility
- nvi
New vi uses ncurses.
- ranger
A console file manager with VI key bindings in Python.
- tin
newsreader, supporting color, MIME
- vifm
File manager with vi like keybindings
as well as some that use ncurses for the terminfo support alone:
- minicom
terminal emulator for serial modem connections
- mosh
a replacement for
ssh
.- tack
terminfo action checker
- tmux
terminal multiplexor
- vile
vi-like-emacs may be built to use the terminfo, termcap or curses interfaces.
and finally, those which use only the termcap interface:
- emacs
text editor
- less
The most commonly used pager (a program that displays text files).
- screen
terminal multiplexor
- vim
text editor
Zeyd Ben-Halim started ncurses 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. Ongoing development work is done by Thomas Dickey. Thomas Dickey also acts as the maintainer for the Free Software Foundation, which holds the copyright on ncurses.
Contact the current maintainers at
bug-ncurses@gnu.org
To join the ncurses mailing list, please write email to
bug-ncurses-request@gnu.orgcontaining the line:
subscribe
<name>@<host.domain>
This list is open to anyone interested in helping with the development and testing of this package.
Beta versions of ncurses and patches to the current release are made available at
ftp://ftp.invisible-island.net/ncurses/ and
https://invisible-mirror.net/archives/ncurses/ .
There is an archive of the mailing list here:
The release notes make scattered references to these pages, which may be interesting by themselves:
The distribution provides a newer version of the terminfo-format terminal description file once maintained by Eric Raymond . 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.
You can find lots of information on terminal-related topics not covered in the terminfo file at Richard Shuford's archive .