X-Git-Url: http://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=announce.html.in;h=378f6f80b012306a993e9f59a3b37b69f380862e;hp=1d4121ee4ff1739361add67ed5c8dec8127663db;hb=073e4446d2def7ebf1f0ff4f124f0c8d4af0b788;hpb=e70a86c3d48b8cbad0f6d1c33ba5b027a243834e diff --git a/announce.html.in b/announce.html.in index 1d4121ee..378f6f80 100644 --- a/announce.html.in +++ b/announce.html.in @@ -1,8 +1,7 @@ - - -
-- -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.
- -The ncurses code was developed under GNU/Linux. -It has been in use for some time with OpenBSD as the system curses library, -and on FreeBSD and NetBSD as an external package. -It should port easily to any ANSI/POSIX-conforming UNIX. -It has even been ported to OS/2 Warp!
- -The distribution includes the library and support utilities, including a -terminfo compiler tic(1), a decompiler infocmp(1), clear(1), tput(1), tset(1), -and a termcap conversion tool captoinfo(1). Full manual pages are provided for -the library and tools.
-
-The ncurses distribution is available via anonymous FTP at
-the GNU distribution site
-ftp://ftp.gnu.org/gnu/ncurses/ .
-
It is also available at
-ftp://invisible-island.net/ncurses/ .
-
-
-Interface changes: -
NCURSES_OPAQUE
symbol to curses.h, will
- use to make structs opaque in selected configurations.
-
- NCURSES_EXT_FUNCS
and
- NCURSES_EXT_COLORS
symbols to curses.h to make
- it simpler to tell if the extended functions and/or colors
- are declared.
-
- adacurses-config
to the Ada95 install.
-
- -f
option to format spaces as
- \s
to prevent them from being lost when that
- is read back in unformatted strings.
-
- tack
program is now distributed separately
- from ncurses.
- Eterm-256color
,
- Eterm-88color
and
- rxvt-88color
- aterm
- konsole-256color
- mrxvt
- screen.mlterm
- screen.rxvt
- teraterm4.59
is now the primary primary
- teraterm entry, renamed original to
- teraterm2.3
- 9term
terminal
- gnome
to version 2.22.3
- h19
, z100
- konsole
to version 1.6.6
- mlterm
, mlterm+pcfkeys
- xterm
, and building-blocks for function-keys
- to xterm patch #230.
- konsole
terminfo entry).
-
- mk-1st.awk
so the generated makefile rules for
- linking or installing shared libraries do not first remove the
- library, in case it is in use, e.g., libncurses.so
by
- /bin/sh
.
-
- win_wchnstr()
to ensure that only a base cell
- is returned for each multi-column character.
-
- waddch()
and winsch()
handling of
- EILSEQ from mbrtowc()
by using unctrl()
- to display illegal bytes rather than trying to append further bytes
- to make up a valid sequence.
-
- curs_set()
state after
- endwin()
/refresh()
-
- keyname()
to use "^X" form only if
- meta()
has been called, or if keyname()
- is called without initializing curses, e.g., via
- initscr()
or newterm()
.
-
- unctrl()
to check codes in 128-255 range versus
- isprint()
.
- If they are not printable, and locale was set, use a "M-" or "~"
- sequence.
-
- resizeterm()
by moving ripped-off lines, and
- repainting the soft-keys.
-
- NCURSES_MOUSE_MASK()
in definition of
- BUTTON_RELEASE()
, etc., to make those work properly
- with the --enable-ext-mouse
configuration
-
- strndup
.
-
- MKlib_gen.sh
from '%' to '@', to
- avoid substitution by IBM xlc to '#' as part of its extensions to
- digraphs.
- wcrtomb()
, making it work on
- Solaris. This is used in the form library to determine the length
- of the buffer needed by field_buffer
.
- wresize()
allows you to resize windows, preserving
-their data.
-use_default_colors()
allows you to
-use the terminal's default colors for the default color pair,
-achieving the effect of transparent colors.
-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.
---enable-ext-colors
option.
-#undef
.
-- -The ncurses code has been tested with a wide variety of applications -including (versions starting with those noted): -
- -The ncurses distribution includes a selection of test programs (including -a few games). - -
-
-To join the ncurses mailing list, please write email to
-bug-ncurses-request@gnu.org
containing 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://invisible-island.net/ncurses/ . - -
- -You can find lots of information on terminal-related topics -not covered in the terminfo file at -Richard Shuford's -archive . - - - + + + +
+ + +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.org +containing 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:
+ +++ +http://lists.gnu.org/archive/html/bug-ncurses + (also https)
+
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 .
+ + + +