blob: 80f880695c859ac08e31648ba89e7cae9fb3940a [file] [log] [blame]
// Copyright 2018 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ash/assistant/model/assistant_query_history.h"
namespace ash {
AssistantQueryHistory::AssistantQueryHistory(int capacity)
: capacity_(capacity) {
queries_.reserve(capacity);
}
AssistantQueryHistory::~AssistantQueryHistory() = default;
std::unique_ptr<AssistantQueryHistory::Iterator>
AssistantQueryHistory::GetIterator() const {
return std::make_unique<AssistantQueryHistory::Iterator>(queries_);
}
void AssistantQueryHistory::Add(const std::string& query) {
if (query.empty())
return;
if (static_cast<int>(queries_.size()) == capacity_)
queries_.pop_front();
queries_.push_back(query);
}
AssistantQueryHistory::Iterator::Iterator(
const base::circular_deque<std::string>& queries)
: queries_(queries), cur_pos_(queries_.size()) {}
AssistantQueryHistory::Iterator::~Iterator() = default;
base::Optional<std::string> AssistantQueryHistory::Iterator::Next() {
// queries_.size() is of type unsigned int and queries_.size() -1 will
// overflow if it is 0.
if (cur_pos_ + 1 >= queries_.size()) {
cur_pos_ = queries_.size();
return base::nullopt;
}
cur_pos_++;
return base::make_optional<std::string>(queries_[cur_pos_]);
}
base::Optional<std::string> AssistantQueryHistory::Iterator::Prev() {
if (queries_.size() == 0)
return base::nullopt;
if (cur_pos_ != 0)
cur_pos_--;
return base::make_optional<std::string>(queries_[cur_pos_]);
}
void AssistantQueryHistory::Iterator::ResetToLast() {
cur_pos_ = queries_.size();
}
} // namespace ash