mirror of https://github.com/OpenMW/openmw.git
Discard additional tokens in non-expression contexts
parent
c9d4ca5320
commit
02775c490b
@ -1,39 +1,55 @@
|
|||||||
#include "skipparser.hpp"
|
#include "skipparser.hpp"
|
||||||
|
|
||||||
|
#include "errorhandler.hpp"
|
||||||
#include "scanner.hpp"
|
#include "scanner.hpp"
|
||||||
|
|
||||||
namespace Compiler
|
namespace Compiler
|
||||||
{
|
{
|
||||||
SkipParser::SkipParser(ErrorHandler& errorHandler, const Context& context)
|
SkipParser::SkipParser(ErrorHandler& errorHandler, const Context& context, bool reportStrayArguments)
|
||||||
: Parser(errorHandler, context)
|
: 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)
|
bool SkipParser::parseInt(int value, const TokenLoc& loc, Scanner& scanner)
|
||||||
{
|
{
|
||||||
|
reportStrayArgument(loc);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SkipParser::parseFloat(float value, const TokenLoc& loc, Scanner& scanner)
|
bool SkipParser::parseFloat(float value, const TokenLoc& loc, Scanner& scanner)
|
||||||
{
|
{
|
||||||
|
reportStrayArgument(loc);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SkipParser::parseName(const std::string& name, const TokenLoc& loc, Scanner& scanner)
|
bool SkipParser::parseName(const std::string& name, const TokenLoc& loc, Scanner& scanner)
|
||||||
{
|
{
|
||||||
|
reportStrayArgument(loc);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SkipParser::parseKeyword(int keyword, const TokenLoc& loc, Scanner& scanner)
|
bool SkipParser::parseKeyword(int keyword, const TokenLoc& loc, Scanner& scanner)
|
||||||
{
|
{
|
||||||
|
reportStrayArgument(loc);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SkipParser::parseSpecial(int code, const TokenLoc& loc, Scanner& scanner)
|
bool SkipParser::parseSpecial(int code, const TokenLoc& loc, Scanner& scanner)
|
||||||
{
|
{
|
||||||
if (code == Scanner::S_newline)
|
if (code == Scanner::S_newline)
|
||||||
|
{
|
||||||
|
if (mReportStrayArguments)
|
||||||
|
scanner.putbackSpecial(code, loc);
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
reportStrayArgument(loc);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue