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>
|
|
|
|
|
2014-07-21 10:15:21 +00:00
|
|
|
#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;
|
|
|
|
|
2014-05-08 10:42:29 +00:00
|
|
|
mMessages->push_back (std::make_pair (id, stream.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);
|
|
|
|
|
2014-05-08 10:42:29 +00:00
|
|
|
mMessages->push_back (std::make_pair (id,
|
|
|
|
(type==ErrorMessage ? "error: " : "warning: ") + message));
|
2014-02-14 12:38:30 +00:00
|
|
|
}
|
|
|
|
|
2014-07-21 10:15:21 +00:00
|
|
|
CSMTools::ScriptCheckStage::ScriptCheckStage (const CSMDoc::Document& document)
|
|
|
|
: mDocument (document), mContext (document.getData()), mMessages (0)
|
2014-02-14 12:38:30 +00:00
|
|
|
{
|
2014-02-15 11:58:34 +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();
|
|
|
|
|
2014-07-21 10:15:21 +00:00
|
|
|
return mDocument.getData().getScripts().getSize();
|
2014-02-14 12:38:30 +00:00
|
|
|
}
|
|
|
|
|
2014-05-08 10:42:29 +00:00
|
|
|
void CSMTools::ScriptCheckStage::perform (int stage, Messages& messages)
|
2014-02-14 12:38:30 +00:00
|
|
|
{
|
2014-07-21 10:15:21 +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;
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
2014-07-21 10:15:21 +00: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 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);
|
|
|
|
|
2014-05-08 10:42:29 +00:00
|
|
|
messages.push_back (std::make_pair (id,
|
|
|
|
std::string ("Critical compile error: ") + error.what()));
|
2014-02-14 12:38:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
mMessages = 0;
|
|
|
|
}
|