| 
 |  | 
#include <term.h>int putp(const char *str);
int tputs(const char *str, int affcnt, int (*putfunc)(int));
The putp(3curses) function is equivalent to tputs(str, 1, putchar). The output of putp(3curses) always goes to stdout, not to the fildes specified in setupterm(3curses).
The tputs(3curses) function outputs str to the terminal. The str argument must be a terminfo string variable or the return value from tgetstr(3curses), tgoto(3curses), tigetstr(3curses) or tparm(3curses). The affcnt argument is the number of lines affected, or 1 if not applicable. If the terminfo database indicates that the terminal in use requires padding after any command in the generated string, tputs(3curses) inserts pad characters into the string that is sent to the terminal, at positions indicated by the terminfo database. The tputs(3curses) function outputs each character of the generated string by calling the user-supplied function putfunc (see below).
The user-supplied function putfunc (specified as an argument to tputs(3curses)) is either putchar(3S) or some other function with the same prototype. The tputs(3curses) function ignores the return value of putfunc.
After use of any of these functions, the model Curses maintains of the state of the terminal might not match the actual state of the terminal. The application should touch and refresh the window before resuming conventional use of Curses.