Optimisation in Tokenizer::tokenize

This commit is contained in:
Daniel Marjamäki 2010-08-11 17:29:33 +02:00
parent 737ca1a968
commit cb72f21994
1 changed files with 34 additions and 29 deletions

View File

@ -1704,39 +1704,44 @@ bool Tokenizer::tokenize(std::istream &code, const char FileName[], const std::s
// Combine tokens.. // Combine tokens..
for (Token *tok = _tokens; tok && tok->next(); tok = tok->next()) for (Token *tok = _tokens; tok && tok->next(); tok = tok->next())
{ {
static const char * const combineWithNext[][3] = const char c1 = tok->str()[0];
if (tok->str().length() == 1 && tok->next()->str().length() == 1)
{ {
{ "<", "<", "<<" }, const char c2 = tok->next()->str()[0];
{ "|", "|", "||" }, // combine equal tokens..
if (c1 == c2 && (c1 == '<' || c1 == '|' || c1 == ':'))
{ "+", "=", "+=" },
{ "-", "=", "-=" },
{ "*", "=", "*=" },
{ "/", "=", "/=" },
{ "&", "=", "&=" },
{ "|", "=", "|=" },
{ "=", "=", "==" },
{ "!", "=", "!=" },
{ "<", "=", "<=" },
{ ">", "=", ">=" },
{ ":", ":", "::" },
{ "-", ">", "." }, // Replace "->" with "."
{ "private", ":", "private:" },
{ "protected", ":", "protected:" },
{ "public", ":", "public:" },
{ "__published", ":", "__published:" }
};
for (unsigned ui = 0; ui < sizeof(combineWithNext) / sizeof(combineWithNext[0]); ui++)
{
if (tok->str() == combineWithNext[ui][0] && tok->next()->str() == combineWithNext[ui][1])
{ {
tok->str(combineWithNext[ui][2]); tok->str(tok->str() + c2);
tok->deleteNext(); tok->deleteNext();
continue;
}
// combine +-*/ and =
else if (c2 == '=' && (strchr("+-*/&|=!<>", c1)))
{
tok->str(tok->str() + c2);
tok->deleteNext();
continue;
}
// replace "->" with "."
else if (c1 == '-' && c2 == '>')
{
tok->str(".");
tok->deleteNext();
continue;
}
}
else if (c1 == 'p' && tok->next()->str() == ":")
{
if (tok->str() == "private" || tok->str() == "protected" || tok->str() == "public" || tok->str() == "__published")
{
tok->str(tok->str() + ":");
tok->deleteNext();
continue;
} }
} }
} }