Refactor TasksView, Mirai instance doesn't depend on it anymore

This commit is contained in:
Vyn 2024-04-17 17:34:26 +02:00
parent d1a4858504
commit 841c87752f
7 changed files with 39 additions and 57 deletions

View file

@ -7,6 +7,7 @@
#include "Backend.h" #include "Backend.h"
#include "TaskItem.h" #include "TaskItem.h"
#include "core/TaskItem.h" #include "core/TaskItem.h"
#include "core/TasksView.h"
#include "core/TodoMd.h" #include "core/TodoMd.h"
#include <iostream> #include <iostream>
#include <ostream> #include <ostream>
@ -15,7 +16,7 @@
#include <qlogging.h> #include <qlogging.h>
#include <qvariant.h> #include <qvariant.h>
Backend::Backend() Backend::Backend() : view(&mirai)
{ {
std::cout << "Backend created" << std::endl; std::cout << "Backend created" << std::endl;
QDir().mkdir(QDir::homePath() + "/.config/mirai"); QDir().mkdir(QDir::homePath() + "/.config/mirai");
@ -51,8 +52,7 @@ Backend::Backend()
jsonTagsConfig.toObject()[jsonTagConfigKey].toObject()["color"].toString(); jsonTagsConfig.toObject()[jsonTagConfigKey].toObject()["color"].toString();
} }
} }
view.update();
view = mirai.getTasks();
rebuildQMLTasksList(); rebuildQMLTasksList();
} }
@ -60,6 +60,7 @@ void Backend::addTodo(QString newTodo, QString date)
{ {
mirai.addTask(newTodo.toStdString(), date.toStdString()); mirai.addTask(newTodo.toStdString(), date.toStdString());
mirai.save(); mirai.save();
view.update();
rebuildQMLTasksList(); rebuildQMLTasksList();
emit tasksChanged(); emit tasksChanged();
} }
@ -75,42 +76,42 @@ void Backend::addTodoFromRawFormat(QString filePath, QString text, QString date)
mirai::TodoMdFormat::StringToTask(text.toStdString(), date.toStdString()) mirai::TodoMdFormat::StringToTask(text.toStdString(), date.toStdString())
); );
mirai.save(); mirai.save();
view.lock()->update(); view.update();
rebuildQMLTasksList(); rebuildQMLTasksList();
emit tasksChanged(); emit tasksChanged();
} }
void Backend::addTagFilter(QString tag) void Backend::addTagFilter(QString tag)
{ {
view.lock()->addTagFilter(tag.toStdString()); view.addTagFilter(tag.toStdString());
rebuildQMLTasksList(); rebuildQMLTasksList();
emit tasksChanged(); emit tasksChanged();
} }
void Backend::removeTagFilter(QString tag) void Backend::removeTagFilter(QString tag)
{ {
view.lock()->removeTagFilter(tag.toStdString()); view.removeTagFilter(tag.toStdString());
rebuildQMLTasksList(); rebuildQMLTasksList();
emit tasksChanged(); emit tasksChanged();
} }
void Backend::addFileFilter(QString fileName) void Backend::addFileFilter(QString fileName)
{ {
view.lock()->addFileFilter(fileName.toStdString()); view.addFileFilter(fileName.toStdString());
rebuildQMLTasksList(); rebuildQMLTasksList();
emit tasksChanged(); emit tasksChanged();
} }
void Backend::removeFileFilter(QString fileName) void Backend::removeFileFilter(QString fileName)
{ {
view.lock()->removeFileFilter(fileName.toStdString()); view.removeFileFilter(fileName.toStdString());
rebuildQMLTasksList(); rebuildQMLTasksList();
emit tasksChanged(); emit tasksChanged();
} }
void Backend::removeFilters() void Backend::removeFilters()
{ {
view.lock()->removeFilters(); view.removeFilters();
rebuildQMLTasksList(); rebuildQMLTasksList();
emit tasksChanged(); emit tasksChanged();
} }
@ -122,7 +123,7 @@ void Backend::updateTodoFromRawFormat(int todoIndex, QString text, QString date)
*(taskItem.taskItem) = *(taskItem.taskItem) =
mirai::TodoMdFormat::StringToTask(text.toStdString(), date.toStdString()); mirai::TodoMdFormat::StringToTask(text.toStdString(), date.toStdString());
mirai.save(); mirai.save();
view.lock()->update(); view.update();
rebuildQMLTasksList(); rebuildQMLTasksList();
emit tasksChanged(); emit tasksChanged();
} }
@ -138,7 +139,7 @@ void Backend::updateTodo(int todoIndex, QString state, QString text, QString dat
taskItem.taskItem->setText(text.toStdString()); taskItem.taskItem->setText(text.toStdString());
taskItem.taskItem->setDate(date.toStdString()); taskItem.taskItem->setDate(date.toStdString());
mirai.save(); mirai.save();
view.lock()->update(); view.update();
rebuildQMLTasksList(); rebuildQMLTasksList();
emit tasksChanged(); emit tasksChanged();
} }
@ -148,6 +149,7 @@ void Backend::removeTodo(int todoIndex)
QMLTaskItem &taskItem = QMLTasks[todoIndex]; QMLTaskItem &taskItem = QMLTasks[todoIndex];
mirai.removeTask(taskItem.taskItem); mirai.removeTask(taskItem.taskItem);
mirai.save(); mirai.save();
view.update();
rebuildQMLTasksList(); rebuildQMLTasksList();
emit tasksChanged(); emit tasksChanged();
} }
@ -173,8 +175,8 @@ void Backend::rebuildQMLTasksList()
std::tm tm = *std::localtime(&t); std::tm tm = *std::localtime(&t);
std::stringstream currentDate; std::stringstream currentDate;
currentDate << std::put_time(&tm, "%Y-%m-%d"); currentDate << std::put_time(&tm, "%Y-%m-%d");
for (int i = 0; i < view.lock()->count(); ++i) { for (int i = 0; i < view.count(); ++i) {
mirai::TaskItem &task = (*view.lock())[i]; mirai::TaskItem &task = view[i];
if (shouldHideCompletedTasks_ && task.getState() == mirai::DONE && task.hasDate() && if (shouldHideCompletedTasks_ && task.getState() == mirai::DONE && task.hasDate() &&
task.getDate() < currentDate.str()) { task.getDate() < currentDate.str()) {
continue; continue;
@ -199,12 +201,12 @@ void Backend::rebuildQMLTasksList()
} }
QMLActiveTagsFilter.clear(); QMLActiveTagsFilter.clear();
for (auto &activeTagFilter : view.lock()->getActiveTagsFilter()) { for (auto &activeTagFilter : view.getActiveTagsFilter()) {
QMLActiveTagsFilter.push_back(QString::fromStdString(activeTagFilter)); QMLActiveTagsFilter.push_back(QString::fromStdString(activeTagFilter));
} }
QMLActiveFilesFilter.clear(); QMLActiveFilesFilter.clear();
for (auto &activeFileFilter : view.lock()->getActiveFilesFilter()) { for (auto &activeFileFilter : view.getActiveFilesFilter()) {
QMLActiveFilesFilter.push_back(QString::fromStdString(activeFileFilter)); QMLActiveFilesFilter.push_back(QString::fromStdString(activeFileFilter));
} }
} }

View file

@ -65,7 +65,7 @@ class Backend : public QObject
bool shouldHideCompletedTasks(); bool shouldHideCompletedTasks();
mirai::Mirai mirai; mirai::Mirai mirai;
std::weak_ptr<mirai::TasksView> view; mirai::TasksView view;
QList<QMLTaskItem> QMLTasks; QList<QMLTaskItem> QMLTasks;
QList<QMLTasksFile> QMLTasksFiles; QList<QMLTasksFile> QMLTasksFiles;

View file

@ -21,13 +21,13 @@ namespace mirai
void Mirai::loadFile(const std::string &path) void Mirai::loadFile(const std::string &path)
{ {
auto tasksFile = TodoMdFormat::readFile(path); auto tasksFile = TodoMdFormat::readFile(path);
files->push_back(std::move(tasksFile)); files.push_back(std::move(tasksFile));
reloadTags(); reloadTags();
} }
void Mirai::save() void Mirai::save()
{ {
for (auto &file : *files) { for (auto &file : files) {
if (file->isDirty()) { if (file->isDirty()) {
TodoMdFormat::writeFile(*file); TodoMdFormat::writeFile(*file);
file->setDirty(false); file->setDirty(false);
@ -38,10 +38,7 @@ void Mirai::save()
void Mirai::addTask(TaskItemData taskItem) void Mirai::addTask(TaskItemData taskItem)
{ {
(*files)[0]->addTask(taskItem); files[0]->addTask(taskItem);
for (auto &view : views) {
view->update();
}
} }
void Mirai::addTask(std::string text, std::string date) void Mirai::addTask(std::string text, std::string date)
@ -50,46 +47,33 @@ void Mirai::addTask(std::string text, std::string date)
/*std::tm tm = *std::localtime(&t);*/ /*std::tm tm = *std::localtime(&t);*/
/*std::stringstream ssCreationDate;*/ /*std::stringstream ssCreationDate;*/
/*ssCreationDate << std::put_time(&tm, "%Y-%m-%d");*/ /*ssCreationDate << std::put_time(&tm, "%Y-%m-%d");*/
(*files)[0]->addTask(text, date); files[0]->addTask(text, date);
for (auto &view : views) {
view->update();
}
} }
void Mirai::removeTask(const TaskItem *taskItem) void Mirai::removeTask(const TaskItem *taskItem)
{ {
for (auto &file : *files) { for (auto &file : files) {
file->removeTask(taskItem); file->removeTask(taskItem);
} }
for (auto &view : views) {
view->update();
}
} }
std::vector<std::unique_ptr<TasksFile>> &Mirai::getFiles() std::vector<std::unique_ptr<TasksFile>> &Mirai::getFiles()
{ {
return *files.get(); return files;
} }
std::optional<std::reference_wrapper<TasksFile>> Mirai::getFileByPath(const std::string &path) std::optional<std::reference_wrapper<TasksFile>> Mirai::getFileByPath(const std::string &path)
{ {
auto fileIterator = std::ranges::find_if(*files, [&](const std::unique_ptr<TasksFile> &file) { auto fileIterator = std::ranges::find_if(files, [&](const std::unique_ptr<TasksFile> &file) {
return file->getPath() == path; return file->getPath() == path;
}); });
if (fileIterator == files->end()) { if (fileIterator == files.end()) {
return std::nullopt; return std::nullopt;
} }
return *(fileIterator->get()); return *(fileIterator->get());
} }
std::weak_ptr<TasksView> Mirai::getTasks()
{
auto view = std::make_shared<TasksView>(files);
views.push_back(view);
return view;
}
const std::vector<std::string> &Mirai::getTags() const std::vector<std::string> &Mirai::getTags()
{ {
return tags; return tags;
@ -98,7 +82,7 @@ const std::vector<std::string> &Mirai::getTags()
void Mirai::reloadTags() void Mirai::reloadTags()
{ {
tags.clear(); tags.clear();
for (auto &file : *files) { for (auto &file : files) {
for (auto &task : file->getTasks()) { for (auto &task : file->getTasks()) {
for (auto &tag : task->getTags()) { for (auto &tag : task->getTags()) {
if (!vectorUtils::contains(tags, tag)) { if (!vectorUtils::contains(tags, tag)) {

View file

@ -9,7 +9,6 @@
#include "TaskItem.h" #include "TaskItem.h"
#include "TasksFile.h" #include "TasksFile.h"
#include "TasksView.h"
#include "TodoMd.h" #include "TodoMd.h"
#include <algorithm> #include <algorithm>
#include <functional> #include <functional>
@ -33,22 +32,12 @@ class Mirai
std::optional<std::reference_wrapper<TasksFile>> getFileByPath(const std::string &path); std::optional<std::reference_wrapper<TasksFile>> getFileByPath(const std::string &path);
std::vector<std::unique_ptr<TasksFile>> &getFiles(); std::vector<std::unique_ptr<TasksFile>> &getFiles();
std::weak_ptr<TasksView> getTasks();
const std::vector<std::string> &getTags(); const std::vector<std::string> &getTags();
void reloadTags(); void reloadTags();
private: private:
// The `TasksFile`s are shared to the views, their lifetime can outlive std::vector<std::unique_ptr<TasksFile>> files = std::vector<std::unique_ptr<TasksFile>>();
// this (Mirai) object
// because we can't control if the caller will keep the main object alive.
std::shared_ptr<std::vector<std::unique_ptr<TasksFile>>> files =
std::make_shared<std::vector<std::unique_ptr<TasksFile>>>();
// We keep a vector of shared_ptr because we need the ref counting mechanism to know
// if we have to remove the view (not used) or tell the view to update() on
// some changes.
std::vector<std::shared_ptr<TasksView>> views;
std::vector<std::string> tags; std::vector<std::string> tags;
}; };
} // namespace mirai } // namespace mirai

View file

@ -5,19 +5,24 @@
*/ */
#include "TasksView.h" #include "TasksView.h"
#include "core/Mirai.h"
#include "utils.h" #include "utils.h"
#include <algorithm> #include <algorithm>
#include <cstddef> #include <cstddef>
#include <iostream> #include <iostream>
#include <memory> #include <memory>
#include <ostream> #include <ostream>
#include <stdexcept>
#include <string> #include <string>
namespace mirai namespace mirai
{ {
TasksView::TasksView(std::shared_ptr<std::vector<std::unique_ptr<TasksFile>>> files) : files(files) TasksView::TasksView(Mirai *miraiInstance) : mirai(miraiInstance)
{ {
if (!miraiInstance) {
throw std::runtime_error("NULL pointer passed in TasksView");
}
update(); update();
} }
@ -34,7 +39,7 @@ size_t TasksView::count() const
void TasksView::update() void TasksView::update()
{ {
tasksToShow.clear(); tasksToShow.clear();
for (auto &file : *files) { for (auto &file : mirai->getFiles()) {
if (filesFilter.size() > 0 && !vectorUtils::contains(filesFilter, file->getName())) { if (filesFilter.size() > 0 && !vectorUtils::contains(filesFilter, file->getName())) {
continue; continue;
} }

View file

@ -7,6 +7,7 @@
#ifndef MIRAI_TASKSVIEW_H #ifndef MIRAI_TASKSVIEW_H
#define MIRAI_TASKSVIEW_H #define MIRAI_TASKSVIEW_H
#include "TasksFile.h" #include "TasksFile.h"
#include "core/Mirai.h"
#include "using.h" #include "using.h"
#include <cstddef> #include <cstddef>
#include <memory> #include <memory>
@ -19,7 +20,7 @@ class TasksView
{ {
public: public:
TasksView(std::shared_ptr<std::vector<std::unique_ptr<TasksFile>>> files); TasksView(Mirai *mirai);
TaskItem &operator[](int index); TaskItem &operator[](int index);
@ -34,7 +35,7 @@ class TasksView
const std::vector<std::string> &getActiveFilesFilter(); const std::vector<std::string> &getActiveFilesFilter();
private: private:
std::shared_ptr<std::vector<std::unique_ptr<TasksFile>>> files; Mirai *mirai;
std::vector<TaskItem *> tasksToShow; std::vector<TaskItem *> tasksToShow;
Tags tagsFilter; Tags tagsFilter;
std::vector<std::string> filesFilter; std::vector<std::string> filesFilter;

View file

@ -16,6 +16,7 @@
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
try { try {
std::cout << "Mirai started" << std::endl;
QGuiApplication app(argc, argv); QGuiApplication app(argc, argv);
qreal refDpi = 54.; qreal refDpi = 54.;