xref: /freebsd/sys/teken/teken.h (revision dcc3a33188bceb5b6e819efdb9c5f72d059084b6)
1 /*-
2  * Copyright (c) 2008-2009 Ed Schouten <ed@FreeBSD.org>
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24  * SUCH DAMAGE.
25  *
26  * $FreeBSD$
27  */
28 
29 #ifndef _TEKEN_H_
30 #define	_TEKEN_H_
31 
32 /*
33  * libteken: terminal emulation library.
34  *
35  * This library converts an UTF-8 stream of bytes to terminal drawing
36  * commands.
37  *
38  * Configuration switches:
39  * - TEKEN_UTF8: Enable/disable UTF-8 handling.
40  * - TEKEN_XTERM: Enable xterm-style emulation, instead of cons25.
41  */
42 
43 #if defined(__FreeBSD__) && defined(_KERNEL)
44 #include "opt_teken.h"
45 #endif /* __FreeBSD__ && _KERNEL */
46 
47 #ifdef TEKEN_UTF8
48 typedef uint32_t teken_char_t;
49 #else /* !TEKEN_UTF8 */
50 typedef unsigned char teken_char_t;
51 #endif /* TEKEN_UTF8 */
52 typedef unsigned short teken_unit_t;
53 typedef unsigned char teken_format_t;
54 #define	TF_BOLD		0x01
55 #define	TF_UNDERLINE	0x02
56 #define	TF_BLINK	0x04
57 #define	TF_REVERSE	0x08
58 typedef unsigned char teken_color_t;
59 #define	TC_BLACK	0
60 #define	TC_RED		1
61 #define	TC_GREEN	2
62 #define	TC_BROWN	3
63 #define	TC_BLUE		4
64 #define	TC_MAGENTA	5
65 #define	TC_CYAN		6
66 #define	TC_WHITE	7
67 #define	TC_NCOLORS	8
68 
69 typedef struct {
70 	teken_unit_t	tp_row;
71 	teken_unit_t	tp_col;
72 } teken_pos_t;
73 typedef struct {
74 	teken_pos_t	tr_begin;
75 	teken_pos_t	tr_end;
76 } teken_rect_t;
77 typedef struct {
78 	teken_format_t	ta_format;
79 	teken_color_t	ta_fgcolor;
80 	teken_color_t	ta_bgcolor;
81 } teken_attr_t;
82 typedef struct {
83 	teken_unit_t	ts_begin;
84 	teken_unit_t	ts_end;
85 } teken_span_t;
86 
87 typedef struct __teken teken_t;
88 
89 typedef void teken_state_t(teken_t *, teken_char_t);
90 
91 /*
92  * Drawing routines supplied by the user.
93  */
94 
95 typedef void tf_bell_t(void *);
96 typedef void tf_cursor_t(void *, const teken_pos_t *);
97 typedef void tf_putchar_t(void *, const teken_pos_t *, teken_char_t,
98     const teken_attr_t *);
99 typedef void tf_fill_t(void *, const teken_rect_t *, teken_char_t,
100     const teken_attr_t *);
101 typedef void tf_copy_t(void *, const teken_rect_t *, const teken_pos_t *);
102 typedef void tf_param_t(void *, int, unsigned int);
103 #define	TP_SHOWCURSOR	0
104 #define	TP_CURSORKEYS	1
105 #define	TP_KEYPADAPP	2
106 #define	TP_AUTOREPEAT	3
107 #define	TP_SWITCHVT	4
108 #define	TP_132COLS	5
109 #define	TP_SETBELLPD	6
110 #define	TP_SETBELLPD_PITCH(pd)		((pd) >> 16)
111 #define	TP_SETBELLPD_DURATION(pd)	((pd) & 0xffff)
112 typedef void tf_respond_t(void *, const void *, size_t);
113 
114 typedef struct {
115 	tf_bell_t	*tf_bell;
116 	tf_cursor_t	*tf_cursor;
117 	tf_putchar_t	*tf_putchar;
118 	tf_fill_t	*tf_fill;
119 	tf_copy_t	*tf_copy;
120 	tf_param_t	*tf_param;
121 	tf_respond_t	*tf_respond;
122 } teken_funcs_t;
123 
124 #if defined(TEKEN_XTERM) && defined(TEKEN_UTF8)
125 typedef teken_char_t teken_scs_t(teken_char_t);
126 #endif /* TEKEN_XTERM && TEKEN_UTF8 */
127 
128 /*
129  * Terminal state.
130  */
131 
132 struct __teken {
133 	const teken_funcs_t *t_funcs;
134 	void		*t_softc;
135 
136 	teken_state_t	*t_nextstate;
137 	unsigned int	 t_stateflags;
138 
139 #define T_NUMSIZE	8
140 	unsigned int	 t_nums[T_NUMSIZE];
141 	unsigned int	 t_curnum;
142 
143 	teken_pos_t	 t_cursor;
144 	teken_attr_t	 t_curattr;
145 	teken_pos_t	 t_saved_cursor;
146 	teken_attr_t	 t_saved_curattr;
147 
148 	teken_attr_t	 t_defattr;
149 	teken_pos_t	 t_winsize;
150 
151 	/* For DECSTBM. */
152 	teken_span_t	 t_scrollreg;
153 	/* For DECOM. */
154 	teken_span_t	 t_originreg;
155 
156 #define	T_NUMCOL	160
157 	unsigned int	 t_tabstops[T_NUMCOL / (sizeof(unsigned int) * 8)];
158 
159 #ifdef TEKEN_UTF8
160 	unsigned int	 t_utf8_left;
161 	teken_char_t	 t_utf8_partial;
162 #endif /* TEKEN_UTF8 */
163 
164 #if defined(TEKEN_XTERM) && defined(TEKEN_UTF8)
165 	unsigned int	 t_curscs;
166 	teken_scs_t	*t_saved_curscs;
167 	teken_scs_t	*t_scs[2];
168 #endif /* TEKEN_XTERM && TEKEN_UTF8 */
169 };
170 
171 /* Initialize teken structure. */
172 void	teken_init(teken_t *, const teken_funcs_t *, void *);
173 
174 /* Deliver character input. */
175 void	teken_input(teken_t *, const void *, size_t);
176 
177 /* Get/set teken attributes. */
178 const teken_attr_t *teken_get_curattr(teken_t *);
179 const teken_attr_t *teken_get_defattr(teken_t *);
180 void	teken_set_cursor(teken_t *, const teken_pos_t *);
181 void	teken_set_curattr(teken_t *, const teken_attr_t *);
182 void	teken_set_defattr(teken_t *, const teken_attr_t *);
183 void	teken_set_winsize(teken_t *, const teken_pos_t *);
184 
185 #endif /* !_TEKEN_H_ */
186