]> ncurses.scripts.mit.edu Git - ncurses.git/blob - ANNOUNCE
ncurses 5.7 - patch 20091107
[ncurses.git] / ANNOUNCE
1                             Announcing ncurses 5.7
2
3    The  ncurses  (new  curses)  library  is  a free software emulation of
4    curses  in  System  V  Release 4.0, and more. It uses terminfo format,
5    supports  pads  and color and multiple highlights and forms characters
6    and   function-key   mapping,   and  has  all  the  other  SYSV-curses
7    enhancements over BSD curses.
8
9    In  mid-June  1995,  the  maintainer of 4.4BSD curses declared that he
10    considered  4.4BSD curses obsolete, and encouraged the keepers of Unix
11    releases such as BSD/OS, FreeBSD and NetBSD to switch over to ncurses.
12
13    The ncurses code was developed under GNU/Linux. It has been in use for
14    some  time  with  OpenBSD as the system curses library, and on FreeBSD
15    and  NetBSD  as  an  external  package.  It  should port easily to any
16    ANSI/POSIX-conforming UNIX. It has even been ported to OS/2 Warp!
17
18    The distribution includes the library and support utilities, including
19    a   terminfo  compiler  tic(1),  a  decompiler  infocmp(1),  clear(1),
20    tput(1),  tset(1),  and  a  termcap conversion tool captoinfo(1). Full
21    manual pages are provided for the library and tools.
22
23    The  ncurses  distribution  is  available via anonymous FTP at the GNU
24    distribution site [1]ftp://ftp.gnu.org/gnu/ncurses/ .
25    It is also available at [2]ftp://invisible-island.net/ncurses/ .
26
27                                  Release Notes
28
29    This  release  is  designed  to  be upward compatible from ncurses 5.0
30    through   5.6;  very  few  applications  will  require  recompilation,
31    depending   on  the  platform.  These  are  the  highlights  from  the
32    change-log since ncurses 5.6 release.
33
34    Interface changes:
35      * generate linkable stubs for some macros:
36        getattrs
37
38    New features and improvements:
39      * library
40           + new  flavor  of  the  ncurses  library  provides  rudimentary
41             support  for  POSIX threads. Several functions are reentrant,
42             but most require either a window-level or screen-level mutex.
43             (This  is  API-compatible,  but  not  ABI-compatible with the
44             normal library).
45           + add  NCURSES_OPAQUE  symbol  to  curses.h,  will  use to make
46             structs opaque in selected configurations.
47           + add   NCURSES_EXT_FUNCS  and  NCURSES_EXT_COLORS  symbols  to
48             curses.h to make it simpler to tell if the extended functions
49             and/or colors are declared.
50           + add wresize() to C++ binding
51           + eliminate fixed-buffer vsprintf() calls in C++ binding.
52           + add  several  functions to C++ binding which wrap C functions
53             that pass a WINDOW* parameter.
54           + adapt mouse-handling code from menu library in form-library
55           + improve  tracing  for  form  library,  showing created forms,
56             fields, etc.
57           + make $NCURSES_NO_PADDING feature work for termcap interface .
58           + add  check  to  trace-file  open,  if  the  given  name  is a
59             directory, add ".log" to the name and try again.
60           + several   new   manpages:  curs_legacy.3x,  curs_memleaks.3x,
61             curs_opaque.3x and curs_threads.3x
62      * programs:
63           + modified  three  test-programs  to  demonstrate the threading
64             support in this version: ditto, rain, worm.
65           + several    new    test-programs:   demo_panels,   dots_mvcur,
66             inch_wide,    inchs,    key_name,    key_names,   savescreen,
67             savescreen.sh    test_arrays,   test_get_wstr,   test_getstr,
68             test_instr, test_inwstr and test_opaque.
69           + add adacurses-config to the Ada95 install.
70           + modify  tic  -f option to format spaces as \s to prevent them
71             from  being  lost  when  that  is  read  back  in unformatted
72             strings.
73           + The tack program is now distributed separately from ncurses.
74      * terminal database
75           + added entries:
76                o Eterm-256color, Eterm-88color and rxvt-88color
77                o aterm
78                o konsole-256color
79                o mrxvt
80                o screen.mlterm
81                o screen.rxvt
82                o teraterm4.59  is now the primary primary teraterm entry,
83                  renamed original to teraterm2.3
84                o 9term terminal
85                o Newbury Data entries
86           + updated/improved entries:
87                o gnome to version 2.22.3
88                o h19, z100
89                o konsole to version 1.6.6
90                o mlterm, mlterm+pcfkeys
91                o xterm, and building-blocks for function-keys to [3]xterm
92                  patch #230.
93
94    Major bug fixes:
95      * add   logic   to   tic  for  cancelling  strings  in  user-defined
96        capabilities (this is needed for current konsole terminfo entry).
97      * modify  mk-1st.awk  so the generated makefile rules for linking or
98        installing  shared  libraries  do not first remove the library, in
99        case it is in use, e.g., libncurses.so by /bin/sh.
100      * correct check for notimeout() in wgetch().
101      * fix a sign-extension bug in infocmp's repair_acsc() function.
102      * change winnstr() to stop at the end of the line.
103      * make Ada95 demo_panels() example work.
104      * fix for adding a non-spacing character at the beginning of a line.
105      * fill   in   extended-color   pair   to   make   colors   work  for
106        wide-characters using extended-colors.
107      * improve  refresh  of  window  on  top  of multi-column characters,
108        taking   into   account  split  characters  on  left/right  window
109        boundaries.
110      * modify  win_wchnstr()  to ensure that only a base cell is returned
111        for each multi-column character.
112      * improve waddch() and winsch() handling of EILSEQ from mbrtowc() by
113        using  unctrl()  to  display  illegal  bytes rather than trying to
114        append further bytes to make up a valid sequence.
115      * restore curs_set() state after endwin()/refresh()
116      * modify  keyname() to use "^X" form only if meta() has been called,
117        or  if  keyname() is called without initializing curses, e.g., via
118        initscr() or newterm().
119      * modify  unctrl() to check codes in 128-255 range versus isprint().
120        If  they  are not printable, and locale was set, use a "M-" or "~"
121        sequence.
122      * improve  resizeterm()  by  moving ripped-off lines, and repainting
123        the soft-keys.
124      * modify  form  library to accept control characters such as newline
125        in set_field_buffer(), which is compatible with Solaris.
126      * use  NCURSES_MOUSE_MASK() in definition of BUTTON_RELEASE(), etc.,
127        to   make   those   work   properly  with  the  --enable-ext-mouse
128        configuration
129      * correct  some  functions  in Ada95 binding which were using return
130        value from C where none was returned.
131      * reviewed/fixed issues reported by Coverity and Klocwork tools.
132
133    Portability:
134      * configure script:
135           + new options:
136
137               --disable-big-strings
138                       control  whether static string tables are generated
139                       as   single   large  strings  (to  improve  startup
140                       performance), or as array of individual strings.
141
142               --disable-relink
143                       control   whether  shared  libraries  are  relinked
144                       (during install) when rpath is enabled.
145
146               --disable-tic-depends
147                       make   explicit  whether  tic  library  depends  on
148                       ncurses/ncursesw library.
149
150               --enable-mixed-case
151                       override   the  configure  script's  check  if  the
152                       filesystem   supports  mixed-case  filenames.  This
153                       allows  one  to  control  how the terminal database
154                       maps to the filesystem. For filesystems that do not
155                       support   mixed-case,  the  library  uses  generate
156                       2-character (hexadecimal) codes for the lower-level
157                       of the filesystem terminfo database
158
159               --enable-reentrant
160                       builds  a  different  flavor of the ncurses library
161                       (ncursest)  which  improves  reentrant  use  of the
162                       library  by  reducing  global  and static variables
163                       (see  the  "--with-pthread" option for the threaded
164                       support).
165
166               --enable-weak-symbols
167                       use  weak-symbols  for  linking to the POSIX thread
168                       library,  and  use  the same soname for the ncurses
169                       shared  library  as the normal library (caveat: the
170                       ABI is for the threaded library, which makes global
171                       data accessed via functions).
172
173               --with-pthread
174                       build  with  the  POSIX thread library (tested with
175                       AIX,   Linux,   FreeBSD,   OpenBSD,  HPUX,  IRIX64,
176                       Solaris, Tru64).
177
178               --with-ticlib
179                       build/install   the   tic-support  functions  in  a
180                       separate library
181
182           + improved options:
183
184               --enable-ext-colors
185                       requires the wide-character configuration.
186
187               --with-chtype
188                       ignore  option  value "unsigned" is always added to
189                       the   type   in   curses.h;   do   the   same   for
190                       --with-mmask-t.
191
192               --with-dmalloc
193                       build-fix for redefinition of strndup.
194
195               --with-hashed-db
196                       accepts  a parameter which is the install-prefix of
197                       a given Berkeley Database.
198
199               --with-hashed-db
200                       the $LIBS environment variable overrides the search
201                       for the db library.
202
203               --without-hashed-db
204                       assumed when "--disable-database" is used.
205
206      * other configure/build issues:
207           + build-fixes for LynxOS
208           + modify  shared-library  rules  to  allow  FreeBSD  3.x to use
209             rpath.
210           + build-fix for FreeBSD "contemporary" TTY interface.
211           + build-fixes for AIX with libtool.
212           + build-fixes for Darwin and libtool.
213           + modify BeOS-specific ifdef's to build on Haiku.
214           + corrected  gcc  options  for  building  shared  libraries  on
215             Solaris and IRIX64.
216           + change  shared-library  configuration for OpenBSD, make rpath
217             work.
218           + build-fixes for using libutf8, e.g., on OpenBSD 3.7
219           + add   "-e"  option  in  ncurses/Makefile.in  when  generating
220             source-files  to  force earlier exit if the build environment
221             fails unexpectedly.
222           + add support for shared libraries for QNX.
223           + change  delimiter  in  MKlib_gen.sh from '%' to '@', to avoid
224             substitution  by  IBM xlc to '#' as part of its extensions to
225             digraphs.
226      * library:
227           + rewrite  wrapper  for  wcrtomb(),  making it work on Solaris.
228             This  is  used in the form library to determine the length of
229             the buffer needed by field_buffer.
230           + add/use  configure  script  macro  CF_SIG_ATOMIC_T,  use  the
231             corresponding type for data manipulated by signal handlers.
232           + set locale in misc/ncurses-config.in since it uses a range
233           + disable  GPM  mouse  support  when  $TERM  does not happen to
234             contain  "linux",  since  Gpm_Open()  no  longer  limits  its
235             assertion  to  terminals  that  it might handle, e.g., within
236             "screen" in xterm.
237           + reset mouse file-descriptor when unloading GPM library.
238      * test programs:
239           + update  test  programs to build/work with various UNIX curses
240             for comparisons.
241
242                               Features of Ncurses
243
244    The ncurses package is fully compatible with SVr4 (System V Release 4)
245    curses:
246      * All  257  of  the  SVr4  calls  have  been  implemented  (and  are
247        documented).
248      * Full  support for SVr4 curses features including keyboard mapping,
249        color,   forms-drawing   with   ACS   characters,   and  automatic
250        recognition of keypad and function keys.
251      * An  emulation  of  the  SVr4 panels library, supporting a stack of
252        windows with backing store, is included.
253      * An  emulation  of the SVr4 menus library, supporting a uniform but
254        flexible interface for menu programming, is included.
255      * An  emulation of the SVr4 form library, supporting data collection
256        through on-screen forms, is included.
257      * Binary   terminfo   entries   generated   by  the  ncurses  tic(1)
258        implementation  are  bit-for-bit-compatible  with the entry format
259        SVr4 curses uses.
260      * The utilities have options to allow you to filter terminfo entries
261        for  use  with  less  capable curses/terminfo versions such as the
262        HP/UX and AIX ports.
263
264    The ncurses package also has many useful extensions over SVr4:
265      * The  API  is 8-bit clean and base-level conformant with the X/OPEN
266        curses  specification, XSI curses (that is, it implements all BASE
267        level  features,  and  most  EXTENDED  features). It includes many
268        function calls not supported under SVr4 curses (but portability of
269        all calls is documented so you can use the SVr4 subset only).
270      * Unlike  SVr3 curses, ncurses can write to the rightmost-bottommost
271        corner  of  the  screen  if  your terminal has an insert-character
272        capability.
273      * Ada95 and C++ bindings.
274      * Support  for mouse event reporting with X Window xterm and FreeBSD
275        and OS/2 console windows.
276      * Extended mouse support via Alessandro Rubini's gpm package.
277      * The  function  wresize()  allows you to resize windows, preserving
278        their data.
279      * The function use_default_colors() allows you to use the terminal's
280        default colors for the default color pair, achieving the effect of
281        transparent colors.
282      * The functions keyok() and define_key() allow you to better control
283        the  use  of function keys, e.g., disabling the ncurses KEY_MOUSE,
284        or  by  defining  more than one control sequence to map to a given
285        key code.
286      * Support  for  256-color  terminals,  such  as  modern  xterm, when
287        configured using the --enable-ext-colors option.
288      * Support for 16-color terminals, such as aixterm and modern xterm.
289      * Better  cursor-movement  optimization.  The package now features a
290        cursor-local-movement computation more efficient than either BSD's
291        or System V's.
292      * Super   hardware   scrolling   support.   The  screen-update  code
293        incorporates  a novel, simple, and cheap algorithm that enables it
294        to  make  optimal  use  of hardware scrolling, line-insertion, and
295        line-deletion  for  screen-line  movements. This algorithm is more
296        powerful than the 4.4BSD curses quickch() routine.
297      * Real  support  for  terminals  with  the  magic-cookie glitch. The
298        screen-update  code  will  refrain from drawing a highlight if the
299        magic-   cookie  unattributed  spaces  required  just  before  the
300        beginning  and  after the end would step on a non-space character.
301        It  will  automatically  shift  highlight boundaries when doing so
302        would  make it possible to draw the highlight without changing the
303        visual appearance of the screen.
304      * It  is  possible to generate the library with a list of pre-loaded
305        fallback  entries linked to it so that it can serve those terminal
306        types  even  when  no  terminfo tree or termcap file is accessible
307        (this  may  be useful for support of screen-oriented programs that
308        must run in single-user mode).
309      * The tic(1)/captoinfo utility provided with ncurses has the ability
310        to  translate many termcaps from the XENIX, IBM and AT&T extension
311        sets.
312      * A BSD-like tset(1) utility is provided.
313      * The ncurses library and utilities will automatically read terminfo
314        entries  from  $HOME/.terminfo  if  it exists, and compile to that
315        directory  if  it  exists  and the user has no write access to the
316        system  directory.  This feature makes it easier for users to have
317        personal  terminfo  entries without giving up access to the system
318        terminfo directory.
319      * You  may  specify  a  path  of  directories to search for compiled
320        descriptions  with  the  environment  variable TERMINFO_DIRS (this
321        generalizes  the  feature  provided by TERMINFO under stock System
322        V.)
323      * In  terminfo  source files, use capabilities may refer not just to
324        other entries in the same source file (as in System V) but also to
325        compiled  entries  in  either the system terminfo directory or the
326        user's $HOME/.terminfo directory.
327      * A  script  (capconvert)  is  provided to help BSD users transition
328        from  termcap to terminfo. It gathers the information in a TERMCAP
329        environment  variable  and/or  a ~/.termcap local entries file and
330        converts   it   to   an   equivalent  local  terminfo  tree  under
331        $HOME/.terminfo.
332      * Automatic  fallback  to  the  /etc/termcap file can be compiled in
333        when  it is not possible to build a terminfo tree. This feature is
334        neither  fast  nor cheap, you don't want to use it unless you have
335        to, but it's there.
336      * The  table-of-entries  utility  toe makes it easy for users to see
337        exactly what terminal types are available on the system.
338      * The library meets the XSI requirement that every macro entry point
339        have  a  corresponding  function  which may be linked (and will be
340        prototype-checked)  if  the  macro  definition  is  disabled  with
341        #undef.
342      * An  HTML  "Introduction  to  Programming  with  NCURSES"  document
343        provides  a  narrative  introduction  to  the  curses  programming
344        interface.
345
346                              State of the Package
347
348    Numerous bugs present in earlier versions have been fixed; the library
349    is  far  more  reliable  than  it  used to be. Bounds checking in many
350    `dangerous'  entry points has been improved. The code is now type-safe
351    according  to gcc -Wall. The library has been checked for malloc leaks
352    and arena corruption by the Purify memory-allocation tester.
353
354    The  ncurses  code has been tested with a wide variety of applications
355    including (versions starting with those noted):
356
357    cdk
358           Curses Development Kit
359           [4]http://invisible-island.net/cdk/
360           [5]http://www.vexus.ca/products/CDK/
361
362    ded
363           directory-editor
364           [6]http://invisible-island.net/ded/
365
366    dialog
367           the  underlying  application used in Slackware's setup, and the
368           basis for similar applications on GNU/Linux.
369           [7]http://invisible-island.net/dialog/
370
371    lynx
372           the character-screen WWW browser
373           [8]http://lynx.isc.org/release/
374
375    Midnight Commander
376           file manager
377           [9]http://www.ibiblio.org/mc/
378
379    mutt
380           mail utility
381           [10]http://www.mutt.org/
382
383    ncftp
384           file-transfer utility
385           [11]http://www.ncftp.com/
386
387    nvi
388           New vi versions 1.50 are able to use ncurses versions 1.9.7 and
389           later.
390           [12]http://www.bostic.com/vi/
391
392    pinfo
393           Lynx-like info browser.
394           [13]https://alioth.debian.org/projects/pinfo/
395
396    tin
397           newsreader, supporting color, MIME [14]http://www.tin.org/
398
399    as well as some that use ncurses for the terminfo support alone:
400
401    minicom
402           terminal emulator
403           [15]http://alioth.debian.org/projects/minicom/
404
405    vile
406           vi-like-emacs
407           [16]http://invisible-island.net/vile/
408
409    The  ncurses  distribution  includes  a  selection  of  test  programs
410    (including a few games).
411
412 Who's Who and What's What
413
414    Zeyd  Ben-Halim started it from a previous package pcurses, written by
415    Pavel  Curtis.  Eric  S. Raymond continued development. Jürgen Pfeifer
416    wrote  most of the form and menu libraries. Ongoing work is being done
417    by  [17]Thomas  Dickey.  Thomas  Dickey acts as the maintainer for the
418    Free  Software  Foundation,  which  holds  the  copyright  on ncurses.
419    Contact the current maintainers at [18]bug-ncurses@gnu.org.
420
421    To   join   the   ncurses   mailing   list,   please  write  email  to
422    bug-ncurses-request@gnu.org containing the line:
423              subscribe <name>@<host.domain>
424
425    This list is open to anyone interested in helping with the development
426    and testing of this package.
427
428    Beta  versions  of ncurses and patches to the current release are made
429    available at [19]ftp://invisible-island.net/ncurses/ .
430
431 Future Plans
432
433      * Extended-level   XPG4   conformance,   with   internationalization
434        support.
435      * Ports to more systems, including DOS and Windows.
436
437    We  need  people to help with these projects. If you are interested in
438    working on them, please join the ncurses list.
439
440 Other Related Resources
441
442    The  distribution  provides  a  newer  version  of the terminfo-format
443    terminal description file once maintained by [20]Eric Raymond . Unlike
444    the  older  version, the termcap and terminfo data are provided in the
445    same  file,  and provides several user-definable extensions beyond the
446    X/Open specification.
447
448    You  can  find  lots  of  information  on  terminal-related topics not
449    covered in the terminfo file at [21]Richard Shuford's archive .
450
451 References
452
453    1. ftp://ftp.gnu.org/gnu/ncurses/
454    2. ftp://invisible-island.net/ncurses/
455    3. http://invisible-island.net/xterm/xterm.log.html#xterm_230
456    4. http://invisible-island.net/cdk/
457    5. http://www.vexus.ca/products/CDK/
458    6. http://invisible-island.net/ded/
459    7. http://invisible-island.net/dialog/
460    8. http://lynx.isc.org/release/
461    9. http://www.ibiblio.org/mc/
462   10. http://www.mutt.org/
463   11. http://www.ncftp.com/
464   12. http://www.bostic.com/vi/
465   13. https://alioth.debian.org/projects/pinfo/
466   14. http://www.tin.org/
467   15. http://alioth.debian.org/projects/minicom/
468   16. http://invisible-island.net/vile/
469   17. mailto:dickey@invisible-island.net
470   18. mailto:bug-ncurses@gnu.org
471   19. ftp://invisible-island.net/ncurses/
472   20. http://www.catb.org/~esr/terminfo/
473   21. http://www.cs.utk.edu/~shuford/terminal_index.html