Remove history.Entry.

No longer needed with sql backend. Query results build their own
namedtuple from the returned columns, and inserting new entries is just
done with named parameters.
This commit is contained in:
Ryan Roden-Corrent 2017-06-10 13:51:11 -04:00
parent 1fe1813431
commit f4f52ee204
2 changed files with 11 additions and 58 deletions

View File

@ -30,48 +30,6 @@ from qutebrowser.utils import (utils, objreg, log, qtutils, usertypes, message,
from qutebrowser.misc import objects, sql from qutebrowser.misc import objects, sql
class Entry:
"""A single entry in the web history.
Attributes:
atime: The time the page was accessed.
url: The URL which was accessed as QUrl.
redirect: If True, don't show this entry in completion
"""
def __init__(self, atime, url, title, redirect=False):
self.atime = float(atime)
self.url = url
self.title = title
self.redirect = redirect
qtutils.ensure_valid(url)
def __repr__(self):
return utils.get_repr(self, constructor=True, atime=self.atime,
url=self.url_str(), title=self.title,
redirect=self.redirect)
def __str__(self):
atime = str(int(self.atime))
if self.redirect:
atime += '-r' # redirect flag
elems = [atime, self.url_str()]
if self.title:
elems.append(self.title)
return ' '.join(elems)
def __eq__(self, other):
return (self.atime == other.atime and
self.title == other.title and
self.url == other.url and
self.redirect == other.redirect)
def url_str(self):
"""Get the URL as a lossless string."""
return self.url.toString(QUrl.FullyEncoded | QUrl.RemovePassword)
class CompletionHistory(sql.SqlTable): class CompletionHistory(sql.SqlTable):
"""History which only has the newest entry for each URL.""" """History which only has the newest entry for each URL."""
@ -113,15 +71,6 @@ class WebHistory(sql.SqlTable):
def __contains__(self, url): def __contains__(self, url):
return self._contains_query.run(val=url).value() return self._contains_query.run(val=url).value()
def _add_entry(self, entry):
"""Add an entry to the in-memory database."""
self.insert(url=entry.url_str(), title=entry.title,
atime=int(entry.atime), redirect=entry.redirect)
if not entry.redirect:
self.completion.insert_or_replace(url=entry.url_str(),
title=entry.title,
last_atime=int(entry.atime))
def get_recent(self): def get_recent(self):
"""Get the most recent history entries.""" """Get the most recent history entries."""
return self.select(sort_by='atime', sort_order='desc', limit=100) return self.select(sort_by='atime', sort_order='desc', limit=100)
@ -199,10 +148,13 @@ class WebHistory(sql.SqlTable):
log.misc.warning("Ignoring invalid URL being added to history") log.misc.warning("Ignoring invalid URL being added to history")
return return
if atime is None: atime = int(atime) if (atime is not None) else int(time.time())
atime = time.time() url_str = url.toString(QUrl.FullyEncoded | QUrl.RemovePassword)
entry = Entry(atime, url, title, redirect=redirect) self.insert(url=url_str, title=title, atime=atime, redirect=redirect)
self._add_entry(entry) if not redirect:
self.completion.insert_or_replace(url=url_str,
title=title,
last_atime=atime)
def _parse_entry(self, line): def _parse_entry(self, line):
"""Parse a history line like '12345 http://example.com title'.""" """Parse a history line like '12345 http://example.com title'."""

View File

@ -89,8 +89,9 @@ class TestHistoryHandler:
items = [] items = []
for i in range(entry_count): for i in range(entry_count):
entry_atime = now - i * interval entry_atime = now - i * interval
entry = history.Entry(atime=str(entry_atime), entry = {"atime": str(entry_atime),
url=QUrl("www.x.com/" + str(i)), title="Page " + str(i)) "url": QUrl("www.x.com/" + str(i)),
"title": "Page " + str(i)}
items.insert(0, entry) items.insert(0, entry)
return items return items
@ -107,7 +108,7 @@ class TestHistoryHandler:
def fake_history(self, fake_web_history, entries): def fake_history(self, fake_web_history, entries):
"""Create fake history.""" """Create fake history."""
for item in entries: for item in entries:
fake_web_history._add_entry(item) fake_web_history.add_url(**item)
@pytest.mark.parametrize("start_time_offset, expected_item_count", [ @pytest.mark.parametrize("start_time_offset, expected_item_count", [
(0, 4), (0, 4),