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