summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrea Diamantini <adjam7@gmail.com>2009-09-10 21:59:09 +0200
committerAndrea Diamantini <adjam7@gmail.com>2009-09-10 21:59:09 +0200
commitcfbfe4ba48c747772e86018df41f6970fc007b11 (patch)
tree6bafe57c475a724866afa0b807b22508f3be9d6f
parentWebkit -> WebKit (diff)
downloadrekonq-cfbfe4ba48c747772e86018df41f6970fc007b11.tar.xz
Session Management (restore on crash)
This is HEAVILY based on code from Lionel and Yoram branches. But this code behaves differently: it restores rekonq tabs (just) on crash. Thanks to Lionel suggestions, it seems "better" than my initial idea :) It is quite extensible. We need just to fix it better as possible and then manage its behaviour in newInstance code.. ;)
-rw-r--r--src/CMakeLists.txt1
-rw-r--r--src/application.cpp23
-rw-r--r--src/application.h10
-rw-r--r--src/mainview.cpp4
-rw-r--r--src/sessionmanager.cpp116
-rw-r--r--src/sessionmanager.h56
6 files changed, 207 insertions, 3 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index a2d0db60..1b760a64 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -21,6 +21,7 @@ SET( rekonq_SRCS
panelhistory.cpp
lineedit.cpp
webpage.cpp
+ sessionmanager.cpp
)
diff --git a/src/application.cpp b/src/application.cpp
index 8324d212..1e30cfd0 100644
--- a/src/application.cpp
+++ b/src/application.cpp
@@ -41,6 +41,7 @@
#include "mainview.h"
#include "webview.h"
#include "urlbar.h"
+#include "sessionmanager.h"
// KDE Includes
#include <KCmdLineArgs>
@@ -62,6 +63,7 @@
QPointer<HistoryManager> Application::s_historyManager;
QPointer<NetworkAccessManager> Application::s_networkAccessManager;
QPointer<BookmarkProvider> Application::s_bookmarkProvider;
+QPointer<SessionManager> Application::s_sessionManager;
@@ -82,6 +84,11 @@ Application::~Application()
int Application::newInstance()
{
+ if( isSessionRestored() && sessionManager()->restoreSession() )
+ {
+ return 1;
+ }
+
KCmdLineArgs::setCwd(QDir::currentPath().toUtf8());
KCmdLineArgs* args = KCmdLineArgs::parsedArgs();
@@ -141,6 +148,7 @@ void Application::postLaunch()
QWebSettings::setIconDatabasePath(directory);
Application::historyManager();
+ Application::sessionManager();
}
@@ -208,6 +216,16 @@ BookmarkProvider *Application::bookmarkProvider()
}
+SessionManager *Application::sessionManager()
+{
+ if(!s_sessionManager)
+ {
+ s_sessionManager = new SessionManager(instance());
+ }
+ return s_sessionManager;
+}
+
+
KIcon Application::icon(const KUrl &url)
{
KIcon icon;
@@ -384,3 +402,8 @@ MainWindow *Application::newMainWindow()
return w;
}
+
+MainWindowList Application::mainWindowList()
+{
+ return m_mainWindows;
+}
diff --git a/src/application.h b/src/application.h
index 60aec259..61d93b87 100644
--- a/src/application.h
+++ b/src/application.h
@@ -49,6 +49,7 @@ class CookieJar;
class HistoryManager;
class MainWindow;
class NetworkAccessManager;
+class SessionManager;
typedef QList< QPointer<MainWindow> > MainWindowList;
@@ -99,14 +100,16 @@ public:
static Application *instance();
MainWindow *mainWindow();
-
+ MainWindowList mainWindowList();
+
static KIcon icon(const KUrl &url);
static HistoryManager *historyManager();
static CookieJar *cookieJar();
static NetworkAccessManager *networkAccessManager();
static BookmarkProvider *bookmarkProvider();
-
+ static SessionManager *sessionManager();
+
public slots:
/**
* Save application's configuration
@@ -138,7 +141,8 @@ private:
static QPointer<HistoryManager> s_historyManager;
static QPointer<NetworkAccessManager> s_networkAccessManager;
static QPointer<BookmarkProvider> s_bookmarkProvider;
-
+ static QPointer<SessionManager> s_sessionManager;
+
MainWindowList m_mainWindows;
};
diff --git a/src/mainview.cpp b/src/mainview.cpp
index a12ec8f9..76684c31 100644
--- a/src/mainview.cpp
+++ b/src/mainview.cpp
@@ -40,6 +40,7 @@
#include "history.h"
#include "urlbar.h"
#include "webview.h"
+#include "sessionmanager.h"
// KDE Includes
#include <KUrl>
@@ -92,6 +93,9 @@ MainView::MainView(QWidget *parent)
setTabsClosable(true);
connect(m_tabBar, SIGNAL(tabCloseRequested(int)), this, SLOT(slotCloseTab(int)));
+
+ // Session Manager
+ connect (this,SIGNAL(tabsChanged()),Application::sessionManager(),SLOT(saveSession()));
}
diff --git a/src/sessionmanager.cpp b/src/sessionmanager.cpp
new file mode 100644
index 00000000..34466e6e
--- /dev/null
+++ b/src/sessionmanager.cpp
@@ -0,0 +1,116 @@
+/* ============================================================
+*
+* This file is a part of the rekonq project
+*
+* Copyright (C) 2009 by Andrea Diamantini <adjam7 at gmail dot com>
+* Copyright (C) 2009 by Yoram Bar-Haim <<yoram.b at zend dot com>
+* Copyright (C) 2009 by Lionel Chauvin <megabigbug@yahoo.fr>
+*
+*
+* This program is free software; you can redistribute it and/or
+* modify it under the terms of the GNU General Public License as
+* published by the Free Software Foundation; either version 2 of
+* the License or (at your option) version 3 or any later version
+* accepted by the membership of KDE e.V. (or its successor approved
+* by the membership of KDE e.V.), which shall act as a proxy
+* defined in Section 14 of version 3 of the license.
+*
+* This program is distributed in the hope that it will be useful,
+* but WITHOUT ANY WARRANTY; without even the implied warranty of
+* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+* GNU General Public License for more details.
+*
+* You should have received a copy of the GNU General Public License
+* along with this program. If not, see <http://www.gnu.org/licenses/>.
+*
+* ============================================================ */
+
+
+// Self Includes
+#include "sessionmanager.h"
+#include "sessionmanager.moc"
+
+// Local Includes
+#include "application.h"
+#include "mainwindow.h"
+#include "mainview.h"
+
+// KDE Includes
+#include <KStandardDirs>
+#include <KDebug>
+
+// Qt Includes
+#include <QFile>
+#include <QDataStream>
+
+
+SessionManager::SessionManager(QObject *parent)
+ : QObject(parent)
+{
+ m_sessionFilePath = KStandardDirs::locateLocal("appdata" , "session");
+}
+
+
+SessionManager::~SessionManager()
+{
+ // rekonq is closing well. no need for session file
+ QFile sessionFile(m_sessionFilePath);
+ sessionFile.remove();
+}
+
+
+void SessionManager::saveSession()
+{
+ QFile sessionFile(m_sessionFilePath);
+ if (!sessionFile.open(QFile::WriteOnly | QFile::Truncate))
+ {
+ kWarning() << "Unable to open session file" << sessionFile.fileName();
+ return;
+ }
+ QDataStream out(&sessionFile);
+ MainWindowList wl = Application::instance()->mainWindowList();
+ foreach(QPointer<MainWindow> w, wl)
+ {
+ out << QByteArray("window");
+ MainView *mv = w->mainView();
+ for (int i = 0 ; i < mv->count() ; i++)
+ {
+ out << mv->webView(i)->url().toEncoded();
+ }
+ }
+ return;
+}
+
+
+bool SessionManager::restoreSession()
+{
+ QFile sessionFile(m_sessionFilePath);
+ if (!sessionFile.exists())
+ return false;
+ if (!sessionFile.open(QFile::ReadOnly))
+ {
+ kWarning() << "Unable to open session file" << sessionFile.fileName();
+ return false;
+ }
+
+ QDataStream in(&sessionFile);
+ int i = 0;
+ while (!sessionFile.atEnd())
+ {
+ ++i;
+ QByteArray data;
+ in >> data;
+ if(data == QByteArray("window"))
+ {
+ Application::instance()->newMainWindow();
+ }
+ else
+ {
+ Application::instance()->loadUrl(data,Rekonq::NewCurrentTab);
+ }
+ }
+
+ // session is restored. remove session file.
+ sessionFile.remove();
+ return true;
+}
diff --git a/src/sessionmanager.h b/src/sessionmanager.h
new file mode 100644
index 00000000..1ff8fa53
--- /dev/null
+++ b/src/sessionmanager.h
@@ -0,0 +1,56 @@
+/* ============================================================
+*
+* This file is a part of the rekonq project
+*
+* Copyright (C) 2009 by Andrea Diamantini <adjam7 at gmail dot com>
+* Copyright (C) 2009 by Yoram Bar-Haim <<yoram.b at zend dot com>
+* Copyright (C) 2009 by Lionel Chauvin <megabigbug@yahoo.fr>
+*
+*
+* This program is free software; you can redistribute it and/or
+* modify it under the terms of the GNU General Public License as
+* published by the Free Software Foundation; either version 2 of
+* the License or (at your option) version 3 or any later version
+* accepted by the membership of KDE e.V. (or its successor approved
+* by the membership of KDE e.V.), which shall act as a proxy
+* defined in Section 14 of version 3 of the license.
+*
+* This program is distributed in the hope that it will be useful,
+* but WITHOUT ANY WARRANTY; without even the implied warranty of
+* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+* GNU General Public License for more details.
+*
+* You should have received a copy of the GNU General Public License
+* along with this program. If not, see <http://www.gnu.org/licenses/>.
+*
+* ============================================================ */
+
+
+#ifndef SESSION_MANAGER_H
+#define SESSION_MANAGER_H
+
+
+// Qt Includes
+#include <QtCore/QObject>
+#include <QtCore/QString>
+
+/**
+ *
+ */
+class SessionManager : public QObject
+{
+ Q_OBJECT
+public:
+ SessionManager(QObject *parent = 0);
+ ~SessionManager();
+
+public slots:
+ void saveSession();
+ bool restoreSession();
+
+private:
+ QString m_sessionFilePath;
+};
+
+
+#endif // SESSION_MANAGER_H