1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-16 16:59:56 +00:00
openmw/components/detournavigator/preparednavmeshdatatuple.hpp

43 lines
1.5 KiB
C++
Raw Normal View History

#ifndef OPENMW_COMPONENTS_DETOURNAVIGATOR_PREPAREDNAVMESHDATATUPLE_H
#define OPENMW_COMPONENTS_DETOURNAVIGATOR_PREPAREDNAVMESHDATATUPLE_H
#include "preparednavmeshdata.hpp"
#include "recast.hpp"
2022-09-22 18:26:05 +00:00
#include "ref.hpp"
#include <Recast.h>
#include <tuple>
2021-11-21 13:21:47 +00:00
inline bool operator==(const rcPolyMesh& lhs, const rcPolyMesh& rhs) noexcept
{
2022-09-22 18:26:05 +00:00
const auto makeTuple = [](const rcPolyMesh& v) {
2021-11-21 13:21:47 +00:00
using namespace DetourNavigator;
2022-09-22 18:26:05 +00:00
return std::tuple(Span(v.verts, static_cast<int>(getVertsLength(v))),
Span(v.polys, static_cast<int>(getPolysLength(v))), Span(v.regs, static_cast<int>(getRegsLength(v))),
Span(v.flags, static_cast<int>(getFlagsLength(v))), Span(v.areas, static_cast<int>(getAreasLength(v))),
ArrayRef(v.bmin), ArrayRef(v.bmax), v.cs, v.ch, v.borderSize, v.maxEdgeError);
2021-11-21 13:21:47 +00:00
};
return makeTuple(lhs) == makeTuple(rhs);
}
2021-11-21 13:21:47 +00:00
inline bool operator==(const rcPolyMeshDetail& lhs, const rcPolyMeshDetail& rhs) noexcept
{
2022-09-22 18:26:05 +00:00
const auto makeTuple = [](const rcPolyMeshDetail& v) {
2021-11-21 13:21:47 +00:00
using namespace DetourNavigator;
2022-09-22 18:26:05 +00:00
return std::tuple(Span(v.meshes, static_cast<int>(getMeshesLength(v))),
Span(v.verts, static_cast<int>(getVertsLength(v))), Span(v.tris, static_cast<int>(getTrisLength(v))));
2021-11-21 13:21:47 +00:00
};
return makeTuple(lhs) == makeTuple(rhs);
}
2021-11-21 13:21:47 +00:00
namespace DetourNavigator
{
inline auto makeTuple(const PreparedNavMeshData& v) noexcept
{
2022-09-22 18:26:05 +00:00
return std::tuple(v.mUserId, v.mCellHeight, v.mCellSize, Ref(v.mPolyMesh), Ref(v.mPolyMeshDetail));
}
}
#endif