xref: /aosp_15_r20/external/pigweed/pw_tokenizer/token_database.cc (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1*61c4878aSAndroid Build Coastguard Worker // Copyright 2020 The Pigweed Authors
2*61c4878aSAndroid Build Coastguard Worker //
3*61c4878aSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); you may not
4*61c4878aSAndroid Build Coastguard Worker // use this file except in compliance with the License. You may obtain a copy of
5*61c4878aSAndroid Build Coastguard Worker // the License at
6*61c4878aSAndroid Build Coastguard Worker //
7*61c4878aSAndroid Build Coastguard Worker //     https://www.apache.org/licenses/LICENSE-2.0
8*61c4878aSAndroid Build Coastguard Worker //
9*61c4878aSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*61c4878aSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11*61c4878aSAndroid Build Coastguard Worker // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12*61c4878aSAndroid Build Coastguard Worker // License for the specific language governing permissions and limitations under
13*61c4878aSAndroid Build Coastguard Worker // the License.
14*61c4878aSAndroid Build Coastguard Worker 
15*61c4878aSAndroid Build Coastguard Worker #include "pw_tokenizer/token_database.h"
16*61c4878aSAndroid Build Coastguard Worker 
17*61c4878aSAndroid Build Coastguard Worker namespace pw::tokenizer {
18*61c4878aSAndroid Build Coastguard Worker 
operator [](size_t index) const19*61c4878aSAndroid Build Coastguard Worker TokenDatabase::Entry TokenDatabase::Entries::operator[](size_t index) const {
20*61c4878aSAndroid Build Coastguard Worker   iterator it = begin();
21*61c4878aSAndroid Build Coastguard Worker   for (size_t i = 0; i < index; ++i) {
22*61c4878aSAndroid Build Coastguard Worker     ++it;
23*61c4878aSAndroid Build Coastguard Worker   }
24*61c4878aSAndroid Build Coastguard Worker   return *it;
25*61c4878aSAndroid Build Coastguard Worker }
26*61c4878aSAndroid Build Coastguard Worker 
Find(const uint32_t token) const27*61c4878aSAndroid Build Coastguard Worker TokenDatabase::Entries TokenDatabase::Find(const uint32_t token) const {
28*61c4878aSAndroid Build Coastguard Worker   iterator first = begin();
29*61c4878aSAndroid Build Coastguard Worker   while (first != end() && token > first->token) {
30*61c4878aSAndroid Build Coastguard Worker     ++first;
31*61c4878aSAndroid Build Coastguard Worker   }
32*61c4878aSAndroid Build Coastguard Worker 
33*61c4878aSAndroid Build Coastguard Worker   iterator last = first;
34*61c4878aSAndroid Build Coastguard Worker   while (last != end() && token == last->token) {
35*61c4878aSAndroid Build Coastguard Worker     ++last;
36*61c4878aSAndroid Build Coastguard Worker   }
37*61c4878aSAndroid Build Coastguard Worker 
38*61c4878aSAndroid Build Coastguard Worker   return Entries(first, last);
39*61c4878aSAndroid Build Coastguard Worker }
40*61c4878aSAndroid Build Coastguard Worker 
41*61c4878aSAndroid Build Coastguard Worker }  // namespace pw::tokenizer
42