mirror of
https://github.com/xcat2/xNBA.git
synced 2025-02-19 03:54:38 +00:00
[console] Exclude text-based UI output from logfile-based consoles
The output from text-based user interfaces such as the "config" command is not generally meaningful for logfile-based consoles such as syslog and vmconsole. Signed-off-by: Michael Brown <mcb30@ipxe.org>
This commit is contained in:
parent
e024cd39a8
commit
64d17dbd50
@ -37,7 +37,7 @@ FILE_LICENCE ( GPL2_OR_LATER );
|
||||
/* Set default console usage if applicable */
|
||||
#if ! ( defined ( CONSOLE_VMWARE ) && CONSOLE_EXPLICIT ( CONSOLE_VMWARE ) )
|
||||
#undef CONSOLE_VMWARE
|
||||
#define CONSOLE_VMWARE CONSOLE_USAGE_ALL
|
||||
#define CONSOLE_VMWARE ( CONSOLE_USAGE_ALL & ~CONSOLE_USAGE_TUI )
|
||||
#endif
|
||||
|
||||
/** VMware logfile console GuestRPC channel */
|
||||
|
@ -12,6 +12,8 @@ static void ansiscr_putc(struct _curses_screen *scr, chtype c) __nonnull;
|
||||
unsigned short _COLS = 80;
|
||||
unsigned short _LINES = 24;
|
||||
|
||||
static unsigned int saved_usage;
|
||||
|
||||
static void ansiscr_reset ( struct _curses_screen *scr ) {
|
||||
/* Reset terminal attributes and clear screen */
|
||||
scr->attrs = 0;
|
||||
@ -20,6 +22,16 @@ static void ansiscr_reset ( struct _curses_screen *scr ) {
|
||||
printf ( "\033[0m" );
|
||||
}
|
||||
|
||||
static void ansiscr_init ( struct _curses_screen *scr ) {
|
||||
saved_usage = console_set_usage ( CONSOLE_USAGE_TUI );
|
||||
ansiscr_reset ( scr );
|
||||
}
|
||||
|
||||
static void ansiscr_exit ( struct _curses_screen *scr ) {
|
||||
ansiscr_reset ( scr );
|
||||
console_set_usage ( saved_usage );
|
||||
}
|
||||
|
||||
static void ansiscr_movetoyx ( struct _curses_screen *scr,
|
||||
unsigned int y, unsigned int x ) {
|
||||
if ( ( x != scr->curs_x ) || ( y != scr->curs_y ) ) {
|
||||
@ -65,8 +77,8 @@ static bool ansiscr_peek ( struct _curses_screen *scr __unused ) {
|
||||
}
|
||||
|
||||
SCREEN _ansi_screen = {
|
||||
.init = ansiscr_reset,
|
||||
.exit = ansiscr_reset,
|
||||
.init = ansiscr_init,
|
||||
.exit = ansiscr_exit,
|
||||
.movetoyx = ansiscr_movetoyx,
|
||||
.putc = ansiscr_putc,
|
||||
.getc = ansiscr_getc,
|
||||
|
@ -117,8 +117,12 @@ struct console_driver {
|
||||
/** Debug messages */
|
||||
#define CONSOLE_USAGE_DEBUG 0x0002
|
||||
|
||||
/** Text-based user interface */
|
||||
#define CONSOLE_USAGE_TUI 0x0004
|
||||
|
||||
/** All console usages */
|
||||
#define CONSOLE_USAGE_ALL ( CONSOLE_USAGE_STDOUT | CONSOLE_USAGE_DEBUG )
|
||||
#define CONSOLE_USAGE_ALL \
|
||||
( CONSOLE_USAGE_STDOUT | CONSOLE_USAGE_DEBUG | CONSOLE_USAGE_TUI )
|
||||
|
||||
/** @} */
|
||||
|
||||
|
@ -39,7 +39,7 @@ FILE_LICENCE ( GPL2_OR_LATER );
|
||||
/* Set default console usage if applicable */
|
||||
#if ! ( defined ( CONSOLE_SYSLOG ) && CONSOLE_EXPLICIT ( CONSOLE_SYSLOG ) )
|
||||
#undef CONSOLE_SYSLOG
|
||||
#define CONSOLE_SYSLOG CONSOLE_USAGE_ALL
|
||||
#define CONSOLE_SYSLOG ( CONSOLE_USAGE_ALL & ~CONSOLE_USAGE_TUI )
|
||||
#endif
|
||||
|
||||
/** The syslog server */
|
||||
|
Loading…
x
Reference in New Issue
Block a user