Adds a single-byte character and rendition to a window and advances the cursor.
#include <curses.h>
int addch(const chtype ch);
int mvaddch(int y, int x, const chtype ch);
int mvwaddch(WINDOW *in, const chtype ch);
int waddch(WINDOW *win, const chtype ch);
The addch, waddch, mvaddch, and mvwaddch subroutines add a character to a window at the logical cursor location. After adding the character, curses advances the position of the cursor one character. At the right margin, an automatic new line is performed.
The addch subroutine adds the character to the stdscr at the current logical cursor location. To add a character to a user-defined window, use the waddch and mvwaddch subroutines. The mvaddch and mvwaddch subroutines move the logical cursor before adding a character.
If you add a character to the bottom of a scrolling region, curses automatically scrolls the region up one line from the bottom of the scrolling region if scrollok is enabled. If the character to add is a tab, new-line, or backspace character, curses moves the cursor appropriately in the window to reflect the addition. Tabs are set at every eighth column. If the character is a new-line, curses first uses the wclrtoeol subroutine to erase the current line from the logical cursor position to the end of the line before moving the cursor.
You can also use the addch subroutines to add control characters to a window. Control characters are drawn in the ^X notation.
Because the Char parameter is an integer, not a character, you can combine video attributes with a character by ORing them into the parameter. The video attributes are also set. With this capability you can copy text and video attributes from one location to another using the inch (inch, mvinch, mvwinch, or winch Subroutine) and addch subroutines.
ch | |
y | |
x | |
*win |
Upon successful completion, these subroutines return OK. Otherwise, they return ERR.
chtype x; x='H'; addch(x);
mvaddch(10, 5, 'x');
WINDOW *my_window; mvwaddch(my_window, 10, 5, 'x');
WINDOW *my_window; waddch(my_window, 'x');
waddch(my_window, 'x' | A_STANDOUT);
This allows 'x' to be highlighted, but leaves the rest of the window alone.
These subroutines are part of Base Operating System (BOS) Runtime.
The inch, winch, mvinch, or mvwinch (inch, mvinch, mvwinch, or winch Subroutine) subroutines, wclrtoeol (clrtoeol or wclrtoeol Subroutine) subroutine.
Curses Overview for Programming, List of Curses Subroutines, Manipulating Characters with Curses in AIX 5L Version 5.1 General Programming Concepts: Writing and Debugging Programs.