Files
llvm/lldb/source/Utility/StringLexer.cpp
Sean Callanan 5c35f7cfd1 Cleaned up the StringLexer a little bit. It turns
out we only want to roll back text that was in the
buffer to begin with, so it's not necessary to
provide a pushback stack.

I'm going to use this slightly cleaner API to perform
lookahead for the Objective-C runtime type parser.

llvm-svn: 221640
2014-11-10 23:20:52 +00:00

88 lines
1.5 KiB
C++

//===--------------------- 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;
}
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;
}
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;
}