mirror of
https://github.com/nvbn/thefuck.git
synced 2025-01-19 04:21:14 +00:00
Don't suggest man 2/3 foo
if no man pages exist
Suggest `foo --help` instead. However, if there are man pages, suggest `foo --help` after `man 2/3 foo` This addresses the comment in the previous commit message: > However, in cases where multiple sections have man pages for `foo`, > running `man foo` could bring up the "wrong" section of man pages. > `man read` is an example of this, but that should probably be handled in > a way that still suggests `foo --help` first when there are *no* man > pages for `foo` in any section.
This commit is contained in:
parent
8bd6c5da67
commit
0c84eefa55
@ -23,7 +23,8 @@ def test_not_match(command):
|
|||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('command, new_command', [
|
@pytest.mark.parametrize('command, new_command', [
|
||||||
(Command('man read'), ['read --help', 'man 3 read', 'man 2 read']),
|
(Command('man read'), ['man 3 read', 'man 2 read', 'read --help']),
|
||||||
|
(Command('man missing', stderr="No manual entry for missing\n"), ['missing --help']),
|
||||||
(Command('man 2 read'), 'man 3 read'),
|
(Command('man 2 read'), 'man 3 read'),
|
||||||
(Command('man 3 read'), 'man 2 read'),
|
(Command('man 3 read'), 'man 2 read'),
|
||||||
(Command('man -s2 read'), 'man -s3 read'),
|
(Command('man -s2 read'), 'man -s3 read'),
|
||||||
|
@ -12,16 +12,22 @@ def get_new_command(command):
|
|||||||
if '2' in command.script:
|
if '2' in command.script:
|
||||||
return command.script.replace("2", "3")
|
return command.script.replace("2", "3")
|
||||||
|
|
||||||
|
last_arg = command.script_parts[-1]
|
||||||
|
help_command = last_arg + ' --help'
|
||||||
|
|
||||||
|
# If there are no man pages for last_arg, suggest `last_arg --help` instead.
|
||||||
|
# Otherwise, suggest `--help` after suggesting other man page sections.
|
||||||
|
if command.stderr.strip() == 'No manual entry for ' + last_arg:
|
||||||
|
return [help_command]
|
||||||
|
|
||||||
split_cmd2 = command.script_parts
|
split_cmd2 = command.script_parts
|
||||||
split_cmd3 = split_cmd2[:]
|
split_cmd3 = split_cmd2[:]
|
||||||
|
|
||||||
split_cmd2.insert(1, ' 2 ')
|
split_cmd2.insert(1, ' 2 ')
|
||||||
split_cmd3.insert(1, ' 3 ')
|
split_cmd3.insert(1, ' 3 ')
|
||||||
|
|
||||||
last_arg = command.script_parts[-1]
|
|
||||||
|
|
||||||
return [
|
return [
|
||||||
last_arg + ' --help',
|
|
||||||
"".join(split_cmd3),
|
"".join(split_cmd3),
|
||||||
"".join(split_cmd2),
|
"".join(split_cmd2),
|
||||||
|
help_command,
|
||||||
]
|
]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user