/* * Copyright (C) 2017 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #define LOG_TAG "hidl_test" #include "Trie.h" #include #include #include namespace android { namespace hardware { namespace tests { namespace trie { namespace V1_0 { namespace implementation { // Methods from ::android::hardware::tests::trie::V1_0::ITrie follow. Return Trie::newTrie(newTrie_cb _hidl_cb) { LOG(INFO) << "SERVER(Trie) newTrie()"; TrieNode ret; ret.isTerminal = false; _hidl_cb(ret); return Void(); } Return Trie::addStrings(const TrieNode& trie, const hidl_vec& strings, addStrings_cb _hidl_cb) { LOG(INFO) << "SERVER(Trie) addStrings(trie, " << strings.size() << " strings)"; // Make trie modifiable. TrieNode newTrie = trie; for (const auto& str : strings) { addString(&newTrie, str); } _hidl_cb(newTrie); return Void(); } Return Trie::containsStrings(const TrieNode& trie, const hidl_vec& strings, containsStrings_cb _hidl_cb) { LOG(INFO) << "SERVER(Trie) containsStrings(trie, " << strings.size() << " strings)"; std::vector ret(strings.size()); for (size_t i = 0; i != strings.size(); ++i) { ret[i] = containsString(&trie, strings[i]); } _hidl_cb(ret); return Void(); } void Trie::addString(TrieNode* trieRoot, const std::string& str) { TrieNode* currNode = trieRoot; for (char ch : str) { auto& vec = currNode->next; auto it = std::find_if(vec.begin(), vec.end(), [&](const TrieEdge& edge) { return ch == edge.character; }); if (it == vec.end()) { vec.resize(vec.size() + 1); it = vec.end() - 1; it->character = ch; it->node.isTerminal = false; } currNode = &(it->node); } currNode->isTerminal = true; } bool Trie::containsString(const TrieNode* trieRoot, const std::string& str) { const TrieNode* currNode = trieRoot; for (char ch : str) { const auto& vec = currNode->next; auto it = std::find_if(vec.begin(), vec.end(), [&](const TrieEdge& edge) { return ch == edge.character; }); if (it == vec.end()) return false; currNode = &(it->node); } return currNode->isTerminal; } ITrie* HIDL_FETCH_ITrie(const char* /* name */) { return new Trie(); } } // namespace implementation } // namespace V1_0 } // namespace trie } // namespace tests } // namespace hardware } // namespace android