1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-28 18:45:33 +00:00
openmw-tes3mp/components/compiler/streamerrorhandler.cpp
2020-04-02 20:27:52 +02:00

85 lines
2.1 KiB
C++

#include "streamerrorhandler.hpp"
#include <sstream>
#include <components/debug/debuglog.hpp>
#include "tokenloc.hpp"
namespace Compiler
{
// Report error to the user.
void StreamErrorHandler::report (const std::string& message, const TokenLoc& loc,
Type type)
{
Debug::Level logLevel = Debug::Info; // Usually script warnings are not too important
if (type == ErrorMessage)
logLevel = Debug::Error;
std::stringstream text;
if (type==ErrorMessage)
text << "Error: ";
else
text << "Warning: ";
if (!mContext.empty())
text << mContext << " ";
text << "line " << loc.mLine+1 << ", column " << loc.mColumn+1
<< " (" << loc.mLiteral << "): " << message;
Log(logLevel) << text.str();
}
// Report a file related error
void StreamErrorHandler::report (const std::string& message, Type type)
{
Debug::Level logLevel = Debug::Info;
if (type==ErrorMessage)
logLevel = Debug::Error;
std::stringstream text;
if (type==ErrorMessage)
text << "Error: ";
else
text << "Warning: ";
if (!mContext.empty())
text << mContext << " ";
text << "file: " << message << std::endl;
Log(logLevel) << text.str();
}
ContextRestore StreamErrorHandler::setContext(const std::string &context, bool restore)
{
if (!restore)
{
mContext = context;
return {nullptr, {}};
}
ContextRestore restorer(this, mContext);
mContext = context;
return restorer;
}
StreamErrorHandler::StreamErrorHandler() {}
ContextRestore::ContextRestore(StreamErrorHandler* handler, const std::string& context) : mHandler(handler), mContext(context) {}
ContextRestore::ContextRestore(ContextRestore&& other) : mHandler(other.mHandler), mContext(other.mContext)
{
other.mHandler = nullptr;
}
ContextRestore::~ContextRestore()
{
if(mHandler)
mHandler->setContext(mContext);
}
}