forked from Ikcelaks/qmk_sequence_transform
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpredicates.c
More file actions
107 lines (105 loc) · 3.63 KB
/
predicates.c
File metadata and controls
107 lines (105 loc) · 3.63 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
// Copyright 2024 Guillaume Stordeur <guillaume.stordeur@gmail.com>
// Copyright 2024 Matt Skalecki <ikcelaks@gmail.com>
// Copyright 2024 QKekos <q.kekos.q@gmail.com>
// SPDX-License-Identifier: Apache-2.0
#include "qmk_wrapper.h"
#include "st_assert.h"
#include "st_debug.h"
#include "predicates.h"
//////////////////////////////////////////////////////////////////////
bool st_pred_upper_alpha(uint8_t triecode)
{
const bool res = triecode >= 'A' && triecode <= 'Z';
st_debug(ST_DBG_SEQ_MATCH, " st_pred_upper_alpha: Res: %d; Code: %#04X\n", res, triecode);
return res;
}
//////////////////////////////////////////////////////////////////////
bool st_pred_alpha(uint8_t triecode)
{
const bool res = (triecode >= 'A' && triecode <= 'Z') || (triecode >= 'a' && triecode <= 'z');
st_debug(ST_DBG_SEQ_MATCH, " st_pred_alpha: Res: %d; Code: %#04X\n", res, triecode);
return res;
}
//////////////////////////////////////////////////////////////////////
bool st_pred_digit(uint8_t triecode)
{
const bool res = triecode >= '0' && triecode <= '9';
st_debug(ST_DBG_SEQ_MATCH, " st_pred_digit: Res: %d; Code: %#04X\n", res, triecode);
return res;
}
//////////////////////////////////////////////////////////////////////
bool st_pred_terminating_punct(uint8_t triecode)
{
bool res;
switch (triecode) {
case '.':
case '!':
case '?':
res = true;
break;
default:
res = false;
break;
}
st_debug(ST_DBG_SEQ_MATCH, " st_pred_terminating_punct: Res: %d; Code: %#04X\n", res, triecode);
return res;
}
//////////////////////////////////////////////////////////////////////
bool st_pred_nonterminating_punct(uint8_t triecode)
{
bool res;
switch (triecode) {
case ',':
case ';':
case ':':
res = true;
break;
default:
res = false;
break;
}
st_debug(ST_DBG_SEQ_MATCH, " st_pred_nonterminating_punct: Res: %d; Code: %#04X\n", res, triecode);
return res;
}
//////////////////////////////////////////////////////////////////////
bool st_pred_punct(uint8_t triecode)
{
const bool res = st_pred_terminating_punct(triecode) || st_pred_nonterminating_punct(triecode);
st_debug(ST_DBG_SEQ_MATCH, " st_pred_punct: Res: %d; Code: %#04X\n", res, triecode);
return res;
}
//////////////////////////////////////////////////////////////////////
bool st_pred_nonalpha(uint8_t triecode)
{
const bool res = triecode < 0x80 && !st_pred_alpha(triecode);
st_debug(ST_DBG_SEQ_MATCH, " st_pred_nonalpha: Res: %d; Code: %#04X\n", res, triecode);
return res;
}
//////////////////////////////////////////////////////////////////////
bool st_pred_any(uint8_t triecode)
{
const bool res = true;
st_debug(ST_DBG_SEQ_MATCH, " st_pred_any: Res: %d; Code: %#04X\n", res, triecode);
return res;
}
//////////////////////////////////////////////////////////////////////
static const st_predicate_t st_predicates[ST_PREDICATE_COUNT] = {
st_pred_upper_alpha,
st_pred_alpha,
st_pred_digit,
st_pred_terminating_punct,
st_pred_nonterminating_punct,
st_pred_punct,
st_pred_nonalpha,
st_pred_any
};
//////////////////////////////////////////////////////////////////////
bool st_predicate_test_triecode(uint8_t predicate_index, uint8_t triecode)
{
st_assert(predicate_index < ST_PREDICATE_COUNT, "Error: attempted to test predicate %d, which is past the last predicat %d",
predicate_index, ST_PREDICATE_COUNT - 1);
if (predicate_index >= ST_PREDICATE_COUNT) {
return false;
}
return st_predicates[predicate_index](triecode);
}