Switch browsing history away from QWebHistoryInterface.

Now adds a url to browser history once we have connected and got enough data
to start rendering the page. The previous approach saved urls as soon as
navigation was initiated, so upon encountering a redirect the final url wasn't
saved.

Using layout started rather than load finished means that pages whose contents
manage to load minus one troublesome asset will still be saved.
This commit is contained in:
Jimmy 2016-03-20 13:14:10 +13:00
parent 1524f29f71
commit 33fbe97863
2 changed files with 8 additions and 1 deletions

View File

@ -212,4 +212,3 @@ def init(parent=None):
""" """
history = WebHistory(parent) history = WebHistory(parent)
objreg.register('web-history', history) objreg.register('web-history', history)
QWebHistoryInterface.setDefaultInterface(history)

View File

@ -145,6 +145,12 @@ class WebView(QWebView):
self.loadProgress.connect(lambda p: setattr(self, 'progress', p)) self.loadProgress.connect(lambda p: setattr(self, 'progress', p))
objreg.get('config').changed.connect(self.on_config_changed) objreg.get('config').changed.connect(self.on_config_changed)
@pyqtSlot()
def on_initial_layout_complete(self):
"""Add url to history now that we have displayed something."""
objreg.get('web-history').addHistoryEntry(
self.url().toDisplayString(), self.title())
def _init_page(self): def _init_page(self):
"""Initialize the QWebPage used by this view.""" """Initialize the QWebPage used by this view."""
page = webpage.BrowserPage(self.win_id, self.tab_id, self) page = webpage.BrowserPage(self.win_id, self.tab_id, self)
@ -152,6 +158,8 @@ class WebView(QWebView):
page.linkHovered.connect(self.linkHovered) page.linkHovered.connect(self.linkHovered)
page.mainFrame().loadStarted.connect(self.on_load_started) page.mainFrame().loadStarted.connect(self.on_load_started)
page.mainFrame().loadFinished.connect(self.on_load_finished) page.mainFrame().loadFinished.connect(self.on_load_finished)
page.mainFrame().initialLayoutCompleted.connect(
self.on_initial_layout_complete)
page.statusBarMessage.connect( page.statusBarMessage.connect(
lambda msg: setattr(self, 'statusbar_message', msg)) lambda msg: setattr(self, 'statusbar_message', msg))
page.networkAccessManager().sslErrors.connect( page.networkAccessManager().sslErrors.connect(