2014-02-14 13:38:30 +01: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>
|
|
|
|
|
2014-07-21 12:15:21 +02:00
|
|
|
#include "../doc/document.hpp"
|
|
|
|
|
2014-02-14 13:38:30 +01:00
|
|
|
#include "../world/data.hpp"
|
|
|
|
|
2015-12-15 12:44:04 +01:00
|
|
|
#include "../prefs/state.hpp"
|
|
|
|
|
2015-06-20 19:04:19 +02:00
|
|
|
CSMDoc::Message::Severity CSMTools::ScriptCheckStage::getSeverity (Type type)
|
|
|
|
{
|
|
|
|
switch (type)
|
|
|
|
{
|
|
|
|
case WarningMessage: return CSMDoc::Message::Severity_Warning;
|
|
|
|
case ErrorMessage: return CSMDoc::Message::Severity_Error;
|
|
|
|
}
|
|
|
|
|
|
|
|
return CSMDoc::Message::Severity_SeriousError;
|
|
|
|
}
|
|
|
|
|
2014-02-14 13:38:30 +01:00
|
|
|
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);
|
|
|
|
|
|
|
|
stream
|
2014-02-15 13:25:38 +01:00
|
|
|
<< "script " << mFile
|
|
|
|
<< ", line " << loc.mLine << ", column " << loc.mColumn
|
2014-02-14 13:38:30 +01:00
|
|
|
<< " (" << loc.mLiteral << "): " << message;
|
|
|
|
|
2014-12-08 12:29:23 +01:00
|
|
|
std::ostringstream hintStream;
|
|
|
|
|
|
|
|
hintStream << "l:" << loc.mLine << " " << loc.mColumn;
|
|
|
|
|
2015-06-20 19:04:19 +02:00
|
|
|
mMessages->add (id, stream.str(), hintStream.str(), getSeverity (type));
|
2014-02-14 13:38:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void CSMTools::ScriptCheckStage::report (const std::string& message, Type type)
|
|
|
|
{
|
|
|
|
CSMWorld::UniversalId id (CSMWorld::UniversalId::Type_Script, mId);
|
|
|
|
|
2015-06-20 19:04:19 +02:00
|
|
|
std::ostringstream stream;
|
|
|
|
stream << "script " << mFile << ": " << message;
|
2015-12-15 12:44:04 +01:00
|
|
|
|
2015-06-20 19:04:19 +02:00
|
|
|
mMessages->add (id, stream.str(), "", getSeverity (type));
|
2014-02-14 13:38:30 +01:00
|
|
|
}
|
|
|
|
|
2014-07-21 12:15:21 +02:00
|
|
|
CSMTools::ScriptCheckStage::ScriptCheckStage (const CSMDoc::Document& document)
|
2015-06-20 16:21:04 +02:00
|
|
|
: mDocument (document), mContext (document.getData()), mMessages (0), mWarningMode (Mode_Ignore)
|
2014-02-14 13:38:30 +01:00
|
|
|
{
|
2014-02-15 12:58:34 +01:00
|
|
|
/// \todo add an option to configure warning mode
|
|
|
|
setWarningsMode (0);
|
|
|
|
|
2014-02-14 13:38:30 +01:00
|
|
|
Compiler::registerExtensions (mExtensions);
|
|
|
|
mContext.setExtensions (&mExtensions);
|
|
|
|
}
|
|
|
|
|
|
|
|
int CSMTools::ScriptCheckStage::setup()
|
|
|
|
{
|
2015-12-15 12:44:04 +01:00
|
|
|
std::string warnings = CSMPrefs::get()["Scripts"]["warnings"].toString();
|
|
|
|
|
|
|
|
if (warnings=="Ignore")
|
|
|
|
mWarningMode = Mode_Ignore;
|
|
|
|
else if (warnings=="Normal")
|
|
|
|
mWarningMode = Mode_Normal;
|
|
|
|
else if (warnings=="Strict")
|
|
|
|
mWarningMode = Mode_Strict;
|
|
|
|
|
2014-02-14 13:38:30 +01:00
|
|
|
mContext.clear();
|
|
|
|
mMessages = 0;
|
|
|
|
mId.clear();
|
2015-06-20 16:21:04 +02:00
|
|
|
Compiler::ErrorHandler::reset();
|
2014-02-14 13:38:30 +01:00
|
|
|
|
2014-07-21 12:15:21 +02:00
|
|
|
return mDocument.getData().getScripts().getSize();
|
2014-02-14 13:38:30 +01:00
|
|
|
}
|
|
|
|
|
2014-12-07 18:57:47 +01:00
|
|
|
void CSMTools::ScriptCheckStage::perform (int stage, CSMDoc::Messages& messages)
|
2014-02-14 13:38:30 +01:00
|
|
|
{
|
2014-07-21 12:15:21 +02:00
|
|
|
mId = mDocument.getData().getScripts().getId (stage);
|
|
|
|
|
|
|
|
if (mDocument.isBlacklisted (
|
|
|
|
CSMWorld::UniversalId (CSMWorld::UniversalId::Type_Script, mId)))
|
|
|
|
return;
|
|
|
|
|
2014-02-14 13:38:30 +01:00
|
|
|
mMessages = &messages;
|
|
|
|
|
2015-06-20 16:21:04 +02:00
|
|
|
switch (mWarningMode)
|
|
|
|
{
|
|
|
|
case Mode_Ignore: setWarningsMode (0); break;
|
2015-06-20 19:16:15 +02:00
|
|
|
case Mode_Normal: setWarningsMode (1); break;
|
|
|
|
case Mode_Strict: setWarningsMode (2); break;
|
2015-06-20 16:21:04 +02:00
|
|
|
}
|
|
|
|
|
2014-02-14 13:38:30 +01:00
|
|
|
try
|
|
|
|
{
|
2014-07-21 12:15:21 +02:00
|
|
|
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 13:38:30 +01: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);
|
|
|
|
|
2015-06-20 19:04:19 +02:00
|
|
|
std::ostringstream stream;
|
|
|
|
stream << "script " << mFile << ": " << error.what();
|
2015-12-15 12:44:04 +01:00
|
|
|
|
2015-06-20 19:04:19 +02:00
|
|
|
messages.add (id, stream.str(), "", CSMDoc::Message::Severity_SeriousError);
|
2014-02-14 13:38:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
mMessages = 0;
|
2015-03-11 10:54:45 -04:00
|
|
|
}
|