teken.h revision 187367
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: head/sys/dev/syscons/teken/teken.h 187367 2009-01-17 16:37:13Z ed $
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
48typedef uint32_t teken_char_t;
49#else /* !TEKEN_UTF8 */
50typedef unsigned char teken_char_t;
51#endif /* TEKEN_UTF8 */
52typedef unsigned short teken_unit_t;
53typedef unsigned char teken_format_t;
54#define	TF_BOLD		0x01
55#define	TF_UNDERLINE	0x02
56#define	TF_BLINK	0x04
57typedef unsigned char teken_color_t;
58#define	TC_BLACK	0
59#define	TC_RED		1
60#define	TC_GREEN	2
61#define	TC_BROWN	3
62#define	TC_BLUE		4
63#define	TC_MAGENTA	5
64#define	TC_CYAN		6
65#define	TC_WHITE	7
66#define	TC_NCOLORS	8
67
68typedef struct {
69	teken_unit_t	tp_row;
70	teken_unit_t	tp_col;
71} teken_pos_t;
72typedef struct {
73	teken_pos_t	tr_begin;
74	teken_pos_t	tr_end;
75} teken_rect_t;
76typedef struct {
77	teken_format_t	ta_format;
78	teken_color_t	ta_fgcolor;
79	teken_color_t	ta_bgcolor;
80} teken_attr_t;
81typedef struct {
82	teken_unit_t	ts_begin;
83	teken_unit_t	ts_end;
84} teken_span_t;
85
86typedef struct __teken teken_t;
87
88typedef void teken_state_t(teken_t *, teken_char_t);
89
90/*
91 * Drawing routines supplied by the user.
92 */
93
94typedef void tf_bell_t(void *);
95typedef void tf_cursor_t(void *, const teken_pos_t *);
96typedef void tf_putchar_t(void *, const teken_pos_t *, teken_char_t,
97    const teken_attr_t *);
98typedef void tf_fill_t(void *, const teken_rect_t *, teken_char_t,
99    const teken_attr_t *);
100typedef void tf_copy_t(void *, const teken_rect_t *, const teken_pos_t *);
101typedef void tf_param_t(void *, int, int);
102#define	TP_SHOWCURSOR	0
103#define	TP_CURSORKEYS	1
104#define	TP_KEYPADAPP	2
105#define	TP_AUTOREPEAT	3
106#define	TP_SWITCHVT	4
107#define	TP_132COLS	5
108typedef void tf_respond_t(void *, const void *, size_t);
109
110typedef struct {
111	tf_bell_t	*tf_bell;
112	tf_cursor_t	*tf_cursor;
113	tf_putchar_t	*tf_putchar;
114	tf_fill_t	*tf_fill;
115	tf_copy_t	*tf_copy;
116	tf_param_t	*tf_param;
117	tf_respond_t	*tf_respond;
118} teken_funcs_t;
119
120/*
121 * Terminal state.
122 */
123
124struct __teken {
125	const teken_funcs_t *t_funcs;
126	void		*t_softc;
127
128	teken_state_t	*t_nextstate;
129	unsigned int	 t_stateflags;
130
131#define T_NUMSIZE	8
132	unsigned int	 t_nums[T_NUMSIZE];
133	unsigned int	 t_curnum;
134
135	teken_pos_t	 t_cursor;
136	teken_attr_t	 t_curattr;
137	teken_pos_t	 t_saved_cursor;
138	teken_attr_t	 t_saved_curattr;
139
140	teken_attr_t	 t_defattr;
141	teken_pos_t	 t_winsize;
142
143	/* For DECSTBM. */
144	teken_span_t	 t_scrollreg;
145	/* For DECOM. */
146	teken_span_t	 t_originreg;
147
148#define	T_NUMCOL	160
149	unsigned int	t_tabstops[T_NUMCOL / (sizeof(unsigned int) * 8)];
150
151#ifdef TEKEN_UTF8
152	unsigned int	t_utf8_left;
153	teken_char_t	t_utf8_partial;
154#endif /* TEKEN_UTF8 */
155};
156
157/* Initialize teken structure. */
158void	teken_init(teken_t *, const teken_funcs_t *, void *);
159
160/* Deliver character input. */
161void	teken_input(teken_t *, const void *, size_t);
162
163/* Set teken attributes. */
164void	teken_set_cursor(teken_t *, const teken_pos_t *);
165void	teken_set_defattr(teken_t *, const teken_attr_t *);
166void	teken_set_winsize(teken_t *, const teken_pos_t *);
167
168#endif /* !_TEKEN_H_ */
169