mirror of
https://github.com/reactos/CMake.git
synced 2024-11-30 23:10:26 +00:00
f1eacf0e07
The expressions may be parsed and then cached and evaluated multiple times. They are evaluated lazily so that literals such as ',' can be treated as universal parameter separators, and can be processed from results without appearing literally, and without interfering with the parsing/evaluation of the entire expression.
86 lines
2.5 KiB
C++
86 lines
2.5 KiB
C++
/*============================================================================
|
|
CMake - Cross Platform Makefile Generator
|
|
Copyright 2012 Stephen Kelly <steveire@gmail.com>
|
|
|
|
Distributed under the OSI-approved BSD License (the "License");
|
|
see accompanying file Copyright.txt for details.
|
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even the
|
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
See the License for more information.
|
|
============================================================================*/
|
|
#include "cmGeneratorExpressionLexer.h"
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
|
cmGeneratorExpressionLexer::cmGeneratorExpressionLexer()
|
|
: SawBeginExpression(false), SawGeneratorExpression(false)
|
|
{
|
|
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
static void InsertText(const char *upto, const char *c,
|
|
std::vector<cmGeneratorExpressionToken> &result)
|
|
{
|
|
if (upto != c)
|
|
{
|
|
result.push_back(cmGeneratorExpressionToken(
|
|
cmGeneratorExpressionToken::Text, upto, c - upto));
|
|
}
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
std::vector<cmGeneratorExpressionToken>
|
|
cmGeneratorExpressionLexer::Tokenize(const char *input)
|
|
{
|
|
std::vector<cmGeneratorExpressionToken> result;
|
|
if (!input)
|
|
return result;
|
|
|
|
const char *c = input;
|
|
const char *upto = c;
|
|
|
|
for ( ; *c; ++c)
|
|
{
|
|
if(c[0] == '$' && c[1] == '<')
|
|
{
|
|
InsertText(upto, c, result);
|
|
upto = c;
|
|
result.push_back(cmGeneratorExpressionToken(
|
|
cmGeneratorExpressionToken::BeginExpression, upto, 2));
|
|
upto = c + 2;
|
|
++c;
|
|
SawBeginExpression = true;
|
|
}
|
|
else if(c[0] == '>')
|
|
{
|
|
InsertText(upto, c, result);
|
|
upto = c;
|
|
result.push_back(cmGeneratorExpressionToken(
|
|
cmGeneratorExpressionToken::EndExpression, upto, 1));
|
|
upto = c + 1;
|
|
SawGeneratorExpression = SawBeginExpression;
|
|
}
|
|
else if(c[0] == ':')
|
|
{
|
|
InsertText(upto, c, result);
|
|
upto = c;
|
|
result.push_back(cmGeneratorExpressionToken(
|
|
cmGeneratorExpressionToken::ColonSeparator, upto, 1));
|
|
upto = c + 1;
|
|
}
|
|
else if(c[0] == ',')
|
|
{
|
|
InsertText(upto, c, result);
|
|
upto = c;
|
|
result.push_back(cmGeneratorExpressionToken(
|
|
cmGeneratorExpressionToken::CommaSeparator, upto, 1));
|
|
upto = c + 1;
|
|
}
|
|
}
|
|
InsertText(upto, c, result);
|
|
|
|
return result;
|
|
}
|