- implemented printw (formatted string output, a la printf)

- implemented hline/vline (part of wborder family)
- screen cursor now relocates at same time as window cursor when
  restoring after a non-wrapping function
pull/1/head
Dan Lynch 2006-05-22 17:03:41 +00:00
parent 84a493b88d
commit bef8874842
2 changed files with 217 additions and 77 deletions

View File

@ -103,6 +103,7 @@ static void _wputstr ( WINDOW *win, const char *str, int wrap, int n ) {
static void _restore_curs_pos ( WINDOW *win, struct cursor_pos *pos ){ static void _restore_curs_pos ( WINDOW *win, struct cursor_pos *pos ){
win->curs_y = pos->y; win->curs_y = pos->y;
win->curs_x = pos->x; win->curs_x = pos->x;
win->scr->movetoyx ( win->scr, win->curs_y, win->curs_x );
} }
/** /**
@ -285,6 +286,37 @@ WINDOW *newwin ( int nlines, int ncols, int begin_y, int begin_x ) {
return win; return win;
} }
struct printw_context {
struct printf_context ctx;
WINDOW *win;
};
static void _printw_handler ( struct printf_context *ctx, unsigned int c ) {
struct printw_context *wctx =
container_of ( ctx, struct printw_context, ctx );
_wputch( wctx->win, c | wctx->win->attrs, WRAP );
}
/**
* Print formatted output in a window
*
* @v *win subject window
* @v *fmt formatted string
* @v varglist argument list
* @ret rc return status code
*/
int vw_printw ( WINDOW *win, const char *fmt, va_list varglist ) {
struct printw_context wctx = {
.win = win,
.ctx = { .handler = _printw_handler, },
};
vcprintf ( &(wctx.ctx), fmt, varglist );
return OK;
}
/** /**
* Add a single-byte character and rendition to a window and advance * Add a single-byte character and rendition to a window and advance
* the cursor * the cursor
@ -373,7 +405,8 @@ int wattrset ( WINDOW *win, int attrs ) {
* @v *opts undefined (for future implementation) * @v *opts undefined (for future implementation)
* @ret rc return status cude * @ret rc return status cude
*/ */
int wattr_get ( WINDOW *win, attr_t *attrs, short *pair, void *opts ) { int wattr_get ( WINDOW *win, attr_t *attrs, short *pair,
void *opts __unused ) {
*attrs = win->attrs & A_ATTRIBUTES; *attrs = win->attrs & A_ATTRIBUTES;
*pair = (short)(( win->attrs & A_COLOR ) >> CPAIR_SHIFT); *pair = (short)(( win->attrs & A_COLOR ) >> CPAIR_SHIFT);
return OK; return OK;
@ -387,7 +420,8 @@ int wattr_get ( WINDOW *win, attr_t *attrs, short *pair, void *opts ) {
* @v *opts undefined (for future implementation) * @v *opts undefined (for future implementation)
* @ret rc return status code * @ret rc return status code
*/ */
int wattr_off ( WINDOW *win, attr_t attrs, void *opts ) { int wattr_off ( WINDOW *win, attr_t attrs,
void *opts __unused ) {
wattroff( win, attrs ); wattroff( win, attrs );
return OK; return OK;
} }
@ -400,7 +434,8 @@ int wattr_off ( WINDOW *win, attr_t attrs, void *opts ) {
* @v *opts undefined (for future implementation) * @v *opts undefined (for future implementation)
* @ret rc return status code * @ret rc return status code
*/ */
int wattr_on ( WINDOW *win, attr_t attrs, void *opts ) { int wattr_on ( WINDOW *win, attr_t attrs,
void *opts __unused ) {
wattron( win, attrs ); wattron( win, attrs );
return OK; return OK;
} }
@ -414,7 +449,8 @@ int wattr_on ( WINDOW *win, attr_t attrs, void *opts ) {
* @v *opts undefined (for future implementation) * @v *opts undefined (for future implementation)
* @ret rc return status code * @ret rc return status code
*/ */
int wattr_set ( WINDOW *win, attr_t attrs, short cpair, void *opts ) { int wattr_set ( WINDOW *win, attr_t attrs, short cpair,
void *opts __unused ) {
wattrset( win, attrs | ( ( (unsigned short)cpair ) << CPAIR_SHIFT ) ); wattrset( win, attrs | ( ( (unsigned short)cpair ) << CPAIR_SHIFT ) );
return OK; return OK;
} }
@ -472,9 +508,9 @@ int wclrtobot ( WINDOW *win ) {
struct cursor_pos pos; struct cursor_pos pos;
_store_curs_pos( win, &pos ); _store_curs_pos( win, &pos );
while ( win->curs_y + win->curs_x ) { do {
_wputch( win, (unsigned)' ', WRAP ); _wputch( win, (unsigned)' ', WRAP );
} } while ( win->curs_y + win->curs_x );
_restore_curs_pos( win, &pos ); _restore_curs_pos( win, &pos );
return OK; return OK;
@ -506,7 +542,8 @@ int wclrtoeol ( WINDOW *win ) {
* @v *opts undefined (for future implementation) * @v *opts undefined (for future implementation)
* @ret rc return status code * @ret rc return status code
*/ */
int wcolour_set ( WINDOW *win, short colour_pair_number, void *opts ) { int wcolour_set ( WINDOW *win, short colour_pair_number,
void *opts __unused ) {
if ( ( unsigned short )colour_pair_number > COLORS ) if ( ( unsigned short )colour_pair_number > COLORS )
return ERR; return ERR;
@ -544,3 +581,62 @@ int wdeleteln ( WINDOW *win ) {
wclrtoeol( win ); wclrtoeol( win );
return OK; return OK;
} }
/**
* Create a horizontal line in a window
*
* @v *win subject window
* @v ch rendition and character
* @v n max number of chars (wide) to render
* @ret rc return status code
*/
int whline ( WINDOW *win, chtype ch, int n ) {
struct cursor_pos pos;
_store_curs_pos ( win, &pos );
while ( ( win->curs_x - win->width ) && n-- ) {
_wputch ( win, ch, NOWRAP );
}
_restore_curs_pos ( win, &pos );
return OK;
}
/**
* Print formatted output to a window
*
* @v *win subject window
* @v *fmt formatted string
* @v ... string arguments
* @ret rc return status code
*/
int wprintw ( WINDOW *win, const char *fmt, ... ) {
va_list args;
int i;
va_start ( args, fmt );
i = vw_printw ( win, fmt, args );
va_end ( args );
return i;
}
/**
* Create a vertical line in a window
*
* @v *win subject window
* @v ch rendition and character
* @v n max number of lines to render
* @ret rc return status code
*/
int wvline ( WINDOW *win, chtype ch, int n ) {
struct cursor_pos pos;
_store_curs_pos ( win, &pos );
while ( ( win->curs_y - win->height ) && n-- ) {
_wputch ( win, ch, NOWRAP );
wmove( win, ++(win->curs_y), pos.x);
}
_restore_curs_pos ( win, &pos );
return OK;
}

View File

@ -314,21 +314,21 @@ extern int halfdelay ( int );
extern bool has_colors ( void ); extern bool has_colors ( void );
extern bool has_ic ( void ); extern bool has_ic ( void );
extern bool has_il ( void ); extern bool has_il ( void );
extern int hline ( chtype, int ); //extern int hline ( chtype, int );
extern void idcok ( WINDOW *, bool ); extern void idcok ( WINDOW *, bool );
extern int idlok ( WINDOW *, bool ); extern int idlok ( WINDOW *, bool );
extern void immedok ( WINDOW *, bool ); extern void immedok ( WINDOW *, bool );
extern chtype inch ( void ); /*extern chtype inch ( void );*/
extern int inchnstr ( chtype *, int ); /*extern int inchnstr ( chtype *, int );*/
extern int inchstr ( chtype * ); /*extern int inchstr ( chtype * );*/
extern WINDOW *initscr ( void ); extern WINDOW *initscr ( void );
extern int init_color ( short, short, short, short ); extern int init_color ( short, short, short, short );
extern int init_pair ( short, short, short ); extern int init_pair ( short, short, short );
extern int innstr ( char *, int ); //extern int innstr ( char *, int );
extern int insch ( chtype ); //extern int insch ( chtype );
extern int insnstr ( const char *, int ); //extern int insnstr ( const char *, int );
extern int insstr ( const char * ); //extern int insstr ( const char * );
extern int instr ( char * ); //extern int instr ( char * );
extern int intrflush ( WINDOW *, bool ); extern int intrflush ( WINDOW *, bool );
extern bool isendwin ( void ); extern bool isendwin ( void );
extern bool is_linetouched ( WINDOW *, int ); extern bool is_linetouched ( WINDOW *, int );
@ -351,18 +351,18 @@ extern int mvderwin ( WINDOW *, int, int );
extern int mvgetch ( int, int ); extern int mvgetch ( int, int );
extern int mvgetnstr ( int, int, char *, int ); extern int mvgetnstr ( int, int, char *, int );
extern int mvgetstr ( int, int, char * ); extern int mvgetstr ( int, int, char * );
extern int mvhline ( int, int, chtype, int ); //extern int mvhline ( int, int, chtype, int );
extern chtype mvinch ( int, int ); //extern chtype mvinch ( int, int );
extern int mvinchnstr ( int, int, chtype *, int ); /*extern int mvinchnstr ( int, int, chtype *, int );*/
extern int mvinchstr ( int, int, chtype * ); /*extern int mvinchstr ( int, int, chtype * );*/
extern int mvinnstr ( int, int, char *, int ); /*extern int mvinnstr ( int, int, char *, int );*/
extern int mvinsch ( int, int, chtype ); //extern int mvinsch ( int, int, chtype );
extern int mvinsnstr ( int, int, const char *, int ); //extern int mvinsnstr ( int, int, const char *, int );
extern int mvinsstr ( int, int, const char * ); //extern int mvinsstr ( int, int, const char * );
extern int mvinstr ( int, int, char * ); //extern int mvinstr ( int, int, char * );
extern int mvprintw ( int, int, char *, ... ); //extern int mvprintw ( int, int, char *, ... );
extern int mvscanw ( int, int, char *, ... ); extern int mvscanw ( int, int, char *, ... );
extern int mvvline ( int, int, chtype, int ); //extern int mvvline ( int, int, chtype, int );
/*extern int mvwaddch ( WINDOW *, int, int, const chtype );*/ /*extern int mvwaddch ( WINDOW *, int, int, const chtype );*/
/*extern int mvwaddchnstr ( WINDOW *, int, int, const chtype *, int );*/ /*extern int mvwaddchnstr ( WINDOW *, int, int, const chtype *, int );*/
/*extern int mvwaddchstr ( WINDOW *, int, int, const chtype * );*/ /*extern int mvwaddchstr ( WINDOW *, int, int, const chtype * );*/
@ -372,19 +372,19 @@ extern int mvvline ( int, int, chtype, int );
extern int mvwgetch ( WINDOW *, int, int ); extern int mvwgetch ( WINDOW *, int, int );
extern int mvwgetnstr ( WINDOW *, int, int, char *, int ); extern int mvwgetnstr ( WINDOW *, int, int, char *, int );
extern int mvwgetstr ( WINDOW *, int, int, char * ); extern int mvwgetstr ( WINDOW *, int, int, char * );
extern int mvwhline ( WINDOW *, int, int, chtype, int ); //extern int mvwhline ( WINDOW *, int, int, chtype, int );
extern int mvwin ( WINDOW *, int, int ); extern int mvwin ( WINDOW *, int, int );
extern chtype mvwinch ( WINDOW *, int, int ); //extern chtype mvwinch ( WINDOW *, int, int );
extern int mvwinchnstr ( WINDOW *, int, int, chtype *, int ); //extern int mvwinchnstr ( WINDOW *, int, int, chtype *, int );
extern int mvwinchstr ( WINDOW *, int, int, chtype * ); //extern int mvwinchstr ( WINDOW *, int, int, chtype * );
extern int mvwinnstr ( WINDOW *, int, int, char *, int ); //extern int mvwinnstr ( WINDOW *, int, int, char *, int );
extern int mvwinsch ( WINDOW *, int, int, chtype ); //extern int mvwinsch ( WINDOW *, int, int, chtype );
extern int mvwinsnstr ( WINDOW *, int, int, const char *, int ); //extern int mvwinsnstr ( WINDOW *, int, int, const char *, int );
extern int mvwinsstr ( WINDOW *, int, int, const char * ); //extern int mvwinsstr ( WINDOW *, int, int, const char * );
extern int mvwinstr ( WINDOW *, int, int, char * ); //extern int mvwinstr ( WINDOW *, int, int, char * );
extern int mvwprintw ( WINDOW *, int, int, char *, ... ); //extern int mvwprintw ( WINDOW *, int, int, char *, ... );
extern int mvwscanw ( WINDOW *, int, int, char *, ... ); extern int mvwscanw ( WINDOW *, int, int, char *, ... );
extern int mvwvline ( WINDOW *, int, int, chtype, int ); //extern int mvwvline ( WINDOW *, int, int, chtype, int );
extern int napms ( int ); extern int napms ( int );
extern WINDOW *newpad ( int, int ); extern WINDOW *newpad ( int, int );
extern WINDOW *newwin ( int, int, int, int ); extern WINDOW *newwin ( int, int, int, int );
@ -461,11 +461,11 @@ extern int vid_attr ( attr_t, short, void * );
extern int vidattr ( chtype ); extern int vidattr ( chtype );
extern int vid_puts ( attr_t, short, void *, int ( *) ( int) ); extern int vid_puts ( attr_t, short, void *, int ( *) ( int) );
extern int vidputs ( chtype, int ( *) ( int) ); extern int vidputs ( chtype, int ( *) ( int) );
extern int vline ( chtype, int ); //extern int vline ( chtype, int );
extern int vwprintw ( WINDOW *, char *, va_list * ); //extern int vwprintw ( WINDOW *, const char *, va_list );
extern int vw_printw ( WINDOW *, char *, va_list * ); extern int vw_printw ( WINDOW *, const char *, va_list );
extern int vwscanw ( WINDOW *, char *, va_list * ); extern int vwscanw ( WINDOW *, char *, va_list );
extern int vw_scanw ( WINDOW *, char *, va_list * ); extern int vw_scanw ( WINDOW *, char *, va_list );
extern int waddch ( WINDOW *, const chtype ); extern int waddch ( WINDOW *, const chtype );
extern int waddchnstr ( WINDOW *, const chtype *, int ); extern int waddchnstr ( WINDOW *, const chtype *, int );
/*extern int waddchstr ( WINDOW *, const chtype * );*/ /*extern int waddchstr ( WINDOW *, const chtype * );*/
@ -494,17 +494,17 @@ extern int wgetch ( WINDOW * );
extern int wgetnstr ( WINDOW *, char *, int ); extern int wgetnstr ( WINDOW *, char *, int );
extern int wgetstr ( WINDOW *, char * ); extern int wgetstr ( WINDOW *, char * );
extern int whline ( WINDOW *, chtype, int ); extern int whline ( WINDOW *, chtype, int );
extern chtype winch ( WINDOW * ); //extern chtype winch ( WINDOW * );
extern int winchnstr ( WINDOW *, chtype *, int ); //extern int winchnstr ( WINDOW *, chtype *, int );
extern int winchstr ( WINDOW *, chtype * ); //extern int winchstr ( WINDOW *, chtype * );
extern int winnstr ( WINDOW *, char *, int ); //extern int winnstr ( WINDOW *, char *, int );
extern int winsch ( WINDOW *, chtype ); //extern int winsch ( WINDOW *, chtype );
extern int winsnstr ( WINDOW *, const char *, int ); //extern int winsnstr ( WINDOW *, const char *, int );
extern int winsstr ( WINDOW *, const char * ); //extern int winsstr ( WINDOW *, const char * );
extern int winstr ( WINDOW *, char * ); //extern int winstr ( WINDOW *, char * );
extern int wmove ( WINDOW *, int, int ); extern int wmove ( WINDOW *, int, int );
extern int wnoutrefresh ( WINDOW * ); extern int wnoutrefresh ( WINDOW * );
extern int wprintw ( WINDOW *, char *, ... ); extern int wprintw ( WINDOW *, const char *, ... );
/*extern int wredrawln ( WINDOW *, int, int );*/ /*extern int wredrawln ( WINDOW *, int, int );*/
/*extern int wrefresh ( WINDOW * );*/ /*extern int wrefresh ( WINDOW * );*/
extern int wscanw ( WINDOW *, char *, ... ); extern int wscanw ( WINDOW *, char *, ... );
@ -582,68 +582,112 @@ static inline int deleteln ( void ) {
return wdeleteln( stdscr ); return wdeleteln( stdscr );
} }
static inline int hline ( chtype ch, int n ) {
return whline ( stdscr, ch, n );
}
static inline int move ( int y, int x ) { static inline int move ( int y, int x ) {
return wmove ( stdscr, y, x ); return wmove ( stdscr, y, x );
} }
static inline int mvaddch ( int y, int x, const chtype ch ) { static inline int mvaddch ( int y, int x, const chtype ch ) {
return ( wmove ( stdscr, y, x ) == ERR return ( wmove ( stdscr, y, x ) == OK
? ERR : waddch( stdscr, ch ) ); ? waddch( stdscr, ch ) : ERR );
} }
static inline int mvaddchnstr ( int y, int x, const chtype *chstr, int n ) { static inline int mvaddchnstr ( int y, int x, const chtype *chstr, int n ) {
return ( wmove ( stdscr, y, x ) == ERR return ( wmove ( stdscr, y, x ) == OK
? ERR : waddchnstr ( stdscr, chstr, n ) ); ? waddchnstr ( stdscr, chstr, n ) : ERR );
} }
static inline int mvaddchstr ( int y, int x, const chtype *chstr ) { static inline int mvaddchstr ( int y, int x, const chtype *chstr ) {
return ( wmove ( stdscr, y, x ) == ERR return ( wmove ( stdscr, y, x ) == OK
? ERR : waddchnstr ( stdscr, chstr, -1 ) ); ? waddchnstr ( stdscr, chstr, -1 ) : ERR );
} }
static inline int mvaddnstr ( int y, int x, const char *str, int n ) { static inline int mvaddnstr ( int y, int x, const char *str, int n ) {
return ( wmove ( stdscr, y, x ) == ERR return ( wmove ( stdscr, y, x ) == OK
? ERR : waddnstr ( stdscr, str, n ) ); ? waddnstr ( stdscr, str, n ) : ERR );
} }
static inline int mvaddstr ( int y, int x, const char *str ) { static inline int mvaddstr ( int y, int x, const char *str ) {
return ( wmove ( stdscr, y, x ) == ERR return ( wmove ( stdscr, y, x ) == OK
? ERR : waddnstr ( stdscr, str, -1 ) ); ? waddnstr ( stdscr, str, -1 ) : ERR );
} }
static inline int mvdelch ( int y, int x ) { static inline int mvdelch ( int y, int x ) {
return ( wmove ( stdscr, y, x ) == ERR return ( wmove ( stdscr, y, x ) == OK
? ERR : wdelch ( stdscr ) ); ? wdelch ( stdscr ) : ERR );
}
static inline int mvhline ( int y, int x, chtype ch, int n ) {
return ( wmove ( stdscr, y, x ) == OK
? whline ( stdscr, ch, n ) : ERR );
}
// OK, so maybe a few I did with macros...
#define mvprintw( y, x, fmt, ... ) \
( wmove(stdscr,(y),(x)) == OK \
? wprintw(stdscr,(fmt), ## __VA_ARGS__ : ERR )
static inline int mvvline ( int y, int x, chtype ch, int n ) {
return ( wmove ( stdscr, y, x ) == OK
? wvline ( stdscr, ch, n ) : ERR );
} }
static inline int mvwaddch ( WINDOW *win, int y, int x, const chtype ch ) { static inline int mvwaddch ( WINDOW *win, int y, int x, const chtype ch ) {
return ( wmove( win, y, x ) == ERR return ( wmove( win, y, x ) == OK
? ERR : waddch ( win, ch ) ); ? waddch ( win, ch ) : ERR );
} }
static inline int mvwaddchnstr ( WINDOW *win, int y, int x, const chtype *chstr, int n ) { static inline int mvwaddchnstr ( WINDOW *win, int y, int x, const chtype *chstr, int n ) {
return ( wmove ( win, y, x ) == ERR return ( wmove ( win, y, x ) == OK
? ERR : waddchnstr ( win, chstr, n ) ); ? waddchnstr ( win, chstr, n ) : ERR );
} }
static inline int mvwaddchstr ( WINDOW *win, int y, int x, const chtype *chstr ) { static inline int mvwaddchstr ( WINDOW *win, int y, int x, const chtype *chstr ) {
return ( wmove ( win, y, x ) == ERR return ( wmove ( win, y, x ) == OK
? ERR : waddchnstr ( win, chstr, -1 ) ); ? waddchnstr ( win, chstr, -1 ) : ERR );
} }
static inline int mvwaddnstr ( WINDOW *win, int y, int x, const char *str, int n ) { static inline int mvwaddnstr ( WINDOW *win, int y, int x, const char *str, int n ) {
return ( wmove ( win, y, x ) == ERR return ( wmove ( win, y, x ) == OK
? ERR : waddnstr ( win, str, n ) ); ? waddnstr ( win, str, n ) : ERR );
} }
static inline int mvwaddstr ( WINDOW *win, int y, int x, const char *str ) { static inline int mvwaddstr ( WINDOW *win, int y, int x, const char *str ) {
return ( wmove ( win, y, x ) == ERR return ( wmove ( win, y, x ) == OK
? ERR : waddnstr ( win, str, -1 ) ); ? waddnstr ( win, str, -1 ) : ERR );
} }
static inline int mvwdelch ( WINDOW *win, int y, int x ) { static inline int mvwdelch ( WINDOW *win, int y, int x ) {
return ( wmove ( win, y, x ) == ERR return ( wmove ( win, y, x ) == OK
? ERR : wdelch ( win ) ); ? wdelch ( win ) : ERR );
}
static inline int mvwhline ( WINDOW *win, int y, int x, chtype ch, int n ) {
return ( wmove ( win, y, x ) == OK
? whline ( win, ch, n ) : ERR );
}
#define mvwprintw( win, y, x, fmt, ... ) \
( wmove((win),(y),(x)) == OK \
? wprintw((win),(fmt), ## __VA_ARGS__) : ERR )
static inline int mvwvline ( WINDOW *win, int y, int x, chtype ch, int n ) {
return ( wmove ( win, y, x ) == OK
? wvline ( win, ch, n ) : ERR );
}
#define printw( fmt, ... ) wprintw(stdscr,(fmt), ## __VA_ARGS__ )
static inline int vline ( chtype ch, int n ) {
return wvline ( stdscr, ch, n );
}
// marked for removal
static inline int vwprintw ( WINDOW *win, const char *fmt, va_list varglist ) {
return vw_printw ( win, fmt, varglist );
} }
static inline int waddchstr ( WINDOW *win, const chtype *chstr ) { static inline int waddchstr ( WINDOW *win, const chtype *chstr ) {