mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-16 16:46:34 +00:00
Do not write to log if log message level is greater than one speficied in the OPENMW_RECAST_MAX_LOG_LEVEL env variable. Use Error by default.
52 lines
1.6 KiB
C++
52 lines
1.6 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(
|
|
ESM::RefId worldspace, const TilePosition& tilePosition, const AgentBounds& agentBounds)
|
|
{
|
|
std::ostringstream stream;
|
|
stream << "Worldspace: " << worldspace << "; tile position: " << tilePosition.x() << ", "
|
|
<< tilePosition.y() << "; agent bounds: " << agentBounds << "; ";
|
|
return stream.str();
|
|
}
|
|
}
|
|
|
|
RecastContext::RecastContext(ESM::RefId worldspace, const TilePosition& tilePosition,
|
|
const AgentBounds& agentBounds, Debug::Level maxLogLevel)
|
|
: mMaxLogLevel(maxLogLevel)
|
|
, mPrefix(formatPrefix(worldspace, tilePosition, agentBounds))
|
|
{
|
|
}
|
|
|
|
void RecastContext::doLog(const rcLogCategory category, const char* msg, const int len)
|
|
{
|
|
if (msg == nullptr || len <= 0)
|
|
return;
|
|
const Debug::Level level = getLogLevel(category);
|
|
if (level > mMaxLogLevel)
|
|
return;
|
|
Log(level) << mPrefix << std::string_view(msg, static_cast<std::size_t>(len));
|
|
}
|
|
}
|