1 /*
2  * Copyright 2017 Google Inc.
3  *
4  * Use of this source code is governed by a BSD-style license that can be
5  * found in the LICENSE file.
6  */
7 
8 #ifndef SKSL_DFA
9 #define SKSL_DFA
10 
11 #include <string>
12 #include <vector>
13 
14 /**
15  * Tables representing a deterministic finite automaton for matching regular expressions.
16  */
17 struct DFA {
18     DFA(std::vector<int> charMappings, std::vector<std::vector<int>> transitions,
19         std::vector<int> accepts)
20     : fCharMappings(charMappings)
21     , fTransitions(transitions)
22     , fAccepts(accepts) {}
23 
24     // maps chars to the row index of fTransitions, as multiple characters may map to the same row.
25     // starting from state s and looking at char c, the new state is
26     // fTransitions[fCharMappings[c]][s].
27     std::vector<int> fCharMappings;
28 
29     // one row per character mapping, one column per state
30     std::vector<std::vector<int>> fTransitions;
31 
32     // contains, for each state, the token id we should report when matching ends in that state (-1
33     // for no match)
34     std::vector<int> fAccepts;
35 };
36 
37 #endif
38