Store both x and y position for marks.

Previously only stored/used y.
This commit is contained in:
Ryan Roden-Corrent 2016-04-14 17:30:43 -04:00
parent f4b9573744
commit be6308534f
3 changed files with 24 additions and 29 deletions

View File

@ -651,15 +651,14 @@ class TabbedBrowser(tabwidget.TabWidget):
""" """
# strip the fragment as it may interfere with scrolling # strip the fragment as it may interfere with scrolling
url = self.current_url().adjusted(QUrl.RemoveFragment) url = self.current_url().adjusted(QUrl.RemoveFragment)
frame = self.currentWidget().page().currentFrame() point = self.currentWidget().page().currentFrame().scrollPosition()
y = frame.scrollPosition().y()
if key.isupper(): if key.isupper():
self._global_marks[key] = y, url self._global_marks[key] = point, url
else: else:
if url not in self._local_marks: if url not in self._local_marks:
self._local_marks[url] = {} self._local_marks[url] = {}
self._local_marks[url][key] = y self._local_marks[url][key] = point
def jump_mark(self, key): def jump_mark(self, key):
"""Jump to the mark named by `key`. """Jump to the mark named by `key`.
@ -672,23 +671,23 @@ class TabbedBrowser(tabwidget.TabWidget):
frame = self.currentWidget().page().currentFrame() frame = self.currentWidget().page().currentFrame()
if key.isupper() and key in self._global_marks: if key.isupper() and key in self._global_marks:
y, url = self._global_marks[key] point, url = self._global_marks[key]
def callback(ok): def callback(ok):
if ok: if ok:
self.cur_load_finished.disconnect(callback) self.cur_load_finished.disconnect(callback)
frame.setScrollPosition(QPoint(0, y)) frame.setScrollPosition(point)
self.openurl(url, newtab=False) self.openurl(url, newtab=False)
self.cur_load_finished.connect(callback) self.cur_load_finished.connect(callback)
elif urlkey in self._local_marks and key in self._local_marks[urlkey]: elif urlkey in self._local_marks and key in self._local_marks[urlkey]:
y = self._local_marks[urlkey][key] point = self._local_marks[urlkey][key]
# save the pre-jump position in the special ' mark # save the pre-jump position in the special ' mark
# this has to happen after we read the mark, otherwise jump_mark # this has to happen after we read the mark, otherwise jump_mark
# "'" would just jump to the current position every time # "'" would just jump to the current position every time
self.set_mark("'") self.set_mark("'")
frame.setScrollPosition(QPoint(0, y)) frame.setScrollPosition(point)
else: else:
message.error(self._win_id, "Mark {} is not set".format(key)) message.error(self._win_id, "Mark {} is not set".format(key))

View File

@ -7,43 +7,43 @@ Feature: Setting positional marks
## :set-mark, :jump-mark ## :set-mark, :jump-mark
Scenario: Setting and jumping to a local mark Scenario: Setting and jumping to a local mark
When I run :scroll-px 0 10 When I run :scroll-px 5 10
And I run :set-mark 'a' And I run :set-mark 'a'
And I run :scroll-px 0 20 And I run :scroll-px 0 20
And I run :jump-mark 'a' And I run :jump-mark 'a'
Then the page should be scrolled to 10 Then the page should be scrolled to 5 10
Scenario: Jumping back jumping to a particular percentage Scenario: Jumping back jumping to a particular percentage
When I run :scroll-px 0 20 When I run :scroll-px 10 20
And I run :scroll-perc 100 And I run :scroll-perc 100
And I run :jump-mark "'" And I run :jump-mark "'"
Then the page should be scrolled to 20 Then the page should be scrolled to 10 20
Scenario: Setting the same local mark on another page Scenario: Setting the same local mark on another page
When I run :scroll-px 0 10 When I run :scroll-px 5 10
And I run :set-mark 'a' And I run :set-mark 'a'
And I open data/marks.html And I open data/marks.html
And I run :scroll-px 0 20 And I run :scroll-px 0 20
And I run :set-mark 'a' And I run :set-mark 'a'
And I run :jump-mark 'a' And I run :jump-mark 'a'
Then the page should be scrolled to 20 Then the page should be scrolled to 0 20
Scenario: Jumping to a local mark after returning to a page Scenario: Jumping to a local mark after returning to a page
When I run :scroll-px 0 10 When I run :scroll-px 5 10
And I run :set-mark 'a' And I run :set-mark 'a'
And I open data/numbers/1.txt And I open data/numbers/1.txt
And I run :set-mark 'a' And I run :set-mark 'a'
And I open data/marks.html And I open data/marks.html
And I run :jump-mark 'a' And I run :jump-mark 'a'
Then the page should be scrolled to 10 Then the page should be scrolled to 5 10
Scenario: Setting and jumping to a global mark Scenario: Setting and jumping to a global mark
When I run :scroll-px 0 20 When I run :scroll-px 5 20
And I run :set-mark 'A' And I run :set-mark 'A'
And I open data/numbers/1.txt And I open data/numbers/1.txt
And I run :jump-mark 'A' And I run :jump-mark 'A'
Then data/marks.html should be loaded Then data/marks.html should be loaded
And the page should be scrolled to 20 And the page should be scrolled to 5 20
Scenario: Jumping to an unset mark Scenario: Jumping to an unset mark
When I run :jump-mark 'b' When I run :jump-mark 'b'
@ -58,14 +58,14 @@ Feature: Setting positional marks
Scenario: Jumping to a local mark after changing fragments Scenario: Jumping to a local mark after changing fragments
When I open data/marks.html#top When I open data/marks.html#top
And I run :scroll 'top' And I run :scroll 'top'
And I run :scroll-px 0 10 And I run :scroll-px 10 10
And I run :set-mark 'a' And I run :set-mark 'a'
When I open data/marks.html#bottom When I open data/marks.html#bottom
And I run :jump-mark 'a' And I run :jump-mark 'a'
Then the page should be scrolled to 10 Then the page should be scrolled to 10 10
Scenario: Jumping back after following a link Scenario: Jumping back after following a link
When I run :hint links normal When I run :hint links normal
And I run :follow-hint s And I run :follow-hint s
And I run :jump-mark "'" And I run :jump-mark "'"
Then the page should be scrolled to 0 Then the page should be scrolled to 0 0

View File

@ -21,13 +21,9 @@ import pytest_bdd as bdd
bdd.scenarios('marks.feature') bdd.scenarios('marks.feature')
def _get_scroll_y(quteproc): @bdd.then(bdd.parsers.parse("the page should be scrolled to {x} {y}"))
def check_y(quteproc, x, y):
data = quteproc.get_session() data = quteproc.get_session()
pos = data['windows'][0]['tabs'][0]['history'][-1]['scroll-pos'] pos = data['windows'][0]['tabs'][0]['history'][-1]['scroll-pos']
return pos['y'] assert int(x) == pos['x']
assert int(y) == pos['y']
@bdd.then(bdd.parsers.parse("the page should be scrolled to "
"{y}"))
def check_y(quteproc, y):
assert int(y) == _get_scroll_y(quteproc)