1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2017 Google Inc. 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard Worker #ifndef SKSL_REGEXNODE 9*c8dee2aaSAndroid Build Coastguard Worker #define SKSL_REGEXNODE 10*c8dee2aaSAndroid Build Coastguard Worker 11*c8dee2aaSAndroid Build Coastguard Worker #include <string> 12*c8dee2aaSAndroid Build Coastguard Worker #include <utility> 13*c8dee2aaSAndroid Build Coastguard Worker #include <vector> 14*c8dee2aaSAndroid Build Coastguard Worker 15*c8dee2aaSAndroid Build Coastguard Worker struct NFA; 16*c8dee2aaSAndroid Build Coastguard Worker 17*c8dee2aaSAndroid Build Coastguard Worker /** 18*c8dee2aaSAndroid Build Coastguard Worker * Represents a node in the parse tree of a regular expression. 19*c8dee2aaSAndroid Build Coastguard Worker */ 20*c8dee2aaSAndroid Build Coastguard Worker struct RegexNode { 21*c8dee2aaSAndroid Build Coastguard Worker enum Kind { 22*c8dee2aaSAndroid Build Coastguard Worker kChar_Kind, 23*c8dee2aaSAndroid Build Coastguard Worker kCharset_Kind, 24*c8dee2aaSAndroid Build Coastguard Worker kConcat_Kind, 25*c8dee2aaSAndroid Build Coastguard Worker kDot_Kind, 26*c8dee2aaSAndroid Build Coastguard Worker kOr_Kind, 27*c8dee2aaSAndroid Build Coastguard Worker kPlus_Kind, 28*c8dee2aaSAndroid Build Coastguard Worker kRange_Kind, 29*c8dee2aaSAndroid Build Coastguard Worker kQuestion_Kind, 30*c8dee2aaSAndroid Build Coastguard Worker kStar_Kind 31*c8dee2aaSAndroid Build Coastguard Worker }; 32*c8dee2aaSAndroid Build Coastguard Worker RegexNodeRegexNode33*c8dee2aaSAndroid Build Coastguard Worker RegexNode(Kind kind) 34*c8dee2aaSAndroid Build Coastguard Worker : fKind(kind) {} 35*c8dee2aaSAndroid Build Coastguard Worker RegexNodeRegexNode36*c8dee2aaSAndroid Build Coastguard Worker RegexNode(Kind kind, char payload) 37*c8dee2aaSAndroid Build Coastguard Worker : fKind(kind) { 38*c8dee2aaSAndroid Build Coastguard Worker fPayload.fChar = payload; 39*c8dee2aaSAndroid Build Coastguard Worker } 40*c8dee2aaSAndroid Build Coastguard Worker RegexNodeRegexNode41*c8dee2aaSAndroid Build Coastguard Worker RegexNode(Kind kind, const char* children) 42*c8dee2aaSAndroid Build Coastguard Worker : fKind(kind) { 43*c8dee2aaSAndroid Build Coastguard Worker fPayload.fBool = false; 44*c8dee2aaSAndroid Build Coastguard Worker while (*children != '\0') { 45*c8dee2aaSAndroid Build Coastguard Worker fChildren.emplace_back(kChar_Kind, *children); 46*c8dee2aaSAndroid Build Coastguard Worker ++children; 47*c8dee2aaSAndroid Build Coastguard Worker } 48*c8dee2aaSAndroid Build Coastguard Worker } 49*c8dee2aaSAndroid Build Coastguard Worker RegexNodeRegexNode50*c8dee2aaSAndroid Build Coastguard Worker RegexNode(Kind kind, RegexNode child) 51*c8dee2aaSAndroid Build Coastguard Worker : fKind(kind) { 52*c8dee2aaSAndroid Build Coastguard Worker fChildren.push_back(std::move(child)); 53*c8dee2aaSAndroid Build Coastguard Worker } 54*c8dee2aaSAndroid Build Coastguard Worker RegexNodeRegexNode55*c8dee2aaSAndroid Build Coastguard Worker RegexNode(Kind kind, RegexNode child1, RegexNode child2) 56*c8dee2aaSAndroid Build Coastguard Worker : fKind(kind) { 57*c8dee2aaSAndroid Build Coastguard Worker fChildren.push_back(std::move(child1)); 58*c8dee2aaSAndroid Build Coastguard Worker fChildren.push_back(std::move(child2)); 59*c8dee2aaSAndroid Build Coastguard Worker } 60*c8dee2aaSAndroid Build Coastguard Worker 61*c8dee2aaSAndroid Build Coastguard Worker /** 62*c8dee2aaSAndroid Build Coastguard Worker * Creates NFA states for this node, with a successful match against this node resulting in a 63*c8dee2aaSAndroid Build Coastguard Worker * transition to all of the states in the accept vector. 64*c8dee2aaSAndroid Build Coastguard Worker */ 65*c8dee2aaSAndroid Build Coastguard Worker std::vector<int> createStates(NFA* nfa, const std::vector<int>& accept) const; 66*c8dee2aaSAndroid Build Coastguard Worker 67*c8dee2aaSAndroid Build Coastguard Worker std::string description() const; 68*c8dee2aaSAndroid Build Coastguard Worker 69*c8dee2aaSAndroid Build Coastguard Worker Kind fKind; 70*c8dee2aaSAndroid Build Coastguard Worker 71*c8dee2aaSAndroid Build Coastguard Worker union Payload { 72*c8dee2aaSAndroid Build Coastguard Worker char fChar; 73*c8dee2aaSAndroid Build Coastguard Worker bool fBool; 74*c8dee2aaSAndroid Build Coastguard Worker } fPayload; 75*c8dee2aaSAndroid Build Coastguard Worker 76*c8dee2aaSAndroid Build Coastguard Worker std::vector<RegexNode> fChildren; 77*c8dee2aaSAndroid Build Coastguard Worker }; 78*c8dee2aaSAndroid Build Coastguard Worker 79*c8dee2aaSAndroid Build Coastguard Worker #endif 80