xref: /freebsd/contrib/ncurses/man/curs_printw.3x (revision b2d2a78ad80ec68d4a17f5aef97d21686cb1e29b)
***************************************************************************
Copyright 2018-2023,2024 Thomas E. Dickey *
Copyright 1998-2010,2017 Free Software Foundation, Inc. *
*
Permission is hereby granted, free of charge, to any person obtaining a *
copy of this software and associated documentation files (the *
"Software"), to deal in the Software without restriction, including *
without limitation the rights to use, copy, modify, merge, publish, *
distribute, distribute with modifications, sublicense, and/or sell *
copies of the Software, and to permit persons to whom the Software is *
furnished to do so, subject to the following conditions: *
*
The above copyright notice and this permission notice shall be included *
in all copies or substantial portions of the Software. *
*
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS *
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF *
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *
IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, *
DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR *
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *
THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
*
Except as contained in this notice, the name(s) of the above copyright *
holders shall not be used in advertising or otherwise to promote the *
sale, use or other dealings in this Software without prior written *
authorization. *
***************************************************************************

$Id: curs_printw.3x,v 1.53 2024/04/20 19:18:18 tom Exp $
curs_printw 3X 2024-04-20 "ncurses @NCURSES_MAJOR@.@NCURSES_MINOR@" "Library calls"
.\} .\} . ..
NAME
\%printw, \%wprintw, \%mvprintw, \%mvwprintw, \%vwprintw, \%vw_printw - write formatted output to a curses window
SYNOPSIS
#include <curses.h>

int printw(const char *fmt, ...); int wprintw(WINDOW *win, const char *fmt, ...); int mvprintw(int y, int x, const char *fmt, ...); int mvwprintw(WINDOW *win, int y, int x, const char *fmt, ...);

int vw_printw(WINDOW *win, const char *fmt, va_list varglist);

/* obsolete */ int vwprintw(WINDOW *win, const char *fmt, va_list varglist);

DESCRIPTION
\%printw, \%wprintw, \%mvprintw, and \%mvwprintw are analogous to \%printf(3). In effect, the string that would be output by \%printf(3) is instead output as though \%waddstr(3X) were used with win (or \%stdscr ) as its first argument.

\%vwprintw and \%vw_printw are analogous to \%vprintf(3), and perform a \%wprintw using a variable argument list. The third argument is a \%va_list, a pointer to a list of arguments, as defined in \%stdarg.h.

RETURN VALUE
These functions return ERR upon failure and OK upon success.

In \%ncurses , failure occurs if the library cannot allocate enough memory for the buffer into which the output is formatted, or if the window pointer win is null.

Functions prefixed with \*(``mv\*('' first perform cursor movement and fail if the position ( y , x ) is outside the window boundaries.

NOTES
No wide character counterpart functions are defined by the \*(``wide\*('' \%ncurses configuration nor by any standard. To format and write a wide-character string to a curses window, consider using \%swprintf(3) and \%waddwstr(3X) or similar.
PORTABILITY
X/Open Curses, Issue 4 describes these functions. It specifies no error conditions for them.

\%ncurses defines \%vw_printw and \%vwprintw identically to support legacy applications. However, the latter is obsolete. .bP X/Open Curses, Issue 4 Version 2 (1996), marked \%vwprintw as requiring \%varargs.h and \*(``TO BE WITHDRAWN\*('', and specified \%vw_printw using the \%stdarg.h interface. .bP X/Open Curses, Issue 5, Draft 2 (December 2007) marked vwprintw (along with vwscanw and the termcap interface) as withdrawn. After incorporating review comments, this became X/Open Curses, Issue 7 (2009). .bP \%ncurses provides \%vwprintw, but marks it as deprecated.

HISTORY
While \%printw was implemented in 4BSD (November 1980), https://minnie.tuhs.org/cgi-bin/utree.pl?file=4BSD/usr/src/lib/\
libcurses/printw.c
it was unused until 4.2BSD (August 1983), which employed it for games. That early version of curses preceded the ANSI C standard of 1989. It did not use \%varargs.h, though that had been available since Seventh Edition Unix (1979). https://minnie.tuhs.org/cgi-bin/utree.pl?file=V7/usr/include/\
varargs.h
In 1991 (a couple of years after SVr4 was generally available, and after the C standard was published), other developers updated the library, using \%stdarg.h internally in 4.4BSD curses . Even with this improvement, BSD curses did not use function prototypes (nor even declare functions) in \%curses.h until 1992.

SVr2 (1984) documented \%printw and \%wprintw tersely as \*(``printf on \%stdscr\*('' and \*(``printf on win\*('', respectively.

SVr3 (1987) added \%mvprintw and \%mvwprintw, with a three-line summary asserting that they were analogous to \%printf(3), explaining that the string that \%printf(3) would write to the standard output stream would instead be output using \%waddstr to the given window. SVr3 also implemented \%vwprintw, describing its third parameter as a \%va_list, defined in \%varargs.h, and referred the reader to the manual pages for \%varargs and \%vprintf for detailed descriptions.

SVr4 (1989) introduced no new variations of \%printw, but provided for using either \%varargs.h or \%stdarg.h to define the \%va_list type. either header declares "va_list", but only one can be used

X/Open Curses, Issue 4 (1995), defined \%vw_printw to replace \%vwprintw, stating that its \%va_list type is defined in \%stdarg.h.

SEE ALSO
\%curses(3X), \%curs_addstr(3X), \%curs_scanw(3X), \%printf(3), \%vprintf(3)