diff options
author | ache <ache@FreeBSD.org> | 1994-10-07 08:58:58 +0000 |
---|---|---|
committer | ache <ache@FreeBSD.org> | 1994-10-07 08:58:58 +0000 |
commit | a80c0624fbd8bd1c784b0b5b7a0fd20b09d317b9 (patch) | |
tree | 4a94ca97fb2fc2fdc1fcdd522a66e39c6e763138 /lib/libncurses/lib_vidattr.c | |
download | FreeBSD-src-a80c0624fbd8bd1c784b0b5b7a0fd20b09d317b9.zip FreeBSD-src-a80c0624fbd8bd1c784b0b5b7a0fd20b09d317b9.tar.gz |
Moved from ports with several enhancements
Diffstat (limited to 'lib/libncurses/lib_vidattr.c')
-rw-r--r-- | lib/libncurses/lib_vidattr.c | 185 |
1 files changed, 185 insertions, 0 deletions
diff --git a/lib/libncurses/lib_vidattr.c b/lib/libncurses/lib_vidattr.c new file mode 100644 index 0000000..a3bd4c7 --- /dev/null +++ b/lib/libncurses/lib_vidattr.c @@ -0,0 +1,185 @@ + +/* This work is copyrighted. See COPYRIGHT.OLD & COPYRIGHT.NEW for * +* details. If they are missing then this copy is in violation of * +* the copyright conditions. */ + +/* + * vidputs(newmode, outc) + * + * newmode is taken to be the logical 'or' of the symbols in curses.h + * representing graphic renditions. The teminal is set to be in all of + * the given modes, if possible. + * + * if set-attributes exists + * use it to set exactly what you want + * else + * if exit-attribute-mode exists + * turn off everything + * else + * turn off those which can be turned off and aren't in + * newmode. + * turn on each mode which should be on and isn't, one by one + * + * NOTE that this algorithm won't achieve the desired mix of attributes + * in some cases, but those are probably just those cases in which it is + * actually impossible, anyway, so... + * + */ + +#include <string.h> +#include "curses.priv.h" +#include <nterm.h> + +static void do_color(int pair, int (*outc)(char)) +{ +short fg, bg; + + if ( pair == 0 ) { + tputs(orig_pair, 1, outc); + } else { + fg = FG(color_pairs[pair]); + bg = BG(color_pairs[pair]); + + T(("setting colors: pair = %d, fg = %d, bg = %d\n", pair, fg, bg)); + + if (set_a_foreground) + tputs(tparm(set_a_foreground, fg), 1, outc); + else + tputs(tparm(set_foreground, fg), 1, outc); + if (set_a_background) + tputs(tparm(set_a_background, bg), 1, outc); + else + tputs(tparm(set_background, bg), 1, outc); + } +} + +static int current_pair = 0; +static chtype previous_attr = 0; + +int vidputs(chtype newmode, int (*outc)(char)) +{ +chtype turn_off, turn_on; + + T(("vidputs(%x) called %s", newmode, _traceattr(newmode))); + T(("previous attribute was %s", _traceattr(previous_attr))); + + if (newmode == A_NORMAL && exit_attribute_mode) { + tputs(exit_attribute_mode, 1, outc); + current_pair = -1; + goto set_color; + } + else if (set_attributes) { + tputs(tparm(set_attributes, + (newmode & A_STANDOUT) != 0, + (newmode & A_UNDERLINE) != 0, + (newmode & A_REVERSE) != 0, + (newmode & A_BLINK) != 0, + (newmode & A_DIM) != 0, + (newmode & A_BOLD) != 0, + (newmode & A_INVIS) != 0, + (newmode & A_PROTECT) != 0, + (newmode & A_ALTCHARSET) != 0), 1, outc); + goto set_color; + } else { + if (exit_attribute_mode) { + if((previous_attr & A_ALTCHARSET) && exit_alt_charset_mode) { + tputs(exit_alt_charset_mode, 1, outc); + previous_attr &= ~A_ALTCHARSET; + } + if (previous_attr) { + T(("exiting attribute mode")); + + tputs(exit_attribute_mode, 1, outc); + previous_attr = 0; + current_pair = -1; + } + } else { + turn_off = ~newmode & previous_attr; + + T(("turning %x off", turn_off)); + + if ((turn_off & A_ALTCHARSET) && exit_alt_charset_mode) + tputs(exit_alt_charset_mode, 1, outc); + + if ((turn_off & A_BOLD) && exit_standout_mode) + tputs(exit_standout_mode, 1, outc); + + if ((turn_off & A_DIM) && exit_standout_mode) + tputs(exit_standout_mode, 1, outc); + + if ((turn_off & A_BLINK) && exit_standout_mode) + tputs(exit_standout_mode, 1, outc); + + if ((turn_off & A_INVIS) && exit_standout_mode) + tputs(exit_standout_mode, 1, outc); + + if ((turn_off & A_PROTECT) && exit_standout_mode) + tputs(exit_standout_mode, 1, outc); + + if ((turn_off & A_UNDERLINE) && exit_underline_mode) + tputs(exit_underline_mode, 1, outc); + + if ((turn_off & A_REVERSE) && exit_standout_mode) + tputs(exit_standout_mode, 1, outc); + + if ((turn_off & A_STANDOUT) && exit_standout_mode) + tputs(exit_standout_mode, 1, outc); + } + + turn_on = newmode & ~previous_attr; + + T(("turning %x on", turn_on)); + + if ((turn_on & A_ALTCHARSET) && enter_alt_charset_mode) + tputs(enter_alt_charset_mode, 1, outc); + + if ((turn_on & A_BLINK) && enter_blink_mode) + tputs(enter_blink_mode, 1, outc); + + if ((turn_on & A_BOLD) && enter_bold_mode) + tputs(enter_bold_mode, 1, outc); + + if ((turn_on & A_DIM) && enter_dim_mode) + tputs(enter_dim_mode, 1, outc); + + if ((turn_on & A_REVERSE) && enter_reverse_mode) + tputs(enter_reverse_mode, 1, outc); + + if ((turn_on & A_STANDOUT) && enter_standout_mode) + tputs(enter_standout_mode, 1, outc); + + if ((turn_on & A_PROTECT) && enter_protected_mode) + tputs(enter_protected_mode, 1, outc); + + if ((turn_on & A_INVIS) && enter_secure_mode) + tputs(enter_secure_mode, 1, outc); + + if ((turn_on & A_UNDERLINE) && enter_underline_mode) + tputs(enter_underline_mode, 1, outc); + set_color: + if (_coloron) { + int pair = PAIR_NUMBER(newmode); + + T(("old pair = %d -- new pair = %d", current_pair, pair)); + if (pair != current_pair) { + current_pair = pair; + do_color(pair, outc); + } + } + } + + + previous_attr = newmode; + + T(("vidputs finished")); + return OK; +} + +int vidattr(chtype newmode) +{ + + T(("vidattr(%x) called", newmode)); + + return(vidputs(newmode, _outc)); +} + |