/****************************************************************************
* Copyright (C) 2016-2021 Maschell
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
****************************************************************************/
#include "SectionEntries.h"
std::optional> SectionEntries::getSection(uint16_t sectionNumber) const {
for (auto const &e : list) {
if (e->sectionNumber == sectionNumber) {
return e;
}
}
return {};
}
uint32_t SectionEntries::getSizeInBytes() const {
return list.size() * SectionEntry::LENGTH;
}
uint32_t SectionEntries::size() const {
return list.size();
}
std::optional> SectionEntries::make_shared(const std::vector &data, uint32_t numberOfSections, const VolumeBlockSize &pBlockSize) {
std::vector> list;
for (uint32_t i = 0; i < numberOfSections; i++) {
if (data.size() < (i + 1) * SectionEntry::LENGTH) {
DEBUG_FUNCTION_LINE_ERR("Failed to parse SectionEntries");
return {};
}
std::array sectionEntryData{};
memcpy(sectionEntryData.data(), data.data() + (i * SectionEntry::LENGTH), SectionEntry::LENGTH);
list.push_back(std::make_shared(sectionEntryData, i, pBlockSize));
}
return std::shared_ptr(new SectionEntries(list));
}
std::vector> SectionEntries::getSections() const & {
return list;
}
SectionEntries::SectionEntries(std::vector> pList) : list(std::move(pList)) {
}