summaryrefslogtreecommitdiffstats
path: root/contrib/llvm/tools/lldb/source/Utility/StringLexer.cpp
blob: 2f62d2cedb401db03c516776043e3797f75c6e48 (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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
//===--------------------- StringLexer.cpp -----------------------*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//

#include "lldb/Utility/StringLexer.h"

#include <algorithm>
#include <assert.h>

using namespace lldb_utility;

StringLexer::StringLexer (std::string s) :
    m_data(s),
    m_position(0)
{ }

StringLexer::StringLexer (const StringLexer& rhs) :
    m_data(rhs.m_data),
    m_position(rhs.m_position)
{ }

StringLexer::Character
StringLexer::Peek ()
{
    return m_data[m_position];
}

bool
StringLexer::NextIf (Character c)
{
    auto val = Peek();
    if (val == c)
    {
        Next();
        return true;
    }
    return false;
}

std::pair<bool, StringLexer::Character>
StringLexer::NextIf (std::initializer_list<Character> cs)
{
    auto val = Peek();
    for (auto c : cs)
    {
        if (val == c)
        {
            Next();
            return {true,c};
        }
    }
    return {false,0};
}

bool
StringLexer::AdvanceIf (const std::string& token)
{
    auto pos = m_position;
    bool matches = true;
    for (auto c : token)
    {
        if (!NextIf(c))
        {
            matches = false;
            break;
        }
    }
    if (!matches)
    {
        m_position = pos;
        return false;
    }
    return true;
}

StringLexer::Character
StringLexer::Next ()
{
    auto val = Peek();
    Consume();
    return val;
}

bool
StringLexer::HasAtLeast (Size s)
{
    return (m_data.size() - m_position) >= s;
}

void
StringLexer::PutBack (Size s)
{
    assert (m_position >= s);
    m_position -= s;
}

bool
StringLexer::HasAny (Character c)
{
    return m_data.find(c, m_position) != std::string::npos;
}

std::string
StringLexer::GetUnlexed ()
{
    return std::string(m_data, m_position);
}

void
StringLexer::Consume()
{
    m_position++;
}

StringLexer&
StringLexer::operator = (const StringLexer& rhs)
{
    if (this != &rhs)
    {
        m_data = rhs.m_data;
        m_position = rhs.m_position;
    }
    return *this;
}
OpenPOWER on IntegriCloud