PDCurses 3.0 - 2007-04-01
The focuses for this release are X/Open conformance, i18n, better color
support, cleaner code, and more consistency across platforms.
This is only a brief summary of the changes. For more details, consult
the CVS log.
New features:
-
An almost complete implementation of X/Open curses, including the
wide-character and attr_t functions (but excluding terminfo). The
wide-character functions work only in Win32 and X11, for now, and
require building the library with the appropriate options (see
INSTALL). Note that this is a simplistic implementation, with exactly
one wchar_t per cchar_t; the only characters it handles properly are
those that are one column wide. -
Support for X Input Methods in the X11 port (see INSTALL). When built
this way, the internal compose key support is disabled in favor of
XIM's, which is a lot more complete, although you lose the box cursor. -
Multibyte character support in the non-wide string handling functions,
per X/Open. This only works when the library is built with wide-
character support enabled. -
Mouse support for DOS and OS/2. The DOS version includes untested
support for scroll wheels, via the "CuteMouse" driver. -
An ncurses-compatible mouse interface, which can work in parallel with
the traditional PDCurses mouse interface. See the man page (or
mouse.c) for details. -
DOS and OS/2 can now return modifiers as keys, as in Win32 and X11.
-
COLORS, which had been fixed at 8, is now either 8 or 16, depending on
the terminal -- usually 16. When it's 8, blinking mode is enabled
(controlled as before by the A_BLINK attribute); when it's 16, bright
background colors are used instead. On platforms where it can be
changed, the mode is toggled by the new function PDC_set_blink().
PDCurses tries to set PDC_set_blink(FALSE) at startup. (In Win32, it's
always set to FALSE; in DOS, with other than an EGA or VGA card, it
can't be.) Also, COLORS is now set to 0 until start_color() is called. -
Corresponding to the change in COLORS, COLOR_PAIRS is now 256.
-
Working init_color() and color_content(). The OS/2 version of
init_color() works only in a full-screen session; the Win32 version
works only in windowed mode, and only in NT-family OSes; the DOS
version works only with VGA adapters (real or simulated). The Win32
version is based mostly on James Brown's setconsoleinfo.c
(www.catch22.net). -
use_default_colors(), assume_default_colors(), and curses_version(),
after ncurses. -
Added global int TABSIZE, after ncurses and Solaris curses; removed
window-specific _tabsize. -
Logical extension to the wide-character slk_ funcs: slk_wlabel(), for
retrieving the label as a wide-character string. -
A non-macro implementation of ncurses' wresize().
-
Working putwin(), getwin(), scr_dump() and scr_restore().
-
A working acs_map[]. Characters from the ACS are now stored in window
structures as a regular character plus the A_ALTCHARSET attribute, and
rendered to the ACS only when displayed. (This allows, for example,
the correct display on one platform of windows saved from another.) -
In X11, allow selection and paste of UTF8_STRING.
-
The testcurs demo now includes a color chart and init_color() test, a
wide character input test, a display of wide ACS characters with
sample Unicode text, a specific test of flash(), more info in the
resize test, and attempts to change the width as well as the height. -
Command-line option for MSVC to build DLLs (see INSTALL). Also, the
naming distinction for DLLs ("curses" vs. "pdcurses") is abandoned,
and either the static lib or DLL is built, not both at once (except
for X11). -
For backwards compatibility, a special module just for deprecated
functions -- currently PDC_check_bios_key(), PDC_get_bios_key(),
PDC_get_ctrl_break() and PDC_set_ctrl_break(). These shouldn't be used
in applications, but currently are... in fact, all the "private"
functions (in curspriv.h) are subject to change and should be avoided. -
A new document, IMPLEMNT, describing PDCurses' internal functions for
those wishing to port it to new platforms. -
Mark Hessling has released the X11 port to the public domain.
(However, x11/ScrollBox* retain their separate copyright and MIT-like
license.)
Bug fixes and such:
-
Most of the macros have been removed (along with the NOMACROS ifdef).
The only remaining ones are those which have to be macros to work, and
those that are required by X/Open to be macros. There were numerous
problems with the macros, and no apparent reason to keep them, except
tradition -- although it was PCcurses 1.x that first omitted them. -
Clean separation of platform-specific code from the rest. Outside of
the platform directories, there remain only a few ifdefs in curses.h
and curspriv.h. -
General reorganization and simplification.
-
Documentation revisions.
-
When expanding control characters in addch() or insch(), retain the
attributes from the chtype. -
Preserve the A_ALTCHARSET attribute in addch() and insch().
-
Per X/Open, beep() should always return OK.
-
On platforms with a controlling terminal (i.e., not X11), curs_set(1)
now sets the cursor to the shape it had at the time of initscr(),
rather than always making it small. (Exception for DOS: If the video
mode has been changed by PDC_resize_screen(), curs_set(1) reverts to
line 6/7.) The shape is taken from SP->orig_cursor (the meaning of
which is platform-specific). -
Stop updating the cursor position when the cursor is invisible (this
gives a huge performance boost in Win 9x); update the cursor position
from curs_set() if changing from invisible to visible. -
Some tweaking of the behavior of def_prog_mode(), def_shell_mode(),
savetty(), reset_prog_mode(), reset_shell_mode() and resetty()...
still not quite right. -
flash() was not implemented for Win32 or X. A portable implementation
is now used for all platforms. Note that it's much slower than the
old (DOS and OS/2) version, but this is only apparent on an extremely
slow machine, such as an XT. -
In getstr(), backspacing on high-bit characters caused a double
backspace. -
hline() and vline() used an incorrect (off by one) interpretation of
_maxx and _maxy. If values of n greater than the max were specified,
these functions could access unallocated memory. -
innstr() is supposed to return the number of characters read, not just
OK or ERR. Reported by Mike Aubury. -
A proper implementation of insch() -- the PDC_chadd()-based version
wasn't handling the control characters correctly. -
Return ASCII and control key names from keyname() (problem revealed by
ncurses' movewindow test); also, per X/Open, return "UNKNOWN KEY" when
appropriate, rather than "NO KEY NAME". -
Turn off the cursor from leaveok(TRUE), even in X11; leaveok(FALSE)
now calls curs_set(1), regardless of the previous state of the cursor. -
In the slk area, BUTTON_CLICKED events now translate to function keys,
along with the previously recognized BUTTON_PRESSED events. Of course,
it should really be checking the events specified by map_button(),
which still doesn't work. -
napms(0) now returns immediately.
-
A unified napms() implementation for DOS -- no longer throttles the
CPU when built with any compiler. -
Allow backspace editing of the nocbreak() buffer.
-
pair_content(0, ...) is valid.
-
There was no check to ensure that the pnoutrefresh() window fit within
the screen. It now returns an ERR if it doesn't. -
In X11, resize_term() must be called with parameters (0, 0), and only
when SP->resized is set, else it returns ERR. -
Copy _bkgd in resize_window(). Patch found on Frederic L. W. Meunier's
web site. -
slk_clear() now removes the buttons completely, as in ncurses.
-
Use the current foreground color for the line attributes (underline,
left, right), unless PDC_set_line_color() is explicitly called. After
setting the line color, you can reset it to this mode via
"PDC_set_line_color(-1)". -
Removed non-macro implementations of COLOR_PAIR() and PAIR_NUMBER().
-
Dispensed with PDC_chadd() and PDC_chins() -- waddch() and winsch()
are now (again) the core functions. -
Dropped or made static many obsolete, unused, and/or broken functions,
including PDC_chg_attrs(), PDC_cursor_on() and _off(),
PDC_fix_cursor(), PDC_get_attribute(), PDC_get_cur_col() and _row(),
PDC_set_80x25(), PDC_set_cursor_mode(), PDC_set_rows(),
PDC_wunderline(), PDC_wleftline(), PDC_wrightline(),
XCursesModifierPress() and XCurses_refresh_scrollbar(). -
Obsolete/unused defines: _BCHAR, _GOCHAR, _STOPCHAR, _PRINTCHAR
_ENDLINE, _FULLWIN and _SCROLLWIN. -
Obsolete/unused elements of the WINDOW struct: _pmax*, _lastp*,
_lasts*. -
Obsolete/unused elements of the SCREEN struct: orgcbr, visible_cursor,
sizeable, shell, blank, cursor, orig_emulation, font, orig_font,
tahead, adapter, scrnmode, kbdinfo, direct_video, video_page,
video_seg, video_ofs, bogus_adapter. (Some of these persist outside
the SCREEN struct, in the platform directories.) Added mouse_wait and
key_code. -
Removed all the EMALLOC stuff. Straight malloc calls were used
elsewhere; it was undocumented outside of comments in curspriv.h; and
there are better ways to use a substitute malloc(). -
Single mouse clicks are now reportable on all platforms (not just
double-clicks). And in general, mouse event reporting is more
consistent across platforms. -
The mouse cursor no longer appears in full-screen mode in Win32 unless
a nonzero mouse event mask is used. -
ALT-keypad input now works in Win32.
-
In Win32, SetConsoleMode(ENABLE_WINDOW_INPUT) is not useful, and
appears to be the source of a four-year-old bug report (hanging in
THE) by Phil Smith. -
Removed the PDC_THREAD_BUILD stuff, which has never worked. For the
record: PDCurses is not thread-safe. Neither is ncurses; and the
X/Open curses spec explicitly makes it a non-requirement. -
With the internal compose key system in the X11 port, modifier keys
were breaking out of the compose state, making it impossible to type
accented capitals, etc. Also, Multi_key is now the default compose
key, instead of leaving it undefined by default; and a few more combos
are supported. -
In X11, the first reported mouse event after startup always read as a
double-click at position 0, 0. (This bug was introduced in 2.8.) -
In X11, don't return selection start as a press event. (Shift-click on
button 1 is still returned.) -
In X11, properly handle pasting of high-bit chars. (It was doing an
unwanted sign extension.) -
In X11, BUTTON_MOVED was never returned, although PDC_MOUSE_MOVED was
set. -
The fix in 2.8 for the scroll wheel in X11 wasn't very good -- it did
report the events as scroll wheel events, but it doubled them. Here's
a proper fix. -
Changed mouse handling in X11: Simpler translation table, with
XCursesPasteSelection() called from XCursesButton() instead of the
translation table; require shift with button 1 or 2 for select or
paste when mouse events are being reported (as with ncurses), allowing
passthrough of simple button 2 events. This fixes the previously
unreliable button 2 behavior. -
Modifier keys are now returned on key up in X11, as in Win32. And in
general, modifier key reporting is more consistent across platforms. -
Modifiers are not returned as keys when a mouse click has occurred
since the key press. -
In BIOS mode (in DOS), count successive identical output bytes, and
make only one BIOS call for all of them. This dramatically improves
performance. -
The cursor position was not always updated correctly in BIOS mode.
-
In testcurs, the way the ACS test was written, it would really only
work with a) PDCurses (with any compiler), or b) gcc (with any
curses). Here's a more portable implementation. -
Better reporting of mouse events in testcurs.
-
Blank out buffer and num before the scanw() test in testcurs, in case
the user just hits enter or etc.; clear the screen after resizing. -
Allow tuidemo to use the last line.
-
Separate left/right modifier keys are now reported properly in Win32.
(Everything was being reported as _R.) -
Attempts to redirect input in Win32 now cause program exit and an
error message, instead of hanging. -
Dropped support for the Microway NDP compiler.
-
Some modules renamed, rearranged.
-
Fixes for errors and warnings when building with Visual C++ 2005.
-
In MSVC, the panel library didn't work with the DLL.
-
Complete export lists for DLLs.
-
Simplified makefiles; moved common elements to .mif files; better
optimization; strip demos when possible. -
Changed makefile targets of "pdcurses.a/lib" and "panel.a/lib" to
$(LIBCURSES) and $ (LIBPANEL). Suggestion of Doug Kaufman. -
Changed "install" target in the makefile to a double-colon rule, to
get around a conflict with INSTALL on non-case-sensitive filesystems,
such as Mac OS X's HFS+. Reported by Douglas Godfrey et al. -
Make PDCurses.man dependent on manext. Suggestion of Tiziano Mueller.
-
Set up configure.ac so autoheader works; removed some obsolescent
macros. Partly the suggestion of T.M. -
The X11 port now builds in the x11 directory (including the demos), as
with other ports. -
The X11 port should now build on more 64-bit systems. Partly due to
M.H. -
The default window title and icons for the X11 port are now "PDCurses"
instead of "XCurses". -
Internal functions and variables made static where possible.
-
Adopted a somewhat more consistent naming style: Internal functions
with external linkage, and only those, have the prefix "PDC_";
external variables that aren't part of the API use "pdc_"; static
functions use ""; and "XC" and "xc_" prefixes are used for functions
and variables, respectively, that are shared between both processes in
the X11 port. Also eliminated camel casing, where possible. -
Changed the encoding for non-ASCII characters in comments and
documentation from Latin-1 to UTF-8.