aboutsummaryrefslogtreecommitdiff
path: root/source/Utility/StringLexer.cpp
blob: bde2fc6a4202e4dcb50a797ca4f1ffa58bc27a1b (plain) (blame)
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
//===--------------------- 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>

using namespace lldb_utility;

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

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

StringLexer::Character
StringLexer::Peek ()
{
    if (m_putback_data.empty())
        return m_data[m_position];
    else
        return m_putback_data.front();
}

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

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

bool
StringLexer::HasAtLeast (Size s)
{
    auto in_m_data = m_data.size()-m_position;
    auto in_putback = m_putback_data.size();
    return (in_m_data + in_putback >= s);
}


void
StringLexer::PutBack (Character c)
{
    m_putback_data.push_back(c);
}

bool
StringLexer::HasAny (Character c)
{
    const auto begin(m_putback_data.begin());
    const auto end(m_putback_data.end());
    if (std::find(begin, end, c) != end)
        return true;
    return m_data.find(c, m_position) != std::string::npos;
}

void
StringLexer::Consume()
{
    if (m_putback_data.empty())
        m_position++;
    else
        m_putback_data.pop_front();
}

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