Adblock import handles local directories and paths

Fixes #464
* Handles local Directories
* Handles local paths without file://
This commit is contained in:
zaowen 2018-09-04 20:53:26 -05:00 committed by zaowen
parent 6293bc5178
commit bdc41db601

View File

@ -174,15 +174,14 @@ class HostBlocker:
for url in config.val.content.host_blocking.lists: for url in config.val.content.host_blocking.lists:
if url.scheme() == 'file': if url.scheme() == 'file':
filename = url.toLocalFile() filename = url.toLocalFile()
try: if os.path.isdir(filename):
fileobj = open(filename, 'rb') for filenames in os.scandir(filename):
except OSError as e: if not filenames.name.startswith('.')\
message.error("adblock: Error while reading {}: {}".format( and filenames.is_file():
filename, e.strerror)) print( filenames.name )
continue self._import_local(filenames.path)
download = FakeDownload(fileobj) else:
self._in_progress.append(download) self._import_local(filename)
self.on_download_finished(download)
else: else:
fobj = io.BytesIO() fobj = io.BytesIO()
fobj.name = 'adblock: ' + url.host() fobj.name = 'adblock: ' + url.host()
@ -193,6 +192,22 @@ class HostBlocker:
download.finished.connect( download.finished.connect(
functools.partial(self.on_download_finished, download)) functools.partial(self.on_download_finished, download))
def _import_local(self, filename):
"""Adds the contents of a file to the blocklist.
Args:
filename: path to a local file to import.
"""
try:
fileobj = open(filename, 'rb')
except OSError as e:
message.error("adblock: Error while reading {}: {}".format(
filename, e.strerror))
return
download = FakeDownload(fileobj)
self._in_progress.append(download)
self.on_download_finished(download)
def _parse_line(self, line): def _parse_line(self, line):
"""Parse a line from a host file. """Parse a line from a host file.