rtl_433/include/term_ctl.h
2023-10-02 19:57:45 +02:00

138 lines
3.8 KiB
C

/** @file
Terminal control utility functions.
Copyright (C) 2018 Christian Zuckschwerdt
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
*/
#ifndef INCLUDE_TERM_CTL_H_
#define INCLUDE_TERM_CTL_H_
#include <stdio.h>
void *term_init(FILE *fp);
void term_free(void *ctx);
int term_get_columns(void *ctx);
int term_has_color(void *ctx);
void term_ring_bell(void *ctx);
typedef enum term_color {
TERM_COLOR_RESET = 0,
TERM_COLOR_BLACK = 30,
TERM_COLOR_RED = 31,
TERM_COLOR_GREEN = 32,
TERM_COLOR_YELLOW = 33,
TERM_COLOR_BLUE = 34,
TERM_COLOR_MAGENTA = 35,
TERM_COLOR_CYAN = 36,
TERM_COLOR_WHITE = 37,
TERM_COLOR_BRIGHT_BLACK = 90,
TERM_COLOR_BRIGHT_RED = 91,
TERM_COLOR_BRIGHT_GREEN = 92,
TERM_COLOR_BRIGHT_YELLOW = 93,
TERM_COLOR_BRIGHT_BLUE = 94,
TERM_COLOR_BRIGHT_MAGENTA = 95,
TERM_COLOR_BRIGHT_CYAN = 96,
TERM_COLOR_BRIGHT_WHITE = 97,
} term_color_t;
/**
* Sets the terminal text foreground color.
* Always sets the bold font attribute, except for TERM_COLOR_RESET.
*/
void term_set_fg(void *ctx, term_color_t color);
/**
* Sets the terminal background and foreground color.
* Both are optional, use `0` to omit a color.
* Must not be used for TERM_COLOR_RESET.
*/
void term_set_bg(void *ctx, term_color_t bg, term_color_t fg);
/*
* Defined in newer <sal.h> for MSVC.
*/
#ifndef _Printf_format_string_
#define _Printf_format_string_
#endif
/**
* Print to terminal with color-codes inline turned into above colors.
* Takes a var-arg format.
*
* E.g.:
*
* void *term = term_init(stdout);
* term_printf (term, "~4Hello ~2world~0.\n");
*
* will print to stdout with 'Hello' mapped to colour 4
* and 'world' mapped to colour 2. See 'term_set_color_map()' below.
*
* And a 'term_printf (NULL, "~4Hello ~2world~0.\n");'
* will print "Hello world" to stderr' with no colors.
*/
int term_printf(void *ctx, _Printf_format_string_ const char *format, ...)
#if defined(__GNUC__) || defined(__clang__)
__attribute__((format(printf, 2, 3)))
#endif
;
/**
* Print to terminal with markup turned into colors.
* Like 'term_printf()', but with automatic coloring for markup.
*
* Markup:
* = Heading =
* [option argument]
* "quoted"
* 'quoted'
*/
int term_help_fprintf(FILE *fp, _Printf_format_string_ char const *format, ...)
#if defined(__GNUC__) || defined(__clang__)
__attribute__((format(printf, 2, 3)))
#endif
;
/**
* Like 'term_printf()', but no var-arg format.
* Simply takes a 0-terminated buffer.
*/
int term_puts(void *ctx, const char *buf);
/**
* Like 'term_help_fprintf()', but no var-arg format.
* Simply takes a 0-terminated buffer.
*/
int term_help_fputs(void *ctx, const char *buf, FILE *fp);
/**
* Change the default color map.
* By default, the color-codes maps to these foreground colour:
* "~0": always restores terminal-colors; TERM_COLOR_RESET.
* "~1": print using TERM_COLOR_GREEN.
* "~2": print using TERM_COLOR_WHITE.
* "~3": print using TERM_COLOR_BLUE.
* "~4": print using TERM_COLOR_CYAN.
* "~5": print using TERM_COLOR_MAGENTA.
* "~6": print using TERM_COLOR_YELLOW.
* "~7": print using TERM_COLOR_BLACK.
* "~8": print using TERM_COLOR_RED.
*/
int term_set_color_map(int idx, term_color_t color);
/**
* Returns the current color-value ('enum term_color') for color-index.
* 'idx'. This index goes from ASCII '0' to 'X'.
* 'X' = '0' + the dimension of the internal 'color_map[]'.
*/
int term_get_color_map(int idx);
#endif /* INCLUDE_TERM_CTL_H_ */