1 | /**
|
---|
2 | * @file vtrecv.h
|
---|
3 | * @author CuBeatSystems
|
---|
4 | * @author Shinichiro Nakamura
|
---|
5 | * @copyright
|
---|
6 | * ===============================================================
|
---|
7 | * Natural Tiny Shell (NT-Shell) Version 0.3.1
|
---|
8 | * ===============================================================
|
---|
9 | * Copyright (c) 2010-2016 Shinichiro Nakamura
|
---|
10 | *
|
---|
11 | * Permission is hereby granted, free of charge, to any person
|
---|
12 | * obtaining a copy of this software and associated documentation
|
---|
13 | * files (the "Software"), to deal in the Software without
|
---|
14 | * restriction, including without limitation the rights to use,
|
---|
15 | * copy, modify, merge, publish, distribute, sublicense, and/or
|
---|
16 | * sell copies of the Software, and to permit persons to whom the
|
---|
17 | * Software is furnished to do so, subject to the following
|
---|
18 | * conditions:
|
---|
19 | *
|
---|
20 | * The above copyright notice and this permission notice shall be
|
---|
21 | * included in all copies or substantial portions of the Software.
|
---|
22 | *
|
---|
23 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
---|
24 | * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
---|
25 | * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
---|
26 | * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
---|
27 | * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
---|
28 | * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
---|
29 | * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
---|
30 | * OTHER DEALINGS IN THE SOFTWARE.
|
---|
31 | */
|
---|
32 |
|
---|
33 | /*
|
---|
34 | * @note
|
---|
35 | * An implementation of Paul Williams' DEC compatible state machine parser.
|
---|
36 | * This code is in the public domain.
|
---|
37 | *
|
---|
38 | * @author Joshua Haberman <joshua@reverberate.org>
|
---|
39 | * @author Shinichiro Nakamura : Modified for Natural Tiny Shell (NT-Shell)
|
---|
40 | */
|
---|
41 |
|
---|
42 | #ifndef VTRECV_H
|
---|
43 | #define VTRECV_H
|
---|
44 |
|
---|
45 | /**
|
---|
46 | * @brief オリジナルに含まれるLUTを使うかどうかを決定する。
|
---|
47 | * @details
|
---|
48 | * オリジナルでは、シーケンスの遷移をテーブル参照で実装してあった。
|
---|
49 | * 15のステートで取りうる256パターンの入力を全網羅するテーブルである。
|
---|
50 | * これは3840個のテーブルデータを持つことになる。
|
---|
51 | *
|
---|
52 | * テーブル参照はメモリに対してリニアアクセス可能なプロセッサにおいて
|
---|
53 | * 固定時間で動作する。テーブル参照のメリットは固定時間での処理である。
|
---|
54 | *
|
---|
55 | * 一方、新たに実装した方法は、重複するデータが多数存在する事に着目した
|
---|
56 | * もので、区間毎に適用するシーケンスを定義したテーブルを用いる。
|
---|
57 | * これはテーブルを線形探索するため後方にあるデータになるほど動作は遅い。
|
---|
58 | * しかし、コードサイズはオリジナルの全網羅形式のテーブルよりも小さい。
|
---|
59 | *
|
---|
60 | * @retval 0 使わない。
|
---|
61 | * @retval 1 使う。
|
---|
62 | */
|
---|
63 | #define USE_ORIGINAL_LUT (0)
|
---|
64 |
|
---|
65 | #define MAX_INTERMEDIATE_CHARS 2
|
---|
66 | #define ACTION(state_change) (vtrecv_action_t)((state_change & 0x0F) >> 0)
|
---|
67 | #define STATE(state_change) (vtrecv_state_t)((state_change & 0xF0) >> 4)
|
---|
68 |
|
---|
69 | typedef enum {
|
---|
70 | VTRECV_STATE_CSI_ENTRY = 1,
|
---|
71 | VTRECV_STATE_CSI_IGNORE = 2,
|
---|
72 | VTRECV_STATE_CSI_INTERMEDIATE = 3,
|
---|
73 | VTRECV_STATE_CSI_PARAM = 4,
|
---|
74 | VTRECV_STATE_DCS_ENTRY = 5,
|
---|
75 | VTRECV_STATE_DCS_IGNORE = 6,
|
---|
76 | VTRECV_STATE_DCS_INTERMEDIATE = 7,
|
---|
77 | VTRECV_STATE_DCS_PARAM = 8,
|
---|
78 | VTRECV_STATE_DCS_PASSTHROUGH = 9,
|
---|
79 | VTRECV_STATE_ESCAPE = 10,
|
---|
80 | VTRECV_STATE_ESCAPE_INTERMEDIATE = 11,
|
---|
81 | VTRECV_STATE_GROUND = 12,
|
---|
82 | VTRECV_STATE_OSC_STRING = 13,
|
---|
83 | VTRECV_STATE_SOS_PM_APC_STRING = 14,
|
---|
84 | } vtrecv_state_t;
|
---|
85 |
|
---|
86 | typedef enum {
|
---|
87 | VTRECV_ACTION_CLEAR = 1,
|
---|
88 | VTRECV_ACTION_COLLECT = 2,
|
---|
89 | VTRECV_ACTION_CSI_DISPATCH = 3,
|
---|
90 | VTRECV_ACTION_ESC_DISPATCH = 4,
|
---|
91 | VTRECV_ACTION_EXECUTE = 5,
|
---|
92 | VTRECV_ACTION_HOOK = 6,
|
---|
93 | VTRECV_ACTION_IGNORE = 7,
|
---|
94 | VTRECV_ACTION_OSC_END = 8,
|
---|
95 | VTRECV_ACTION_OSC_PUT = 9,
|
---|
96 | VTRECV_ACTION_OSC_START = 10,
|
---|
97 | VTRECV_ACTION_PARAM = 11,
|
---|
98 | VTRECV_ACTION_PRINT = 12,
|
---|
99 | VTRECV_ACTION_PUT = 13,
|
---|
100 | VTRECV_ACTION_UNHOOK = 14,
|
---|
101 | VTRECV_ACTION_ERROR = 15,
|
---|
102 | } vtrecv_action_t;
|
---|
103 |
|
---|
104 | typedef unsigned char state_change_t;
|
---|
105 | struct vtrecv;
|
---|
106 | typedef void (*vtrecv_callback_t)(struct vtrecv*, vtrecv_action_t, unsigned int);
|
---|
107 | typedef struct vtrecv {
|
---|
108 | int utf8_state;
|
---|
109 | unsigned int ch;
|
---|
110 | vtrecv_state_t state;
|
---|
111 | vtrecv_callback_t cb;
|
---|
112 | unsigned char intermediate_chars[MAX_INTERMEDIATE_CHARS+1];
|
---|
113 | int num_intermediate_chars;
|
---|
114 | char ignore_flagged;
|
---|
115 | int params[16];
|
---|
116 | int num_params;
|
---|
117 | void* user_data;
|
---|
118 | } vtrecv_t;
|
---|
119 |
|
---|
120 | #ifdef __cplusplus
|
---|
121 | extern "C" {
|
---|
122 | #endif
|
---|
123 |
|
---|
124 | void vtrecv_init(vtrecv_t *parser, vtrecv_callback_t cb);
|
---|
125 | void vtrecv_execute(vtrecv_t *parser, unsigned char *data, int len);
|
---|
126 |
|
---|
127 | #ifdef __cplusplus
|
---|
128 | }
|
---|
129 | #endif
|
---|
130 |
|
---|
131 | #endif
|
---|
132 |
|
---|