openmw-tes3coop/apps/opencs/model/tools/scriptcheck.cpp

120 lines
3.2 KiB
C++
Raw Normal View History

2014-02-14 12:38:30 +00:00
#include "scriptcheck.hpp"
#include <components/compiler/tokenloc.hpp>
#include <components/compiler/scanner.hpp>
#include <components/compiler/fileparser.hpp>
#include <components/compiler/exception.hpp>
#include <components/compiler/extensions0.hpp>
#include "../doc/document.hpp"
2014-02-14 12:38:30 +00:00
#include "../world/data.hpp"
void CSMTools::ScriptCheckStage::report (const std::string& message, const Compiler::TokenLoc& loc,
Type type)
{
std::ostringstream stream;
CSMWorld::UniversalId id (CSMWorld::UniversalId::Type_Script, mId);
if (type==ErrorMessage)
stream << "error ";
else
stream << "warning ";
stream
2014-02-15 12:25:38 +00:00
<< "script " << mFile
<< ", line " << loc.mLine << ", column " << loc.mColumn
2014-02-14 12:38:30 +00:00
<< " (" << loc.mLiteral << "): " << message;
std::ostringstream hintStream;
hintStream << "l:" << loc.mLine << " " << loc.mColumn;
mMessages->add (id, stream.str(), hintStream.str());
2014-02-14 12:38:30 +00:00
}
void CSMTools::ScriptCheckStage::report (const std::string& message, Type type)
{
CSMWorld::UniversalId id (CSMWorld::UniversalId::Type_Script, mId);
mMessages->push_back (std::make_pair (id,
(type==ErrorMessage ? "error: " : "warning: ") + message));
2014-02-14 12:38:30 +00:00
}
CSMTools::ScriptCheckStage::ScriptCheckStage (const CSMDoc::Document& document)
: mDocument (document), mContext (document.getData()), mMessages (0), mWarningMode (Mode_Ignore)
2014-02-14 12:38:30 +00:00
{
/// \todo add an option to configure warning mode
setWarningsMode (0);
2014-02-14 12:38:30 +00:00
Compiler::registerExtensions (mExtensions);
mContext.setExtensions (&mExtensions);
}
int CSMTools::ScriptCheckStage::setup()
{
mContext.clear();
mMessages = 0;
mId.clear();
Compiler::ErrorHandler::reset();
2014-02-14 12:38:30 +00:00
return mDocument.getData().getScripts().getSize();
2014-02-14 12:38:30 +00:00
}
void CSMTools::ScriptCheckStage::perform (int stage, CSMDoc::Messages& messages)
2014-02-14 12:38:30 +00:00
{
mId = mDocument.getData().getScripts().getId (stage);
if (mDocument.isBlacklisted (
CSMWorld::UniversalId (CSMWorld::UniversalId::Type_Script, mId)))
return;
2014-02-14 12:38:30 +00:00
mMessages = &messages;
switch (mWarningMode)
{
case Mode_Ignore: setWarningsMode (0); break;
case Mode_Strict: setWarningsMode (1); break;
}
2014-02-14 12:38:30 +00:00
try
{
const CSMWorld::Data& data = mDocument.getData();
mFile = data.getScripts().getRecord (stage).get().mId;
std::istringstream input (data.getScripts().getRecord (stage).get().mScriptText);
2014-02-14 12:38:30 +00:00
Compiler::Scanner scanner (*this, input, mContext.getExtensions());
Compiler::FileParser parser (*this, mContext);
scanner.scan (parser);
}
catch (const Compiler::SourceException&)
{
// error has already been reported via error handler
}
catch (const std::exception& error)
{
CSMWorld::UniversalId id (CSMWorld::UniversalId::Type_Script, mId);
messages.push_back (std::make_pair (id,
std::string ("Critical compile error: ") + error.what()));
2014-02-14 12:38:30 +00:00
}
mMessages = 0;
2015-03-11 14:54:45 +00:00
}
void CSMTools::ScriptCheckStage::updateUserSetting (const QString& name, const QStringList& value)
{
if (name=="script-editor/warnings")
{
if (value.at (0)=="Ignore")
mWarningMode = Mode_Ignore;
else if (value.at (0)=="Strict")
mWarningMode = Mode_Strict;
}
}