mirror of https://github.com/OpenMW/openmw.git
Merge branch 'treejunk' into 'master'
Discard additional tokens in non-expression contexts See merge request OpenMW/openmw!3700macos_ci_fix
commit
67955ac55f
@ -1,39 +1,55 @@
|
||||
#include "skipparser.hpp"
|
||||
|
||||
#include "errorhandler.hpp"
|
||||
#include "scanner.hpp"
|
||||
|
||||
namespace Compiler
|
||||
{
|
||||
SkipParser::SkipParser(ErrorHandler& errorHandler, const Context& context)
|
||||
SkipParser::SkipParser(ErrorHandler& errorHandler, const Context& context, bool reportStrayArguments)
|
||||
: Parser(errorHandler, context)
|
||||
, mReportStrayArguments(reportStrayArguments)
|
||||
{
|
||||
}
|
||||
|
||||
void SkipParser::reportStrayArgument(const TokenLoc& loc)
|
||||
{
|
||||
if (mReportStrayArguments)
|
||||
getErrorHandler().warning("Extra argument", loc);
|
||||
}
|
||||
|
||||
bool SkipParser::parseInt(int value, const TokenLoc& loc, Scanner& scanner)
|
||||
{
|
||||
reportStrayArgument(loc);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool SkipParser::parseFloat(float value, const TokenLoc& loc, Scanner& scanner)
|
||||
{
|
||||
reportStrayArgument(loc);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool SkipParser::parseName(const std::string& name, const TokenLoc& loc, Scanner& scanner)
|
||||
{
|
||||
reportStrayArgument(loc);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool SkipParser::parseKeyword(int keyword, const TokenLoc& loc, Scanner& scanner)
|
||||
{
|
||||
reportStrayArgument(loc);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool SkipParser::parseSpecial(int code, const TokenLoc& loc, Scanner& scanner)
|
||||
{
|
||||
if (code == Scanner::S_newline)
|
||||
{
|
||||
if (mReportStrayArguments)
|
||||
scanner.putbackSpecial(code, loc);
|
||||
return false;
|
||||
|
||||
}
|
||||
reportStrayArgument(loc);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue