summaryrefslogtreecommitdiff
path: root/src/webenginewidgets
diff options
context:
space:
mode:
authorJocelyn Turcotte <jocelyn.turcotte@digia.com>2014-03-21 14:43:21 +0100
committerThe Qt Project <gerrit-noreply@qt-project.org>2014-03-31 16:43:59 +0200
commite9575322f8068b2dd2bc0b30a0f444f769a861b9 (patch)
tree1a6fbc4a8cb71d10f436265d20bcb1538e836220 /src/webenginewidgets
parent3f69bf43c45e54789ce6cdc4a2f01ea129e6287c (diff)
downloadqtwebengine-e9575322f8068b2dd2bc0b30a0f444f769a861b9.tar.gz
Implement QWebEngineHistory serialization
This does uses logic taken from Chromium's state save and restore code. The history version is incremented from the same method in QtWebKit in cases where the application would try loading a stream from a previous version using QtWebKit. In all cases where Chromium does a restore of a serialized history, it does so on a fresh WebContents instance, thus we must do the same and some of the initialization code has to be updated. Change-Id: I45abb052073bd44c9cb47bc2abcf4b558fe3dbbd Reviewed-by: Pierre Rossi <pierre.rossi@gmail.com>
Diffstat (limited to 'src/webenginewidgets')
-rw-r--r--src/webenginewidgets/api/qwebenginehistory.cpp6
-rw-r--r--src/webenginewidgets/api/qwebenginepage.cpp9
-rw-r--r--src/webenginewidgets/api/qwebenginepage_p.h1
3 files changed, 12 insertions, 4 deletions
diff --git a/src/webenginewidgets/api/qwebenginehistory.cpp b/src/webenginewidgets/api/qwebenginehistory.cpp
index d9e9b9c9f..7079bdfc7 100644
--- a/src/webenginewidgets/api/qwebenginehistory.cpp
+++ b/src/webenginewidgets/api/qwebenginehistory.cpp
@@ -281,15 +281,13 @@ void QWebEngineHistory::setMaximumItemCount(int count)
QDataStream& operator<<(QDataStream& stream, const QWebEngineHistory& history)
{
- Q_UNUSED(history);
- qWarning("Not implemented: %s", __func__);
+ history.d_func()->page->webContents()->serializeNavigationHistory(stream);
return stream;
}
QDataStream& operator>>(QDataStream& stream, QWebEngineHistory& history)
{
- Q_UNUSED(history);
- qWarning("Not implemented: %s", __func__);
+ history.d_func()->page->recreateFromSerializedHistory(stream);
return stream;
}
diff --git a/src/webenginewidgets/api/qwebenginepage.cpp b/src/webenginewidgets/api/qwebenginepage.cpp
index b6c84de6c..e9ad17cf0 100644
--- a/src/webenginewidgets/api/qwebenginepage.cpp
+++ b/src/webenginewidgets/api/qwebenginepage.cpp
@@ -354,6 +354,15 @@ void QWebEnginePagePrivate::_q_webActionTriggered(bool checked)
}
#endif // QT_NO_ACTION
+void QWebEnginePagePrivate::recreateFromSerializedHistory(QDataStream &input)
+{
+ QExplicitlySharedDataPointer<WebContentsAdapter> newWebContents = WebContentsAdapter::createFromSerializedNavigationHistory(input, this, WebContentsAdapterClient::SoftwareRenderingMode);
+ if (newWebContents) {
+ adapter = newWebContents.data();
+ adapter->initialize(this);
+ }
+}
+
QWebEnginePage::QWebEnginePage(QObject* parent)
: QObject(*new QWebEnginePagePrivate, parent)
{
diff --git a/src/webenginewidgets/api/qwebenginepage_p.h b/src/webenginewidgets/api/qwebenginepage_p.h
index a69866cbd..927519008 100644
--- a/src/webenginewidgets/api/qwebenginepage_p.h
+++ b/src/webenginewidgets/api/qwebenginepage_p.h
@@ -142,6 +142,7 @@ public:
void _q_webActionTriggered(bool checked);
WebContentsAdapter *webContents() { return adapter.data(); }
+ void recreateFromSerializedHistory(QDataStream &input);
QExplicitlySharedDataPointer<WebContentsAdapter> adapter;
QWebEngineHistory *history;