diff options
author | 2020-08-03 14:33:06 +0000 | |
---|---|---|
committer | 2020-08-03 14:33:06 +0000 | |
commit | 061da546b983eb767bad15e67af1174fb0bcf31c (patch) | |
tree | 83c78b820819d70aa40c36d90447978b300078c5 /gnu/llvm/lldb/source/Utility/StringLexer.cpp | |
parent | Import LLVM 10.0.0 release including clang, lld and lldb. (diff) | |
download | wireguard-openbsd-061da546b983eb767bad15e67af1174fb0bcf31c.tar.xz wireguard-openbsd-061da546b983eb767bad15e67af1174fb0bcf31c.zip |
Import LLVM 10.0.0 release including clang, lld and lldb.
ok hackroom
tested by plenty
Diffstat (limited to 'gnu/llvm/lldb/source/Utility/StringLexer.cpp')
-rw-r--r-- | gnu/llvm/lldb/source/Utility/StringLexer.cpp | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/gnu/llvm/lldb/source/Utility/StringLexer.cpp b/gnu/llvm/lldb/source/Utility/StringLexer.cpp new file mode 100644 index 00000000000..c357cb0fb55 --- /dev/null +++ b/gnu/llvm/lldb/source/Utility/StringLexer.cpp @@ -0,0 +1,84 @@ +//===--------------------- StringLexer.cpp -----------------------*- C++-*-===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#include "lldb/Utility/StringLexer.h" + +#include <algorithm> +#include <assert.h> + +using namespace lldb_private; + +StringLexer::StringLexer(std::string s) : m_data(s), m_position(0) {} + +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; +} + +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; +} |