1
0
mirror of https://github.com/wting/autojump synced 2024-10-27 20:34:07 +00:00

try to avoid hammering the filesystem

This significantly improves performance on a loaded machine
This commit is contained in:
Joël Schaerer 2011-09-15 17:06:15 +02:00
parent 92b80073fd
commit c2bd900989

View File

@ -180,28 +180,21 @@ def match(path, pattern, ignore_case=False, only_end=False):
eaten_path = path eaten_path = path
return (does_match, eaten_path) return (does_match, eaten_path)
def find_matches(dirs, patterns, result_list, ignore_case, max_matches): def find_matches(dirs, patterns, result_list, ignore_case, max_matches, current_dir):
"""Find max_matches paths that match the pattern, """Find max_matches paths that match the pattern,
and add them to the result_list""" and add them to the result_list"""
for path, count in dirs: for path, count in dirs:
# Don't jump to where we alread are # Don't jump to where we alread are
try: if current_dir == path :
if decode(os.path.realpath(os.curdir)) == path :
continue
#Sometimes the current path doesn't exist anymore.
#In that case, jump if possible.
except OSError:
pass
#If a path doesn't exist, don't jump there
#We still keep it in db in case it's from a removable drive
if not os.path.exists(path):
continue continue
does_match, eaten_path = True, path does_match, eaten_path = True, path
for n,p in enumerate(patterns): for n,p in enumerate(patterns):
#For the last pattern, only match the end of the pattern #For the last pattern, only match the end of the pattern
does_match, eaten_path = match(eaten_path, p, ignore_case, only_end=(n == len(patterns)-1)) does_match, eaten_path = match(eaten_path, p, ignore_case, only_end=(n == len(patterns)-1))
if not does_match: break if not does_match: break
if does_match: #If a path doesn't exist, don't jump there
#We still keep it in db in case it's from a removable drive
if does_match and os.path.exists(path):
uniqadd(result_list, path) uniqadd(result_list, path)
if len(result_list) >= max_matches : if len(result_list) >= max_matches :
break break
@ -275,12 +268,21 @@ def shell_utility():
max_matches = 9 max_matches = 9
else: else:
max_matches = 1 max_matches = 1
find_matches(dirs, patterns, results, False, max_matches)
# Don't jump to the current directory
try:
current_dir = decode(os.path.realpath(os.curdir))
#Sometimes the current path doesn't exist anymore.
#In that case, jump if possible.
except OSError:
current_dir = None
find_matches(dirs, patterns, results, False, max_matches, current_dir)
# If not found, try ignoring case. # If not found, try ignoring case.
# On completion always show all results # On completion always show all results
if completion or not results: if completion or not results:
find_matches(dirs, patterns, results, find_matches(dirs, patterns, results,
ignore_case=True, max_matches=max_matches) ignore_case=True,
max_matches=max_matches, current_dir=current_dir)
# Keep the database to a reasonable size # Keep the database to a reasonable size
if not completion and clean_dict(dirs, path_dict): if not completion and clean_dict(dirs, path_dict):
save(path_dict, dic_file) save(path_dict, dic_file)