180814287SRaphael Isemann //===-- CommandHistory.cpp ------------------------------------------------===//
27594f14fSEnrico Granata //
32946cd70SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
42946cd70SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
52946cd70SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
67594f14fSEnrico Granata //
77594f14fSEnrico Granata //===----------------------------------------------------------------------===//
87594f14fSEnrico Granata 
9*76e47d48SRaphael Isemann #include <cinttypes>
105275aaa0SVince Harron 
11b9c1b51eSKate Stone #include "lldb/Interpreter/CommandHistory.h"
127594f14fSEnrico Granata 
137594f14fSEnrico Granata using namespace lldb;
147594f14fSEnrico Granata using namespace lldb_private;
157594f14fSEnrico Granata 
GetSize() const16b9c1b51eSKate Stone size_t CommandHistory::GetSize() const {
1716ff8604SSaleem Abdulrasool   std::lock_guard<std::recursive_mutex> guard(m_mutex);
187594f14fSEnrico Granata   return m_history.size();
197594f14fSEnrico Granata }
207594f14fSEnrico Granata 
IsEmpty() const21b9c1b51eSKate Stone bool CommandHistory::IsEmpty() const {
2216ff8604SSaleem Abdulrasool   std::lock_guard<std::recursive_mutex> guard(m_mutex);
237594f14fSEnrico Granata   return m_history.empty();
247594f14fSEnrico Granata }
257594f14fSEnrico Granata 
2653877afcSZachary Turner llvm::Optional<llvm::StringRef>
FindString(llvm::StringRef input_str) const2753877afcSZachary Turner CommandHistory::FindString(llvm::StringRef input_str) const {
2816ff8604SSaleem Abdulrasool   std::lock_guard<std::recursive_mutex> guard(m_mutex);
2953877afcSZachary Turner   if (input_str.size() < 2)
3053877afcSZachary Turner     return llvm::None;
3153877afcSZachary Turner 
327594f14fSEnrico Granata   if (input_str[0] != g_repeat_char)
3353877afcSZachary Turner     return llvm::None;
347594f14fSEnrico Granata 
3553877afcSZachary Turner   if (input_str[1] == g_repeat_char) {
367594f14fSEnrico Granata     if (m_history.empty())
3753877afcSZachary Turner       return llvm::None;
38eb4a0cb1SZachary Turner     return llvm::StringRef(m_history.back());
3953877afcSZachary Turner   }
4053877afcSZachary Turner 
4153877afcSZachary Turner   input_str = input_str.drop_front();
4253877afcSZachary Turner 
4353877afcSZachary Turner   size_t idx = 0;
4453877afcSZachary Turner   if (input_str.front() == '-') {
45aab5be05SJim Ingham     if (input_str.drop_front(1).getAsInteger(0, idx))
4653877afcSZachary Turner       return llvm::None;
47eb4a0cb1SZachary Turner     if (idx >= m_history.size())
4853877afcSZachary Turner       return llvm::None;
4953877afcSZachary Turner     idx = m_history.size() - idx;
50b9c1b51eSKate Stone   } else {
51aab5be05SJim Ingham     if (input_str.getAsInteger(0, idx))
5253877afcSZachary Turner       return llvm::None;
537594f14fSEnrico Granata     if (idx >= m_history.size())
5453877afcSZachary Turner       return llvm::None;
557594f14fSEnrico Granata   }
56eb4a0cb1SZachary Turner 
57eb4a0cb1SZachary Turner   return llvm::StringRef(m_history[idx]);
587594f14fSEnrico Granata }
597594f14fSEnrico Granata 
GetStringAtIndex(size_t idx) const6053877afcSZachary Turner llvm::StringRef CommandHistory::GetStringAtIndex(size_t idx) const {
6116ff8604SSaleem Abdulrasool   std::lock_guard<std::recursive_mutex> guard(m_mutex);
627594f14fSEnrico Granata   if (idx < m_history.size())
6353877afcSZachary Turner     return m_history[idx];
6453877afcSZachary Turner   return "";
657594f14fSEnrico Granata }
667594f14fSEnrico Granata 
operator [](size_t idx) const6753877afcSZachary Turner llvm::StringRef CommandHistory::operator[](size_t idx) const {
687594f14fSEnrico Granata   return GetStringAtIndex(idx);
697594f14fSEnrico Granata }
707594f14fSEnrico Granata 
GetRecentmostString() const7153877afcSZachary Turner llvm::StringRef CommandHistory::GetRecentmostString() const {
7216ff8604SSaleem Abdulrasool   std::lock_guard<std::recursive_mutex> guard(m_mutex);
737594f14fSEnrico Granata   if (m_history.empty())
7453877afcSZachary Turner     return "";
7553877afcSZachary Turner   return m_history.back();
767594f14fSEnrico Granata }
777594f14fSEnrico Granata 
AppendString(llvm::StringRef str,bool reject_if_dupe)7853877afcSZachary Turner void CommandHistory::AppendString(llvm::StringRef str, bool reject_if_dupe) {
7916ff8604SSaleem Abdulrasool   std::lock_guard<std::recursive_mutex> guard(m_mutex);
80b9c1b51eSKate Stone   if (reject_if_dupe) {
81b9c1b51eSKate Stone     if (!m_history.empty()) {
827594f14fSEnrico Granata       if (str == m_history.back())
837594f14fSEnrico Granata         return;
847594f14fSEnrico Granata     }
857594f14fSEnrico Granata   }
86adcd0268SBenjamin Kramer   m_history.push_back(std::string(str));
877594f14fSEnrico Granata }
887594f14fSEnrico Granata 
Clear()89b9c1b51eSKate Stone void CommandHistory::Clear() {
9016ff8604SSaleem Abdulrasool   std::lock_guard<std::recursive_mutex> guard(m_mutex);
917594f14fSEnrico Granata   m_history.clear();
927594f14fSEnrico Granata }
937594f14fSEnrico Granata 
Dump(Stream & stream,size_t start_idx,size_t stop_idx) const94b9c1b51eSKate Stone void CommandHistory::Dump(Stream &stream, size_t start_idx,
95b9c1b51eSKate Stone                           size_t stop_idx) const {
9616ff8604SSaleem Abdulrasool   std::lock_guard<std::recursive_mutex> guard(m_mutex);
970167e064SKate Stone   stop_idx = std::min(stop_idx + 1, m_history.size());
98b9c1b51eSKate Stone   for (size_t counter = start_idx; counter < stop_idx; counter++) {
997594f14fSEnrico Granata     const std::string hist_item = m_history[counter];
100b9c1b51eSKate Stone     if (!hist_item.empty()) {
1017594f14fSEnrico Granata       stream.Indent();
1026fea17e8SGreg Clayton       stream.Printf("%4" PRIu64 ": %s\n", (uint64_t)counter, hist_item.c_str());
1037594f14fSEnrico Granata     }
1047594f14fSEnrico Granata   }
1057594f14fSEnrico Granata }
106