diff --git a/src/plugins/tasklist/tasklistplugin.cpp b/src/plugins/tasklist/tasklistplugin.cpp index e22ad4e23b1..9cbbab8b97b 100644 --- a/src/plugins/tasklist/tasklistplugin.cpp +++ b/src/plugins/tasklist/tasklistplugin.cpp @@ -38,6 +38,7 @@ #include #include #include +#include #include #include @@ -48,6 +49,9 @@ using namespace ProjectExplorer; using namespace TaskList::Internal; +static const char SESSION_FILE_KEY[] = "TaskList.File"; +static const char SESSION_CONTEXT_KEY[] = "TaskList.Context"; + namespace TaskList { static Task::TaskType typeFrom(const QString &typeName) @@ -171,22 +175,34 @@ bool TaskListPlugin::initialize(const QStringList &arguments, QString *errorMess m_fileFactory = new TaskFileFactory(this); addAutoReleasedObject(m_fileFactory); addAutoReleasedObject(new StopMonitoringHandler); + + connect(SessionManager::instance(), SIGNAL(sessionLoaded(QString)), + this, SLOT(loadDataFromSession())); + return true; } bool TaskListPlugin::loadFile(QString *errorString, Project *context, const QString &fileName) { clearTasks(); - return parseTaskFile(errorString, context, fileName); -} -bool TaskListPlugin::monitorFile(Project *context, const QString &fileName) -{ - return m_fileFactory->open(context, fileName); + bool result = parseTaskFile(errorString, context, fileName); + if (result) { + SessionManager::setValue(QLatin1String(SESSION_CONTEXT_KEY), + context ? context->projectFilePath() : QString()); + SessionManager::setValue(QLatin1String(SESSION_FILE_KEY), fileName); + } else { + stopMonitoring(); + } + + return result; } void TaskListPlugin::stopMonitoring() { + SessionManager::setValue(QLatin1String(SESSION_CONTEXT_KEY), QString()); + SessionManager::setValue(QLatin1String(SESSION_FILE_KEY), QString()); + m_fileFactory->closeAllFiles(); } @@ -195,6 +211,15 @@ void TaskListPlugin::clearTasks() TaskHub::clearTasks(Constants::TASKLISTTASK_ID); } +void TaskListPlugin::loadDataFromSession() +{ + const QString fileName = SessionManager::value(QLatin1String(SESSION_FILE_KEY)).toString(); + if (fileName.isEmpty()) + return; + Project *project = SessionManager::projectForFile(SessionManager::value(QLatin1String(SESSION_CONTEXT_KEY)).toString()); + m_fileFactory->open(project, fileName); +} + } // namespace TaskList Q_EXPORT_PLUGIN(TaskList::TaskListPlugin) diff --git a/src/plugins/tasklist/tasklistplugin.h b/src/plugins/tasklist/tasklistplugin.h index 2c42e425da9..772bf8f3d90 100644 --- a/src/plugins/tasklist/tasklistplugin.h +++ b/src/plugins/tasklist/tasklistplugin.h @@ -46,10 +46,12 @@ public: void extensionsInitialized() {} static bool loadFile(QString *errorString, ProjectExplorer::Project *context, const QString &fileName); - static bool monitorFile(ProjectExplorer::Project *context, const QString &fileName); static void stopMonitoring(); static void clearTasks(); + +public slots: + void loadDataFromSession(); }; } // namespace TaskList