mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-21 09:23:53 +00:00
15e8f0b53c
Recast functions have preconditions for arguments they don't validate. This may produce garbage data which may lead to crash. Check arguments and log when they are invalid. Do not throw exceptions when these function calls fail, capture Recast reported errors via RecastContext inherited from rcContext and log them.
45 lines
1.3 KiB
C++
45 lines
1.3 KiB
C++
#include "recastcontext.hpp"
|
|
#include "debug.hpp"
|
|
|
|
#include "components/debug/debuglog.hpp"
|
|
|
|
#include <sstream>
|
|
|
|
namespace DetourNavigator
|
|
{
|
|
namespace
|
|
{
|
|
Debug::Level getLogLevel(rcLogCategory category)
|
|
{
|
|
switch (category)
|
|
{
|
|
case RC_LOG_PROGRESS:
|
|
return Debug::Verbose;
|
|
case RC_LOG_WARNING:
|
|
return Debug::Warning;
|
|
case RC_LOG_ERROR:
|
|
return Debug::Error;
|
|
}
|
|
return Debug::Debug;
|
|
}
|
|
|
|
std::string formatPrefix(const TilePosition& tilePosition, const AgentBounds& agentBounds)
|
|
{
|
|
std::ostringstream stream;
|
|
stream << "Tile position: " << tilePosition.x() << ", " << tilePosition.y()
|
|
<< "; agent bounds: " << agentBounds << "; ";
|
|
return stream.str();
|
|
}
|
|
}
|
|
|
|
RecastContext::RecastContext(const TilePosition& tilePosition, const AgentBounds& agentBounds)
|
|
: mPrefix(formatPrefix(tilePosition, agentBounds))
|
|
{
|
|
}
|
|
|
|
void RecastContext::doLog(const rcLogCategory category, const char* msg, const int len)
|
|
{
|
|
if (len > 0)
|
|
Log(getLogLevel(category)) << mPrefix << std::string_view(msg, static_cast<std::size_t>(len));
|
|
}
|
|
}
|