|
|
@ -306,10 +306,22 @@ namespace Compiler
|
|
|
|
int i = 0;
|
|
|
|
int i = 0;
|
|
|
|
|
|
|
|
|
|
|
|
std::string lowerCase = Misc::StringUtils::lowerCase(name);
|
|
|
|
std::string lowerCase = Misc::StringUtils::lowerCase(name);
|
|
|
|
|
|
|
|
bool isKeyword = false;
|
|
|
|
for (; sKeywords[i]; ++i)
|
|
|
|
for (; sKeywords[i]; ++i)
|
|
|
|
if (lowerCase==sKeywords[i])
|
|
|
|
if (lowerCase==sKeywords[i])
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
isKeyword = true;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Russian localization and some mods use a quirk - add newline character directly
|
|
|
|
|
|
|
|
// to compiled bytecode via HEX-editor to implement multiline messageboxes.
|
|
|
|
|
|
|
|
// Of course, original editor will not compile such script.
|
|
|
|
|
|
|
|
// Allow messageboxes to bybass the "incomplete string or name" error.
|
|
|
|
|
|
|
|
if (lowerCase == "messagebox")
|
|
|
|
|
|
|
|
enableIgnoreNewlines();
|
|
|
|
|
|
|
|
else if (isKeyword)
|
|
|
|
|
|
|
|
mIgnoreNewline = false;
|
|
|
|
|
|
|
|
|
|
|
|
if (sKeywords[i])
|
|
|
|
if (sKeywords[i])
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -356,12 +368,17 @@ namespace Compiler
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
else if (c=='\n')
|
|
|
|
else if (c=='\n')
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (mIgnoreNewline)
|
|
|
|
|
|
|
|
mErrorHandler.warning ("string contains newline character, make sure that it is intended", mLoc);
|
|
|
|
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
error = true;
|
|
|
|
error = true;
|
|
|
|
mErrorHandler.error ("incomplete string or name", mLoc);
|
|
|
|
mErrorHandler.error ("incomplete string or name", mLoc);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
else if (!(c=='"' && name.empty()))
|
|
|
|
else if (!(c=='"' && name.empty()))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (!isStringCharacter (c) && !(mTolerantNames && (c=='.' || c=='-')))
|
|
|
|
if (!isStringCharacter (c) && !(mTolerantNames && (c=='.' || c=='-')))
|
|
|
@ -588,7 +605,7 @@ namespace Compiler
|
|
|
|
const Extensions *extensions)
|
|
|
|
const Extensions *extensions)
|
|
|
|
: mErrorHandler (errorHandler), mStream (inputStream), mExtensions (extensions),
|
|
|
|
: mErrorHandler (errorHandler), mStream (inputStream), mExtensions (extensions),
|
|
|
|
mPutback (Putback_None), mPutbackCode(0), mPutbackInteger(0), mPutbackFloat(0),
|
|
|
|
mPutback (Putback_None), mPutbackCode(0), mPutbackInteger(0), mPutbackFloat(0),
|
|
|
|
mStrictKeywords (false), mTolerantNames (false)
|
|
|
|
mStrictKeywords (false), mTolerantNames (false), mIgnoreNewline(false)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -641,6 +658,11 @@ namespace Compiler
|
|
|
|
mExtensions->listKeywords (keywords);
|
|
|
|
mExtensions->listKeywords (keywords);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void Scanner::enableIgnoreNewlines()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
mIgnoreNewline = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Scanner::enableStrictKeywords()
|
|
|
|
void Scanner::enableStrictKeywords()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mStrictKeywords = true;
|
|
|
|
mStrictKeywords = true;
|
|
|
|