1 /* 2 * Copyright (C) 2018 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 #ifndef LIBTEXTCLASSIFIER_UTILS_REGEX_MATCH_H_ 18 #define LIBTEXTCLASSIFIER_UTILS_REGEX_MATCH_H_ 19 20 #include "utils/flatbuffers.h" 21 #include "utils/flatbuffers_generated.h" 22 #include "utils/utf8/unilib.h" 23 24 namespace libtextclassifier3 { 25 // Sets a field in the flatbuffer from a regex match group. 26 // Returns true if successful, and false if the field couldn't be set. 27 bool SetFieldFromCapturingGroup(const int group_id, 28 const FlatbufferFieldPath* field_path, 29 const UniLib::RegexMatcher* matcher, 30 ReflectiveFlatbuffer* flatbuffer); 31 32 // Post-checks a regular expression match with a lua verifier script. 33 // The verifier can access: 34 // * `context`: The context as a string. 35 // * `match`: The groups of the regex match as an array, each group gives 36 // * `begin`: span start 37 // * `end`: span end 38 // * `text`: the text 39 // The verifier is expected to return a boolean, indicating whether the 40 // verification succeeded or not. 41 // Returns true if the verification was successful, false if not. 42 bool VerifyMatch(const std::string& context, 43 const UniLib::RegexMatcher* matcher, 44 const std::string& lua_verifier_code); 45 46 } // namespace libtextclassifier3 47 48 #endif // LIBTEXTCLASSIFIER_UTILS_REGEX_MATCH_H_ 49