blob: 7bdbd51a2287d633a8c155ec56029af27c215a86 [file] [log] [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_SYNC_FILE_SYSTEM_TASK_LOGGER_H_
#define CHROME_BROWSER_SYNC_FILE_SYSTEM_TASK_LOGGER_H_
#include <memory>
#include <string>
#include <vector>
#include "base/containers/circular_deque.h"
#include "base/memory/weak_ptr.h"
#include "base/observer_list.h"
#include "base/time/time.h"
namespace sync_file_system {
class TaskLogger final {
public:
struct TaskLog {
int log_id;
base::TimeTicks start_time;
base::TimeTicks end_time;
std::string task_description;
std::string result_description;
std::vector<std::string> details;
TaskLog();
~TaskLog();
};
using LogList = base::circular_deque<std::unique_ptr<TaskLog>>;
class Observer {
public:
Observer(const Observer&) = delete;
Observer& operator=(const Observer&) = delete;
virtual void OnLogRecorded(const TaskLog& task_log) = 0;
protected:
Observer() {}
virtual ~Observer() {}
};
TaskLogger();
TaskLogger(const TaskLogger&) = delete;
TaskLogger& operator=(const TaskLogger&) = delete;
~TaskLogger();
void RecordLog(std::unique_ptr<TaskLog> log);
void ClearLog();
void AddObserver(Observer* observer);
void RemoveObserver(Observer* observer);
const LogList& GetLog() const;
base::WeakPtr<TaskLogger> AsWeakPtr() {
return weak_ptr_factory_.GetWeakPtr();
}
private:
LogList log_history_;
base::ObserverList<Observer>::Unchecked observers_;
base::WeakPtrFactory<TaskLogger> weak_ptr_factory_{this};
};
} // namespace sync_file_system
#endif // CHROME_BROWSER_SYNC_FILE_SYSTEM_TASK_LOGGER_H_