summaryrefslogtreecommitdiff
path: root/Source/cmGeneratorExpressionLexer.cxx
blob: cd71ec033f3f653526f3fc68dcd0d4f05b270d70 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/*============================================================================
  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;
}