diff options
| author | Andrea Diamantini <adjam7@gmail.com> | 2012-07-30 17:33:34 +0200 | 
|---|---|---|
| committer | Andrea Diamantini <adjam7@gmail.com> | 2012-12-10 02:48:04 +0100 | 
| commit | e4ff5514f1fad63fc03ba3e1046eb4a350ca3562 (patch) | |
| tree | 22aedf3169f9a6d8e4e63d5d60da4c7146e8dc7b /src/session | |
| parent | Insert back HistoryManager (diff) | |
| download | rekonq-e4ff5514f1fad63fc03ba3e1046eb4a350ca3562.tar.xz | |
Session Manager
- Moved to new rekonq API
- Use autosaver to save up disk writes
Diffstat (limited to 'src/session')
| -rw-r--r-- | src/session/sessionmanager.cpp | 331 | ||||
| -rw-r--r-- | src/session/sessionmanager.h | 104 | 
2 files changed, 435 insertions, 0 deletions
| diff --git a/src/session/sessionmanager.cpp b/src/session/sessionmanager.cpp new file mode 100644 index 00000000..1ea5c133 --- /dev/null +++ b/src/session/sessionmanager.cpp @@ -0,0 +1,331 @@ +/* ============================================================ +* +* This file is a part of the rekonq project +* +* Copyright (C) 2009-2012 by Andrea Diamantini <adjam7 at gmail dot com> +* Copyright (C) 2009 by Yoram Bar-Haim <<yoram.b at zend dot com> +* Copyright (C) 2009-2011 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 "autosaver.h" +#include "tabhistory.h" +#include "tabwindow.h" +#include "webwindow.h" +#include "webpage.h" + +// KDE Includes +#include <KStandardDirs> +#include <KUrl> + +// Qt Includes +#include <QFile> +#include <QDomDocument> + + +// Only used internally +bool readSessionDocument(QDomDocument & document, const QString & sessionFilePath) +{ +    QFile sessionFile(sessionFilePath); + +    if (!sessionFile.exists()) +        return false; + +    if (!sessionFile.open(QFile::ReadOnly)) +    { +        kDebug() << "Unable to open session file" << sessionFile.fileName(); +        return false; +    } + +    if (!document.setContent(&sessionFile, false)) +    { +        kDebug() << "Unable to parse session file" << sessionFile.fileName(); +        return false; +    } + +    return true; +} + + +int loadTabs(TabWindow *tw, QDomElement & window, bool useFirstTab) +{ +    int currentTab = 0; + +    for (unsigned int tabNo = 0; tabNo < window.elementsByTagName("tab").length(); tabNo++) +    { +        QDomElement tab = window.elementsByTagName("tab").at(tabNo).toElement(); +        if (tab.hasAttribute("currentTab")) +            currentTab = tabNo; + +        KUrl u = KUrl(tab.attribute("url")); + +        TabHistory tabHistory; +        tabHistory.title = tab.attribute("title"); +        tabHistory.url = tab.attribute("url"); +        QDomCDATASection historySection = tab.firstChild().toCDATASection(); +        tabHistory.history = QByteArray::fromBase64(historySection.data().toAscii()); + +        if (tabNo == 0 && useFirstTab) +        { +            tw->loadUrl(u, Rekonq::CurrentTab, &tabHistory); +        } +        else +        { +            tw->loadUrl(u, Rekonq::NewTab, &tabHistory); +        } +    } + +    return currentTab; +} + + +// ------------------------------------------------------------------------------------------------- + + +QWeakPointer<SessionManager> SessionManager::s_sessionyManager; + + +SessionManager *SessionManager::self() +{ +    if (s_sessionyManager.isNull()) +    { +        s_sessionyManager = new SessionManager(qApp); +    } +    return s_sessionyManager.data(); +} + + +// ---------------------------------------------------------------------------------------------- + + +SessionManager::SessionManager(QObject *parent) +    : QObject(parent) +    , m_safe(true) +    , m_isSessionEnabled(false) +    , m_saveTimer(new AutoSaver(this)) +{ +    // AutoSaver. Save your hd from frying... +    connect(m_saveTimer, SIGNAL(saveNeeded()), this, SLOT(save())); + +    m_sessionFilePath = KStandardDirs::locateLocal("appdata" , "session"); +} + + +void SessionManager::saveSession() +{ +    if (!m_isSessionEnabled) +        return; +     +    m_saveTimer->changeOccurred(); +} + + +void SessionManager::save() +{ +    if (!m_isSessionEnabled || !m_safe) +        return; + +    m_safe = false; + +    kDebug() << "SAVING SESSION..."; + +    QFile sessionFile(m_sessionFilePath); +    if (!sessionFile.open(QFile::WriteOnly | QFile::Truncate)) +    { +        kDebug() << "Unable to open session file" << sessionFile.fileName(); +        return; +    } +    TabWindowList wl = rApp->tabWindowList(); +    QDomDocument document("session"); +    QDomElement session = document.createElement("session"); +    document.appendChild(session); + +    Q_FOREACH(const QWeakPointer<TabWindow> &w, wl) +    { +        QDomElement window = document.createElement("window"); +        int tabInserted = 0; + +        window.setAttribute("name", w.data()->objectName()); + +        for (signed int tabNo = 0; tabNo < w.data()->count(); tabNo++) +        { +            KUrl u = w.data()->webWindow(tabNo)->url(); + +            tabInserted++; +            QDomElement tab = document.createElement("tab"); +            tab.setAttribute("title", w.data()->webWindow(tabNo)->title()); // redundant, but needed for closedSites() +            // as there's not way to read out the historyData +            tab.setAttribute("url", u.url()); +            if (w.data()->currentIndex() == tabNo) +            { +                tab.setAttribute("currentTab", 1); +            } +            QByteArray history; +            QDataStream historyStream(&history, QIODevice::ReadWrite); +            historyStream << *(w.data()->webWindow(tabNo)->page()->history()); +            QDomCDATASection historySection = document.createCDATASection(history.toBase64()); + +            tab.appendChild(historySection); +            window.appendChild(tab); +        } +        if (tabInserted > 0) +            session.appendChild(window); +    } + +    QTextStream TextStream(&sessionFile); +    document.save(TextStream, 2); +    sessionFile.close(); + +    m_safe = true; +    return; +} + + +bool SessionManager::restoreSessionFromScratch() +{ +    QDomDocument document("session"); + +    if (!readSessionDocument(document, m_sessionFilePath)) +        return false; + +    for (unsigned int winNo = 0; winNo < document.elementsByTagName("window").length(); winNo++) +    { +        QDomElement window = document.elementsByTagName("window").at(winNo).toElement(); + +        TabWindow *tw = rApp->newTabWindow(); + +        int currentTab = loadTabs(tw, window, false); + +        tw->setCurrentIndex(currentTab); +    } + +    return true; +} + + +void SessionManager::restoreCrashedSession() +{ +    QDomDocument document("session"); + +    if (!readSessionDocument(document, m_sessionFilePath)) +        return; + +    for (unsigned int winNo = 0; winNo < document.elementsByTagName("window").length(); winNo++) +    { +        QDomElement window = document.elementsByTagName("window").at(winNo).toElement(); + +        TabWindow *tw = (winNo == 0) +            ? rApp->tabWindow() +            : rApp->newTabWindow(); + +        KUrl u = tw->currentWebWindow()->url(); +        bool useCurrentTab = (u.isEmpty() || u.protocol() == QL1S("about")); +        int currentTab = loadTabs(tw, window, useCurrentTab); + +        tw->setCurrentIndex(currentTab); +    } + +    setSessionManagementEnabled(true); +} + + +int SessionManager::restoreSavedSession() +{ +    QDomDocument document("session"); + +    if (!readSessionDocument(document, m_sessionFilePath)) +        return 0; + +    unsigned int winNo; + +    for (winNo = 0; winNo < document.elementsByTagName("window").length(); winNo++) +    { +        QDomElement window = document.elementsByTagName("window").at(winNo).toElement(); + +        TabWindow *tw = rApp->newTabWindow(); + +        int currentTab = loadTabs(tw, window, true); + +        tw->setCurrentIndex(currentTab); +    } + +    return winNo; +} + + +bool SessionManager::restoreTabWindow(TabWindow* window) +{ +    QDomDocument document("session"); + +    if (!readSessionDocument(document, m_sessionFilePath)) +        return false; + +    unsigned int winNo; + +    for (winNo = 0; winNo < document.elementsByTagName("window").length(); winNo++) +    { +        QDomElement savedWindowElement = document.elementsByTagName("window").at(winNo).toElement(); + +        if (window->objectName() != savedWindowElement.attribute("name", "")) +            continue; + +        int currentTab = loadTabs(window, savedWindowElement, false); + +        window->setCurrentIndex(currentTab); + +        return true; +    } + +    return false; +} + + +QList<TabHistory> SessionManager::closedSites() +{ +    QList<TabHistory> list; +    QDomDocument document("session"); + +    if (!readSessionDocument(document, m_sessionFilePath)) +        return list; + +    for (unsigned int tabNo = 0; tabNo < document.elementsByTagName("tab").length(); tabNo++) +    { +        QDomElement tab = document.elementsByTagName("tab").at(tabNo).toElement(); + +        TabHistory tabHistory; + +        tabHistory.title = tab.attribute("title"); +        tabHistory.url = tab.attribute("url"); + +        QDomCDATASection historySection = tab.firstChild().toCDATASection(); +        tabHistory.history = QByteArray::fromBase64(historySection.data().toAscii()); + +        list << tabHistory; +    } + +    return list; +} diff --git a/src/session/sessionmanager.h b/src/session/sessionmanager.h new file mode 100644 index 00000000..31afea82 --- /dev/null +++ b/src/session/sessionmanager.h @@ -0,0 +1,104 @@ +/* ============================================================ +* +* This file is a part of the rekonq project +* +* Copyright (C) 2009-2012 by Andrea Diamantini <adjam7 at gmail dot com> +* Copyright (C) 2009 by Yoram Bar-Haim <<yoram.b at zend dot com> +* Copyright (C) 2009-2011 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 + + +// Rekonq Includes +#include "rekonq_defines.h" + +// Qt Includes +#include <QObject> +#include <QString> +#include <QWeakPointer> + +// Forward Declarations +class AutoSaver; +class TabHistory; +class TabWindow; + + +/** +  * Session Management: Needs clean up :) +  *  +  */ +class REKONQ_TESTS_EXPORT SessionManager : public QObject +{ +    Q_OBJECT + +public: +    /** +     * Entry point. +     * Access to SessionManager class by using +     * SessionyManager::self()->thePublicMethodYouNeed() +     */ +    static SessionManager *self(); + +    inline void setSessionManagementEnabled(bool on) +    { +        m_isSessionEnabled = on; +    } + +    QList<TabHistory> closedSites(); + +    // This method restores session +    // while turning back from Private mode +    int restoreSavedSession(); + +    // This method restores a single TabWindow +    bool restoreTabWindow(TabWindow * window); + +private: +    SessionManager(QObject *parent = 0); + +public Q_SLOTS: +    // This method restores session +    // on restart when restore at startup is chosen +    bool restoreSessionFromScratch(); + +private Q_SLOTS: +    void saveSession(); +    void save(); +     +    // This method restores session +    // after a crash +    void restoreCrashedSession(); + +private: +    QString m_sessionFilePath; + +    bool m_safe; +    bool m_isSessionEnabled; +    AutoSaver *m_saveTimer; + +    static QWeakPointer<SessionManager> s_sessionyManager; +}; + + +#endif // SESSION_MANAGER_H | 
