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_DFASTATE 9 #define SKSL_DFASTATE 10 11 #include "LexUtil.h" 12 13 struct DFAState { 14 struct Label { 15 std::vector<int> fStates; 16 LabelDFAState::Label17 Label(std::vector<int> states) 18 : fStates(std::move(states)) {} 19 20 bool operator==(const Label& other) const { 21 return fStates == other.fStates; 22 } 23 24 bool operator!=(const Label& other) const { 25 return !(*this == other); 26 } 27 descriptionDFAState::Label28 std::string description() const { 29 std::string result = "<"; 30 const char* separator = ""; 31 for (int s : fStates) { 32 result += separator; 33 result += std::to_string(s); 34 separator = ", "; 35 } 36 result += ">"; 37 return result; 38 } 39 }; 40 DFAStateDFAState41 DFAState() 42 : fId(INVALID) 43 , fLabel({}) {} 44 DFAStateDFAState45 DFAState(int id, Label label) 46 : fId(id) 47 , fLabel(std::move(label)) {} 48 49 DFAState(const DFAState& other) = delete; 50 51 int fId; 52 53 Label fLabel; 54 55 bool fIsScanned = false; 56 }; 57 58 namespace std { 59 template<> struct hash<DFAState::Label> { 60 size_t operator()(const DFAState::Label& s) const { 61 size_t result = 0; 62 for (int i : s.fStates) { 63 result = result * 101 + i; 64 } 65 return result; 66 } 67 }; 68 } // namespace 69 70 #endif 71