1*4d7e907cSAndroid Build Coastguard Worker /*
2*4d7e907cSAndroid Build Coastguard Worker * Copyright (C) 2017 The Android Open Source Project
3*4d7e907cSAndroid Build Coastguard Worker *
4*4d7e907cSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
5*4d7e907cSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
6*4d7e907cSAndroid Build Coastguard Worker * You may obtain a copy of the License at
7*4d7e907cSAndroid Build Coastguard Worker *
8*4d7e907cSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
9*4d7e907cSAndroid Build Coastguard Worker *
10*4d7e907cSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
11*4d7e907cSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
12*4d7e907cSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*4d7e907cSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
14*4d7e907cSAndroid Build Coastguard Worker * limitations under the License.
15*4d7e907cSAndroid Build Coastguard Worker */
16*4d7e907cSAndroid Build Coastguard Worker
17*4d7e907cSAndroid Build Coastguard Worker #define LOG_TAG "hidl_test"
18*4d7e907cSAndroid Build Coastguard Worker
19*4d7e907cSAndroid Build Coastguard Worker #include "Trie.h"
20*4d7e907cSAndroid Build Coastguard Worker #include <android-base/logging.h>
21*4d7e907cSAndroid Build Coastguard Worker #include <inttypes.h>
22*4d7e907cSAndroid Build Coastguard Worker #include <string>
23*4d7e907cSAndroid Build Coastguard Worker
24*4d7e907cSAndroid Build Coastguard Worker namespace android {
25*4d7e907cSAndroid Build Coastguard Worker namespace hardware {
26*4d7e907cSAndroid Build Coastguard Worker namespace tests {
27*4d7e907cSAndroid Build Coastguard Worker namespace trie {
28*4d7e907cSAndroid Build Coastguard Worker namespace V1_0 {
29*4d7e907cSAndroid Build Coastguard Worker namespace implementation {
30*4d7e907cSAndroid Build Coastguard Worker
31*4d7e907cSAndroid Build Coastguard Worker // Methods from ::android::hardware::tests::trie::V1_0::ITrie follow.
newTrie(newTrie_cb _hidl_cb)32*4d7e907cSAndroid Build Coastguard Worker Return<void> Trie::newTrie(newTrie_cb _hidl_cb) {
33*4d7e907cSAndroid Build Coastguard Worker LOG(INFO) << "SERVER(Trie) newTrie()";
34*4d7e907cSAndroid Build Coastguard Worker
35*4d7e907cSAndroid Build Coastguard Worker TrieNode ret;
36*4d7e907cSAndroid Build Coastguard Worker ret.isTerminal = false;
37*4d7e907cSAndroid Build Coastguard Worker _hidl_cb(ret);
38*4d7e907cSAndroid Build Coastguard Worker return Void();
39*4d7e907cSAndroid Build Coastguard Worker }
40*4d7e907cSAndroid Build Coastguard Worker
addStrings(const TrieNode & trie,const hidl_vec<hidl_string> & strings,addStrings_cb _hidl_cb)41*4d7e907cSAndroid Build Coastguard Worker Return<void> Trie::addStrings(const TrieNode& trie, const hidl_vec<hidl_string>& strings,
42*4d7e907cSAndroid Build Coastguard Worker addStrings_cb _hidl_cb) {
43*4d7e907cSAndroid Build Coastguard Worker LOG(INFO) << "SERVER(Trie) addStrings(trie, " << strings.size() << " strings)";
44*4d7e907cSAndroid Build Coastguard Worker
45*4d7e907cSAndroid Build Coastguard Worker // Make trie modifiable.
46*4d7e907cSAndroid Build Coastguard Worker TrieNode newTrie = trie;
47*4d7e907cSAndroid Build Coastguard Worker
48*4d7e907cSAndroid Build Coastguard Worker for (const auto& str : strings) {
49*4d7e907cSAndroid Build Coastguard Worker addString(&newTrie, str);
50*4d7e907cSAndroid Build Coastguard Worker }
51*4d7e907cSAndroid Build Coastguard Worker _hidl_cb(newTrie);
52*4d7e907cSAndroid Build Coastguard Worker return Void();
53*4d7e907cSAndroid Build Coastguard Worker }
54*4d7e907cSAndroid Build Coastguard Worker
containsStrings(const TrieNode & trie,const hidl_vec<hidl_string> & strings,containsStrings_cb _hidl_cb)55*4d7e907cSAndroid Build Coastguard Worker Return<void> Trie::containsStrings(const TrieNode& trie, const hidl_vec<hidl_string>& strings,
56*4d7e907cSAndroid Build Coastguard Worker containsStrings_cb _hidl_cb) {
57*4d7e907cSAndroid Build Coastguard Worker LOG(INFO) << "SERVER(Trie) containsStrings(trie, " << strings.size() << " strings)";
58*4d7e907cSAndroid Build Coastguard Worker
59*4d7e907cSAndroid Build Coastguard Worker std::vector<bool> ret(strings.size());
60*4d7e907cSAndroid Build Coastguard Worker for (size_t i = 0; i != strings.size(); ++i) {
61*4d7e907cSAndroid Build Coastguard Worker ret[i] = containsString(&trie, strings[i]);
62*4d7e907cSAndroid Build Coastguard Worker }
63*4d7e907cSAndroid Build Coastguard Worker _hidl_cb(ret);
64*4d7e907cSAndroid Build Coastguard Worker return Void();
65*4d7e907cSAndroid Build Coastguard Worker }
66*4d7e907cSAndroid Build Coastguard Worker
addString(TrieNode * trieRoot,const std::string & str)67*4d7e907cSAndroid Build Coastguard Worker void Trie::addString(TrieNode* trieRoot, const std::string& str) {
68*4d7e907cSAndroid Build Coastguard Worker TrieNode* currNode = trieRoot;
69*4d7e907cSAndroid Build Coastguard Worker
70*4d7e907cSAndroid Build Coastguard Worker for (char ch : str) {
71*4d7e907cSAndroid Build Coastguard Worker auto& vec = currNode->next;
72*4d7e907cSAndroid Build Coastguard Worker
73*4d7e907cSAndroid Build Coastguard Worker auto it = std::find_if(vec.begin(), vec.end(),
74*4d7e907cSAndroid Build Coastguard Worker [&](const TrieEdge& edge) { return ch == edge.character; });
75*4d7e907cSAndroid Build Coastguard Worker
76*4d7e907cSAndroid Build Coastguard Worker if (it == vec.end()) {
77*4d7e907cSAndroid Build Coastguard Worker vec.resize(vec.size() + 1);
78*4d7e907cSAndroid Build Coastguard Worker it = vec.end() - 1;
79*4d7e907cSAndroid Build Coastguard Worker it->character = ch;
80*4d7e907cSAndroid Build Coastguard Worker it->node.isTerminal = false;
81*4d7e907cSAndroid Build Coastguard Worker }
82*4d7e907cSAndroid Build Coastguard Worker
83*4d7e907cSAndroid Build Coastguard Worker currNode = &(it->node);
84*4d7e907cSAndroid Build Coastguard Worker }
85*4d7e907cSAndroid Build Coastguard Worker
86*4d7e907cSAndroid Build Coastguard Worker currNode->isTerminal = true;
87*4d7e907cSAndroid Build Coastguard Worker }
88*4d7e907cSAndroid Build Coastguard Worker
containsString(const TrieNode * trieRoot,const std::string & str)89*4d7e907cSAndroid Build Coastguard Worker bool Trie::containsString(const TrieNode* trieRoot, const std::string& str) {
90*4d7e907cSAndroid Build Coastguard Worker const TrieNode* currNode = trieRoot;
91*4d7e907cSAndroid Build Coastguard Worker
92*4d7e907cSAndroid Build Coastguard Worker for (char ch : str) {
93*4d7e907cSAndroid Build Coastguard Worker const auto& vec = currNode->next;
94*4d7e907cSAndroid Build Coastguard Worker
95*4d7e907cSAndroid Build Coastguard Worker auto it = std::find_if(vec.begin(), vec.end(),
96*4d7e907cSAndroid Build Coastguard Worker [&](const TrieEdge& edge) { return ch == edge.character; });
97*4d7e907cSAndroid Build Coastguard Worker
98*4d7e907cSAndroid Build Coastguard Worker if (it == vec.end()) return false;
99*4d7e907cSAndroid Build Coastguard Worker currNode = &(it->node);
100*4d7e907cSAndroid Build Coastguard Worker }
101*4d7e907cSAndroid Build Coastguard Worker
102*4d7e907cSAndroid Build Coastguard Worker return currNode->isTerminal;
103*4d7e907cSAndroid Build Coastguard Worker }
104*4d7e907cSAndroid Build Coastguard Worker
HIDL_FETCH_ITrie(const char *)105*4d7e907cSAndroid Build Coastguard Worker ITrie* HIDL_FETCH_ITrie(const char* /* name */) {
106*4d7e907cSAndroid Build Coastguard Worker return new Trie();
107*4d7e907cSAndroid Build Coastguard Worker }
108*4d7e907cSAndroid Build Coastguard Worker
109*4d7e907cSAndroid Build Coastguard Worker } // namespace implementation
110*4d7e907cSAndroid Build Coastguard Worker } // namespace V1_0
111*4d7e907cSAndroid Build Coastguard Worker } // namespace trie
112*4d7e907cSAndroid Build Coastguard Worker } // namespace tests
113*4d7e907cSAndroid Build Coastguard Worker } // namespace hardware
114*4d7e907cSAndroid Build Coastguard Worker } // namespace android
115