2005-10-17 13:24:12 +00:00
|
|
|
/** \file output.h
|
2012-11-18 10:23:22 +00:00
|
|
|
Generic output functions
|
2005-10-17 13:24:12 +00:00
|
|
|
*/
|
2005-09-20 13:26:39 +00:00
|
|
|
/**
|
|
|
|
Constants for various character classifications. Each character of a command string can be classified as one of the following types.
|
|
|
|
*/
|
2005-10-04 15:11:39 +00:00
|
|
|
#ifndef FISH_OUTPUT_H
|
|
|
|
#define FISH_OUTPUT_H
|
|
|
|
|
2015-07-25 15:14:25 +00:00
|
|
|
#include <vector>
|
2016-04-21 06:00:54 +00:00
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
2015-07-25 15:14:25 +00:00
|
|
|
#include "common.h"
|
2016-04-21 06:00:54 +00:00
|
|
|
#include "fallback.h" // IWYU pragma: keep
|
2012-02-13 02:05:59 +00:00
|
|
|
#include "color.h"
|
2005-10-04 15:11:39 +00:00
|
|
|
|
2005-09-20 13:26:39 +00:00
|
|
|
/**
|
2012-11-18 10:23:22 +00:00
|
|
|
Constants for various colors as used by the set_color function.
|
2005-09-20 13:26:39 +00:00
|
|
|
*/
|
|
|
|
enum
|
|
|
|
{
|
2012-11-19 00:30:30 +00:00
|
|
|
FISH_COLOR_BLACK,
|
|
|
|
FISH_COLOR_RED,
|
|
|
|
FISH_COLOR_GREEN,
|
|
|
|
FISH_COLOR_YELLOW,
|
|
|
|
FISH_COLOR_BLUE,
|
|
|
|
FISH_COLOR_MAGENTA,
|
|
|
|
FISH_COLOR_CYAN,
|
|
|
|
FISH_COLOR_WHITE,
|
2016-04-04 23:55:40 +00:00
|
|
|
FISH_COLOR_NORMAL, // the default fg color of the terminal
|
2012-11-19 00:30:30 +00:00
|
|
|
FISH_COLOR_RESET
|
2015-08-11 08:00:05 +00:00
|
|
|
};
|
2005-09-20 13:26:39 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the fg and bg color. May be called as often as you like, since
|
|
|
|
if the new color is the same as the previous, nothing will be
|
|
|
|
written. Negative values for set_color will also be ignored. Since
|
|
|
|
the terminfo string this function emits can potentially cause the
|
|
|
|
screen to flicker, the function takes care to write as little as
|
|
|
|
possible.
|
|
|
|
|
2016-04-04 23:55:40 +00:00
|
|
|
Possible values for color are any form the FISH_COLOR_* enum
|
|
|
|
and FISH_COLOR_RESET. FISH_COLOR_RESET will perform an
|
2005-09-20 13:26:39 +00:00
|
|
|
exit_attribute_mode, even if set_color thinks it is already in
|
|
|
|
FISH_COLOR_NORMAL mode.
|
|
|
|
|
|
|
|
In order to set the color to normal, three terminfo strings may
|
|
|
|
have to be written.
|
|
|
|
|
|
|
|
- First a string to set the color, such as set_a_foreground. This
|
|
|
|
is needed because otherwise the previous strings colors might be
|
|
|
|
removed as well.
|
|
|
|
|
|
|
|
- After that we write the exit_attribute_mode string to reset all
|
|
|
|
color attributes.
|
|
|
|
|
|
|
|
- Lastly we may need to write set_a_background or set_a_foreground
|
|
|
|
to set the other half of the color pair to what it should be.
|
|
|
|
|
|
|
|
\param c Foreground color.
|
|
|
|
\param c2 Background color.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2012-02-12 01:07:56 +00:00
|
|
|
void set_color(rgb_color_t c, rgb_color_t c2);
|
2005-09-20 13:26:39 +00:00
|
|
|
|
2008-01-13 16:47:47 +00:00
|
|
|
/**
|
|
|
|
Write specified multibyte string
|
|
|
|
*/
|
2014-05-09 21:37:23 +00:00
|
|
|
void writembs_check(char *mbs, const char *mbs_name, const char *file, long line);
|
|
|
|
#define writembs(mbs) writembs_check((mbs), #mbs, __FILE__, __LINE__)
|
2005-09-20 13:26:39 +00:00
|
|
|
|
2005-10-17 13:24:12 +00:00
|
|
|
/**
|
2006-10-01 15:59:18 +00:00
|
|
|
Write a wide character using the output method specified using output_set_writer().
|
2005-10-17 13:24:12 +00:00
|
|
|
*/
|
2012-11-19 00:30:30 +00:00
|
|
|
int writech(wint_t ch);
|
2005-09-20 13:26:39 +00:00
|
|
|
|
2005-10-17 13:24:12 +00:00
|
|
|
/**
|
|
|
|
Write a wide character string to FD 1.
|
|
|
|
*/
|
2012-11-19 00:30:30 +00:00
|
|
|
void writestr(const wchar_t *str);
|
2005-09-20 13:26:39 +00:00
|
|
|
|
2005-10-17 13:24:12 +00:00
|
|
|
/**
|
|
|
|
Return the internal color code representing the specified color
|
|
|
|
*/
|
2012-11-19 00:30:30 +00:00
|
|
|
rgb_color_t parse_color(const wcstring &val, bool is_background);
|
2005-09-20 13:26:39 +00:00
|
|
|
|
2006-02-16 13:40:25 +00:00
|
|
|
/**
|
|
|
|
This is for writing process notification messages. Has to write to
|
|
|
|
stdout, so clr_eol and such functions will work correctly. Not an
|
|
|
|
issue since this function is only used in interactive mode anyway.
|
|
|
|
*/
|
2012-11-19 00:30:30 +00:00
|
|
|
int writeb(tputs_arg_t b);
|
2006-02-16 13:40:25 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Set the function used for writing in move_cursor, writespace and
|
2006-02-20 13:11:46 +00:00
|
|
|
set_color and all other output functions in this library. By
|
|
|
|
default, the write call is used to give completely unbuffered
|
|
|
|
output to stdout.
|
2006-02-16 13:40:25 +00:00
|
|
|
*/
|
2012-11-19 00:30:30 +00:00
|
|
|
void output_set_writer(int (*writer)(char));
|
2006-02-16 13:40:25 +00:00
|
|
|
|
2008-01-13 16:47:47 +00:00
|
|
|
/**
|
|
|
|
Return the current output writer
|
|
|
|
*/
|
2006-10-01 16:02:58 +00:00
|
|
|
int (*output_get_writer())(char) ;
|
|
|
|
|
2012-03-05 18:44:08 +00:00
|
|
|
/** Set the terminal name */
|
2012-12-19 21:31:06 +00:00
|
|
|
void output_set_term(const wcstring &term);
|
2012-03-05 18:44:08 +00:00
|
|
|
|
|
|
|
/** Return the terminal name */
|
2012-02-10 00:06:24 +00:00
|
|
|
const wchar_t *output_get_term();
|
2007-09-09 14:04:36 +00:00
|
|
|
|
2014-09-19 22:37:31 +00:00
|
|
|
/** Sets what colors are supported */
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
color_support_term256 = 1 << 0,
|
|
|
|
color_support_term24bit = 1 << 1
|
|
|
|
};
|
|
|
|
typedef unsigned int color_support_t;
|
|
|
|
color_support_t output_get_color_support();
|
|
|
|
void output_set_color_support(color_support_t support);
|
2012-02-13 17:52:17 +00:00
|
|
|
|
2014-11-10 00:42:35 +00:00
|
|
|
/** Given a list of rgb_color_t, pick the "best" one, as determined by the color support. Returns rgb_color_t::none() if empty */
|
|
|
|
rgb_color_t best_color(const std::vector<rgb_color_t> &colors, color_support_t support);
|
|
|
|
|
2013-02-14 23:50:24 +00:00
|
|
|
/* Exported for builtin_set_color's usage only */
|
2014-09-20 01:44:18 +00:00
|
|
|
void write_color(rgb_color_t color, bool is_fg);
|
2013-02-14 23:50:24 +00:00
|
|
|
unsigned char index_for_color(rgb_color_t c);
|
|
|
|
|
2005-10-04 15:11:39 +00:00
|
|
|
#endif
|