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 WorkerTokenDatabase::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 WorkerTokenDatabase::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