2021-10-16 17:07:55 +00:00
|
|
|
#ifndef OPENMW_COMPONENTS_ESMLOADER_RECORD_H
|
|
|
|
#define OPENMW_COMPONENTS_ESMLOADER_RECORD_H
|
|
|
|
|
2022-01-22 14:58:41 +00:00
|
|
|
#include <components/esm3/loadcell.hpp>
|
2022-04-12 15:27:59 +00:00
|
|
|
#include <components/misc/algorithm.hpp>
|
2021-10-16 17:07:55 +00:00
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
#include <utility>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace EsmLoader
|
|
|
|
{
|
|
|
|
template <class T>
|
|
|
|
struct Record
|
|
|
|
{
|
|
|
|
bool mDeleted;
|
|
|
|
T mValue;
|
|
|
|
|
2022-09-22 18:26:05 +00:00
|
|
|
template <class... Args>
|
|
|
|
explicit Record(bool deleted, Args&&... args)
|
2021-10-16 17:07:55 +00:00
|
|
|
: mDeleted(deleted)
|
2022-09-22 18:26:05 +00:00
|
|
|
, mValue(std::forward<Args>(args)...)
|
|
|
|
{
|
|
|
|
}
|
2021-10-16 17:07:55 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
using Records = std::vector<Record<T>>;
|
|
|
|
|
|
|
|
template <class T, class GetKey>
|
|
|
|
inline std::vector<T> prepareRecords(Records<T>& records, const GetKey& getKey)
|
|
|
|
{
|
2022-09-22 18:26:05 +00:00
|
|
|
const auto greaterByKey = [&](const auto& l, const auto& r) { return getKey(r) < getKey(l); };
|
|
|
|
const auto equalByKey = [&](const auto& l, const auto& r) { return getKey(l) == getKey(r); };
|
2021-10-16 17:07:55 +00:00
|
|
|
std::stable_sort(records.begin(), records.end(), greaterByKey);
|
|
|
|
std::vector<T> result;
|
2022-09-22 18:26:05 +00:00
|
|
|
Misc::forEachUnique(records.rbegin(), records.rend(), equalByKey, [&](const auto& v) {
|
2021-10-16 17:07:55 +00:00
|
|
|
if (!v.mDeleted)
|
|
|
|
result.emplace_back(std::move(v.mValue));
|
2022-04-12 15:27:59 +00:00
|
|
|
});
|
2021-10-16 17:07:55 +00:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|