Fast and reasonably complete (framebuffer) terminal emulator (Zig fork)
1/* Copyright (C) 2022-2024 mintsuki and contributors.
2 *
3 * Redistribution and use in source and binary forms, with or without
4 * modification, are permitted provided that the following conditions are met:
5 *
6 * 1. Redistributions of source code must retain the above copyright notice,
7 * this list of conditions and the following disclaimer.
8 *
9 * 2. Redistributions in binary form must reproduce the above copyright notice,
10 * this list of conditions and the following disclaimer in the documentation
11 * and/or other materials provided with the distribution.
12 *
13 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
14 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
17 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
23 * POSSIBILITY OF SUCH DAMAGE.
24 */
25
26#ifndef FLANTERM_H
27#define FLANTERM_H 1
28
29#ifdef __cplusplus
30extern "C" {
31#endif
32
33#include <stddef.h>
34#include <stdint.h>
35#include <stdbool.h>
36
37#define FLANTERM_MAX_ESC_VALUES 16
38
39#define FLANTERM_CB_DEC 10
40#define FLANTERM_CB_BELL 20
41#define FLANTERM_CB_PRIVATE_ID 30
42#define FLANTERM_CB_STATUS_REPORT 40
43#define FLANTERM_CB_POS_REPORT 50
44#define FLANTERM_CB_KBD_LEDS 60
45#define FLANTERM_CB_MODE 70
46#define FLANTERM_CB_LINUX 80
47
48#define FLANTERM_OOB_OUTPUT_OCRNL (1 << 0)
49#define FLANTERM_OOB_OUTPUT_OFDEL (1 << 1)
50#define FLANTERM_OOB_OUTPUT_OFILL (1 << 2)
51#define FLANTERM_OOB_OUTPUT_OLCUC (1 << 3)
52#define FLANTERM_OOB_OUTPUT_ONLCR (1 << 4)
53#define FLANTERM_OOB_OUTPUT_ONLRET (1 << 5)
54#define FLANTERM_OOB_OUTPUT_ONOCR (1 << 6)
55#define FLANTERM_OOB_OUTPUT_OPOST (1 << 7)
56
57struct flanterm_context {
58 /* internal use */
59
60 size_t tab_size;
61 bool autoflush;
62 bool cursor_enabled;
63 bool scroll_enabled;
64 bool control_sequence;
65 bool escape;
66 bool osc;
67 bool osc_escape;
68 bool rrr;
69 bool discard_next;
70 bool bold;
71 bool bg_bold;
72 bool reverse_video;
73 bool dec_private;
74 bool insert_mode;
75 uint64_t code_point;
76 size_t unicode_remaining;
77 uint8_t g_select;
78 uint8_t charsets[2];
79 size_t current_charset;
80 size_t escape_offset;
81 size_t esc_values_i;
82 size_t saved_cursor_x;
83 size_t saved_cursor_y;
84 size_t current_primary;
85 size_t current_bg;
86 size_t scroll_top_margin;
87 size_t scroll_bottom_margin;
88 uint32_t esc_values[FLANTERM_MAX_ESC_VALUES];
89 uint64_t oob_output;
90 bool saved_state_bold;
91 bool saved_state_bg_bold;
92 bool saved_state_reverse_video;
93 size_t saved_state_current_charset;
94 size_t saved_state_current_primary;
95 size_t saved_state_current_bg;
96
97 /* to be set by backend */
98
99 size_t rows, cols;
100
101 void (*raw_putchar)(struct flanterm_context *, uint8_t c);
102 void (*clear)(struct flanterm_context *, bool move);
103 void (*set_cursor_pos)(struct flanterm_context *, size_t x, size_t y);
104 void (*get_cursor_pos)(struct flanterm_context *, size_t *x, size_t *y);
105 void (*set_text_fg)(struct flanterm_context *, size_t fg);
106 void (*set_text_bg)(struct flanterm_context *, size_t bg);
107 void (*set_text_fg_bright)(struct flanterm_context *, size_t fg);
108 void (*set_text_bg_bright)(struct flanterm_context *, size_t bg);
109 void (*set_text_fg_rgb)(struct flanterm_context *, uint32_t fg);
110 void (*set_text_bg_rgb)(struct flanterm_context *, uint32_t bg);
111 void (*set_text_fg_default)(struct flanterm_context *);
112 void (*set_text_bg_default)(struct flanterm_context *);
113 void (*set_text_fg_default_bright)(struct flanterm_context *);
114 void (*set_text_bg_default_bright)(struct flanterm_context *);
115 void (*move_character)(struct flanterm_context *, size_t new_x, size_t new_y, size_t old_x, size_t old_y);
116 void (*scroll)(struct flanterm_context *);
117 void (*revscroll)(struct flanterm_context *);
118 void (*swap_palette)(struct flanterm_context *);
119 void (*save_state)(struct flanterm_context *);
120 void (*restore_state)(struct flanterm_context *);
121 void (*double_buffer_flush)(struct flanterm_context *);
122 void (*full_refresh)(struct flanterm_context *);
123 void (*deinit)(struct flanterm_context *, void (*)(void *, size_t));
124
125 /* to be set by client */
126
127 void (*callback)(struct flanterm_context *, uint64_t, uint64_t, uint64_t, uint64_t);
128};
129
130void flanterm_context_reinit(struct flanterm_context *ctx);
131void flanterm_write(struct flanterm_context *ctx, const char *buf, size_t count);
132
133#ifdef __cplusplus
134}
135#endif
136
137#endif