#pragma once #include #include "simdjson/simdjson.h" #include "cycle_t.h" class cycles_t final { private: std::vector m_cycles; public: cycles_t(size_t reserved = 10); cycles_t(simdjson::dom::array input); void add(const cycle_t& cycle); [[nodiscard]] auto begin() const { return m_cycles.begin(); } [[nodiscard]] auto end() const { return m_cycles.end(); } [[nodiscard]] auto size() const noexcept { return m_cycles.size(); } void clear() { m_cycles.clear(); } [[nodiscard]] auto& operator[](size_t idx) noexcept { return m_cycles[idx]; } [[nodiscard]] const auto& operator[](size_t idx) const noexcept { return m_cycles[idx]; } };