2018-03-13 22:49:08 +00:00
|
|
|
#ifndef OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_H
|
|
|
|
#define OPENMW_COMPONENTS_DETOURNAVIGATOR_DEBUG_H
|
|
|
|
|
|
|
|
#include "tilebounds.hpp"
|
|
|
|
|
|
|
|
#include <components/bullethelpers/operators.hpp>
|
|
|
|
#include <components/osghelpers/operators.hpp>
|
|
|
|
|
|
|
|
#include <iomanip>
|
|
|
|
#include <iostream>
|
|
|
|
#include <sstream>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#ifdef OPENMW_WRITE_OBJ
|
|
|
|
#include <vector>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef OPENMW_WRITE_TO_FILE
|
|
|
|
class dtNavMesh;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
namespace DetourNavigator
|
|
|
|
{
|
|
|
|
inline std::ostream& operator <<(std::ostream& stream, const TileBounds& value)
|
|
|
|
{
|
|
|
|
return stream << "TileBounds {" << value.mMin << ", " << value.mMax << "}";
|
|
|
|
}
|
|
|
|
|
|
|
|
// Use to dump scene to load from recastnavigation demo tool
|
|
|
|
#ifdef OPENMW_WRITE_OBJ
|
|
|
|
void writeObj(const std::vector<float>& vertices, const std::vector<int>& indices);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef OPENMW_WRITE_TO_FILE
|
|
|
|
class RecastMesh;
|
|
|
|
|
|
|
|
void writeToFile(const RecastMesh& recastMesh, const std::string& revision);
|
|
|
|
|
|
|
|
void writeToFile(const dtNavMesh& navMesh, const std::string& revision);
|
|
|
|
#endif
|
|
|
|
|
2018-04-01 14:41:24 +00:00
|
|
|
class Log
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Log() : mEnabled(false) {}
|
|
|
|
|
|
|
|
void setEnabled(bool value)
|
|
|
|
{
|
|
|
|
mEnabled = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool isEnabled() const
|
|
|
|
{
|
|
|
|
return mEnabled;
|
|
|
|
}
|
|
|
|
|
|
|
|
void write(const std::string& text)
|
|
|
|
{
|
|
|
|
if (mEnabled)
|
|
|
|
std::cout << text;
|
|
|
|
}
|
|
|
|
|
|
|
|
static Log& instance()
|
|
|
|
{
|
|
|
|
static Log value;
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
bool mEnabled;
|
|
|
|
};
|
|
|
|
|
2018-03-13 22:49:08 +00:00
|
|
|
inline void write(std::ostream& stream)
|
|
|
|
{
|
|
|
|
stream << '\n';
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class Head, class ... Tail>
|
|
|
|
void write(std::ostream& stream, const Head& head, const Tail& ... tail)
|
|
|
|
{
|
|
|
|
stream << head;
|
|
|
|
write(stream, tail ...);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class ... Ts>
|
|
|
|
void log(Ts&& ... values)
|
|
|
|
{
|
2018-04-01 14:41:24 +00:00
|
|
|
auto& log = Log::instance();
|
|
|
|
if (!log.isEnabled())
|
|
|
|
return;
|
2018-03-13 22:49:08 +00:00
|
|
|
std::ostringstream stream;
|
|
|
|
write(stream, std::forward<Ts>(values) ...);
|
2018-04-01 14:41:24 +00:00
|
|
|
log.write(stream.str());
|
2018-03-13 22:49:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|