Merge branch 'multi_url_heuristic' of https://github.com/hcraT/qutebrowser into hcraT-multi_url_heuristic

This commit is contained in:
Florian Bruhin 2016-03-17 21:28:40 +01:00
commit 99fadacda6
4 changed files with 77 additions and 23 deletions

View File

@ -818,10 +818,13 @@ class CommandDispatcher:
text = utils.get_clipboard(selection=sel) text = utils.get_clipboard(selection=sel)
if not text.strip(): if not text.strip():
raise cmdexc.CommandError("{} is empty.".format(target)) raise cmdexc.CommandError("{} is empty.".format(target))
log.misc.debug("{} contained: '{}'".format(target, log.misc.debug("{} contained: {!r}".format(target, text))
text.replace('\n', '\\n'))) text_urls = [u for u in text.split('\n') if u.strip()]
text_urls = enumerate(u for u in text.split('\n') if u.strip()) if (len(text_urls) > 1 and not urlutils.is_url(text_urls[0]) and
for i, text_url in text_urls: urlutils.get_path_if_valid(
text_urls[0], check_exists=True) is None):
text_urls = [text]
for i, text_url in enumerate(text_urls):
if not window and i > 0: if not window and i > 0:
tab = False tab = False
bg = True bg = True

View File

@ -80,7 +80,7 @@ def _parse_search_term(s):
engine = None engine = None
term = s term = s
log.url.debug("engine {}, term '{}'".format(engine, term)) log.url.debug("engine {}, term {!r}".format(engine, term))
return (engine, term) return (engine, term)
@ -93,7 +93,7 @@ def _get_search_url(txt):
Return: Return:
The search URL as a QUrl. The search URL as a QUrl.
""" """
log.url.debug("Finding search engine for '{}'".format(txt)) log.url.debug("Finding search engine for {!r}".format(txt))
engine, term = _parse_search_term(txt) engine, term = _parse_search_term(txt)
assert term assert term
if engine is None: if engine is None:
@ -171,22 +171,10 @@ def fuzzy_url(urlstr, cwd=None, relative=False, do_search=True):
A target QUrl to a search page or the original URL. A target QUrl to a search page or the original URL.
""" """
urlstr = urlstr.strip() urlstr = urlstr.strip()
expanded = os.path.expanduser(urlstr) path = get_path_if_valid(urlstr, cwd=cwd, relative=relative,
check_exists=True)
if os.path.isabs(expanded): if path is not None:
path = expanded
elif relative and cwd:
path = os.path.join(cwd, expanded)
elif relative:
try:
path = os.path.abspath(expanded)
except OSError:
path = None
else:
path = None
if path is not None and os.path.exists(path):
log.url.debug("URL is a local file")
url = QUrl.fromLocalFile(path) url = QUrl.fromLocalFile(path)
elif (not do_search) or is_url(urlstr): elif (not do_search) or is_url(urlstr):
# probably an address # probably an address
@ -198,7 +186,7 @@ def fuzzy_url(urlstr, cwd=None, relative=False, do_search=True):
url = _get_search_url(urlstr) url = _get_search_url(urlstr)
except ValueError: # invalid search engine except ValueError: # invalid search engine
url = qurl_from_user_input(urlstr) url = qurl_from_user_input(urlstr)
log.url.debug("Converting fuzzy term {} to URL -> {}".format( log.url.debug("Converting fuzzy term {!r} to URL -> {}".format(
urlstr, url.toDisplayString())) urlstr, url.toDisplayString()))
if do_search and config.get('general', 'auto-search') and urlstr: if do_search and config.get('general', 'auto-search') and urlstr:
qtutils.ensure_valid(url) qtutils.ensure_valid(url)
@ -246,7 +234,7 @@ def is_url(urlstr):
""" """
autosearch = config.get('general', 'auto-search') autosearch = config.get('general', 'auto-search')
log.url.debug("Checking if '{}' is a URL (autosearch={}).".format( log.url.debug("Checking if {!r} is a URL (autosearch={}).".format(
urlstr, autosearch)) urlstr, autosearch))
urlstr = urlstr.strip() urlstr = urlstr.strip()
@ -349,6 +337,44 @@ def raise_cmdexc_if_invalid(url):
raise cmdexc.CommandError(get_errstring(url)) raise cmdexc.CommandError(get_errstring(url))
def get_path_if_valid(pathstr, cwd=None, relative=False, check_exists=False):
"""Check if path is a valid path.
Args:
pathstr: The path as string.
cwd: The current working directory, or None.
relative: Whether to resolve relative files.
check_exists: Whether to check if the file
actually exists of filesystem.
Return:
The path if it is a valid path, None otherwise.
"""
pathstr = pathstr.strip()
log.url.debug("Checking if {!r} is a path".format(pathstr))
expanded = os.path.expanduser(pathstr)
if os.path.isabs(expanded):
path = expanded
elif relative and cwd:
path = os.path.join(cwd, expanded)
elif relative:
try:
path = os.path.abspath(expanded)
except OSError:
path = None
else:
path = None
if check_exists:
if path is not None and os.path.exists(path):
log.url.debug("URL is a local file")
else:
path = None
return path
def filename_from_url(url): def filename_from_url(url):
"""Get a suitable filename from an URL. """Get a suitable filename from an URL.

View File

@ -126,6 +126,19 @@ Feature: Yanking and pasting.
- data/hello2.txt - data/hello2.txt
- data/hello3.txt - data/hello3.txt
Scenario: Pasting multiline text
Given I have a fresh instance
When I set searchengines -> DEFAULT to http://localhost:(port)/data/hello.txt?q={}
And I put the following lines into the clipboard:
this url:
http://qutebrowser.org
should not open
And I run :paste -t
And I wait until data/hello.txt?q=this%20url%3A%0Ahttp%3A//qutebrowser.org%0Ashould%20not%20open is loaded
Then the following tabs should be open:
- about:blank
- data/hello.txt?q=this%20url%3A%0Ahttp%3A//qutebrowser.org%0Ashould%20not%20open (active)
Scenario: Pasting multiple urls in a background tab Scenario: Pasting multiple urls in a background tab
Given I open about:blank Given I open about:blank
When I run :tab-only When I run :tab-only

View File

@ -238,6 +238,18 @@ class TestFuzzyUrl:
with pytest.raises(urlutils.InvalidUrlError): with pytest.raises(urlutils.InvalidUrlError):
urlutils.fuzzy_url(url, do_search=True) urlutils.fuzzy_url(url, do_search=True)
@pytest.mark.parametrize('path, check_exists', [
('/foo', False),
('/bar', True),
])
def test_get_path_existing(self, path, check_exists, os_mock):
"""Test with an absolute path."""
os_mock.path.exists.return_value = False
expected = None if check_exists else path
url = urlutils.get_path_if_valid(path, check_exists=check_exists)
assert url == expected
@pytest.mark.parametrize('url, special', [ @pytest.mark.parametrize('url, special', [
('file:///tmp/foo', True), ('file:///tmp/foo', True),