diff --git a/bin/autojump b/bin/autojump index 0509a0d..820fb3a 100755 --- a/bin/autojump +++ b/bin/autojump @@ -193,8 +193,8 @@ def find_matches(entries, needles, check_entries=True): lambda entry: not is_cwd(entry) and path_exists(entry), chain( match_consecutive(needles, data, ignore_case), - match_fuzzy(needles, data, ignore_case), - match_anywhere(needles, data, ignore_case))) + match_anywhere(needles, data, ignore_case), + match_fuzzy(needles, data, ignore_case))) def handle_tab_completion(needle, entries): diff --git a/bin/autojump_match.py b/bin/autojump_match.py index 75f9aca..0da31d4 100644 --- a/bin/autojump_match.py +++ b/bin/autojump_match.py @@ -20,23 +20,26 @@ else: def match_anywhere(needles, haystack, ignore_case=False): """ Matches needles anywhere in the path as long as they're in the same (but - not necessary consecutive) order. + not necessary consecutive) order, and the last needle is at the end. For example: needles = ['foo', 'baz'] - regex needle = r'.*foo.*baz.*' + regex needle = r'foo.*/.*baz[^/]*$' haystack = [ (path='/foo/bar/baz', weight=10), (path='/baz/foo/bar', weight=10), + (path='/foo/baz/bar', weight=11), (path='/foo/baz', weight=10), ] result = [ - (path='/moo/foo/baz', weight=10), + (path='/foo/bar/baz', weight=10), (path='/foo/baz', weight=10), ] """ - regex_needle = '.*' + '.*'.join(imap(re.escape, needles)) + '.*' + regex_some_seps = '.*' + os.sep + '.*' + regex_no_sep_end = '[^' + os.sep + ']*$' + regex_needle = regex_some_seps.join(imap(re.escape, needles)) + regex_no_sep_end regex_flags = re.IGNORECASE | re.UNICODE if ignore_case else re.UNICODE found = lambda haystack: re.search( regex_needle,