mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-21 10:53:53 +00:00
46 lines
1.3 KiB
C++
46 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));
|
||
|
}
|
||
|
}
|