-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPatternMatcher.h
59 lines (51 loc) · 1.78 KB
/
PatternMatcher.h
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
/***********************************************************************
* Copyright 2007-2010 Michael Drueing <[email protected]>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of
* the License or (at your option) version 3 or any later version
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
***********************************************************************/
/*
* Implementation of the Aho-Corasick pattern matching DFA
*/
#ifndef PATTERN_MATCHER_H
#define PATTERN_MATCHER_H
#include "Ripper.h"
class PatternMatcher
{
public:
// This is one node of the Trie/DFA
struct ACNode
{
struct ACNode *g[256]; // one output for each byte value
// TODO: Do something with multiple rippers matching the same pattern
// (we'll handle it when it happens ;-)
const struct HeaderStruct *header; // or NULL if no header matches
Ripper *ripper; // or NULL if this is not a terminal node
struct ACNode *f; // the failure node
};
private:
// this is the root of the Trie/DFA
ACNode *rootNode;
ACNode *currentNode;
ACNode *GetNode(ACNode *n);
void DestroyNode(ACNode *node);
void InitNode(ACNode *n);
public:
PatternMatcher();
void AddPattern(const HeaderStruct *header, Ripper *ripper);
void FinalizeMatcher();
void BeginSearch();
bool NextByte(unsigned char ch, ACNode **finalState);
~PatternMatcher();
};
#endif