| // Copyright 2023 Google LLC | 
 | // | 
 | // 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. | 
 |  | 
 | #ifndef TESTS_VERILATOR_SIM_FIFO_H_ | 
 | #define TESTS_VERILATOR_SIM_FIFO_H_ | 
 |  | 
 | #include <vector> | 
 |  | 
 | // A SystemC CRT transaction queue. | 
 |  | 
 | template <typename T> | 
 | class fifo_t { | 
 |  public: | 
 |   bool empty() { return entries_.empty(); } | 
 |  | 
 |   void write(T v) { entries_.emplace_back(v); } | 
 |  | 
 |   bool read(T& v) { | 
 |     if (entries_.empty()) return false; | 
 |     v = entries_.at(0); | 
 |     entries_.erase(entries_.begin()); | 
 |     return true; | 
 |   } | 
 |  | 
 |   bool next(T& v, int index = 0) { | 
 |     if (index >= count()) return false; | 
 |     v = entries_.at(index); | 
 |     return true; | 
 |   } | 
 |  | 
 |   bool rand(T& v) { | 
 |     if (entries_.empty()) return false; | 
 |     int index = ::rand() % count(); | 
 |     v = entries_.at(index); | 
 |     return true; | 
 |   } | 
 |  | 
 |   void clear() { entries_.clear(); } | 
 |  | 
 |   bool remove(int index = 0) { | 
 |     if (index >= count()) return false; | 
 |     entries_.erase(entries_.begin() + index); | 
 |     return true; | 
 |   } | 
 |  | 
 |   void shuffle() { | 
 |     const int count = entries_.size(); | 
 |     if (count < 2) return; | 
 |     for (int i = 0; i < count; ++i) { | 
 |       const int index = ::rand() % count; | 
 |       T v = entries_.at(index); | 
 |       entries_.erase(entries_.begin() + index); | 
 |       entries_.emplace_back(v); | 
 |     } | 
 |   } | 
 |  | 
 |   int count() { return entries_.size(); } | 
 |  | 
 |  private: | 
 |   std::vector<T> entries_; | 
 | }; | 
 |  | 
 | #endif  // TESTS_VERILATOR_SIM_FIFO_H_ |