2020-02-01 05:55:08 +08:00
|
|
|
|
2010-09-18 10:18:26 +08:00
|
|
|
function __fish_complete_man
|
2016-11-28 13:27:22 +08:00
|
|
|
# Try to guess what section to search in. If we don't know, we
|
2017-03-19 12:55:02 +08:00
|
|
|
# use [^)]*, which should match any section.
|
|
|
|
set -l section ""
|
|
|
|
set -l token (commandline -ct)
|
|
|
|
set -l prev (commandline -poc)
|
2016-11-28 13:27:22 +08:00
|
|
|
set -e prev[1]
|
|
|
|
while set -q prev[1]
|
|
|
|
switch $prev[1]
|
|
|
|
case '-**'
|
2010-09-18 10:18:26 +08:00
|
|
|
|
2016-11-28 13:27:22 +08:00
|
|
|
case '*'
|
2019-01-22 08:12:57 +08:00
|
|
|
set section (string escape --style=regex $prev[1])
|
|
|
|
set section (string replace --all / \\/ $section)
|
2016-11-28 13:27:22 +08:00
|
|
|
end
|
|
|
|
set -e prev[1]
|
|
|
|
end
|
2016-05-29 20:31:12 +08:00
|
|
|
|
2018-03-03 21:26:20 +08:00
|
|
|
set -l exclude_fish_commands
|
|
|
|
# Only include fish commands when section is empty or 1
|
2020-03-10 02:36:12 +08:00
|
|
|
if test -z "$section" -o "$section" = 1
|
2019-05-05 18:09:25 +08:00
|
|
|
set -e exclude_fish_commands
|
2018-03-03 21:26:20 +08:00
|
|
|
end
|
|
|
|
|
2016-05-29 20:31:12 +08:00
|
|
|
set section $section"[^)]*"
|
|
|
|
# If we don't have a token but a section, list all pages for that section.
|
|
|
|
# Don't do it for all sections because that would be overwhelming.
|
|
|
|
if test -z "$token" -a "$section" != "[^)]*"
|
|
|
|
set token "."
|
|
|
|
end
|
2006-02-15 10:22:28 +08:00
|
|
|
|
2016-11-28 13:27:22 +08:00
|
|
|
if test -n "$token"
|
|
|
|
# Do the actual search
|
2022-10-29 00:39:43 +08:00
|
|
|
__fish_apropos ^$token 2>/dev/null | awk '
|
2017-01-27 12:00:43 +08:00
|
|
|
BEGIN { FS="[\t ]- "; OFS="\t"; }
|
|
|
|
# BSD/Darwin
|
2021-09-19 23:18:57 +08:00
|
|
|
/^[^( \t]+(, [^( \t]+)*\('$section'\)/ {
|
|
|
|
paren = index($1, "(");
|
|
|
|
sect = substr($1, paren + 1, length($1) - paren - 1);
|
|
|
|
aliases = substr($1, 1, paren - 1)
|
|
|
|
split(aliases, pages, ", ");
|
2017-01-27 12:00:43 +08:00
|
|
|
for (i in pages) {
|
2021-09-19 23:18:57 +08:00
|
|
|
print pages[i], sect ": " $2
|
2017-01-27 12:00:43 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
# man-db
|
|
|
|
/^[^( \t]+ +\('$section'\)/ {
|
|
|
|
split($1, t, " ");
|
|
|
|
sect = substr(t[2], 2, length(t[2]) - 2);
|
|
|
|
print t[1], sect ": " $2;
|
|
|
|
}
|
|
|
|
# man-db RHEL 5 with [aliases]
|
|
|
|
/^[^( \t]+ +\[.*\] +\('$section'\)/ {
|
|
|
|
split($1, t, " ");
|
|
|
|
sect = substr(t[3], 2, length(t[3]) - 2);
|
|
|
|
print t[1], sect ": " $2;
|
2022-10-29 00:39:43 +08:00
|
|
|
}
|
2017-01-27 12:00:43 +08:00
|
|
|
# Solaris 11
|
|
|
|
# Does not display descriptions
|
|
|
|
# Solaris apropos outputs embedded backspace in descriptions
|
|
|
|
/^[0-9]+\. [^( \t]*\('$section'\) / {
|
|
|
|
split($1, t, " ")
|
|
|
|
paren = index(t[2], "(");
|
|
|
|
name = substr(t[2], 1, paren - 1);
|
|
|
|
sect = substr(t[2], paren + 1, length(t[2]) - paren - 1);
|
|
|
|
print name, sect
|
|
|
|
}
|
|
|
|
'
|
|
|
|
|
2017-01-25 22:34:59 +08:00
|
|
|
# Fish commands are not given by apropos
|
2018-03-03 21:26:20 +08:00
|
|
|
if not set -ql exclude_fish_commands
|
2019-05-05 18:09:25 +08:00
|
|
|
set -l files $__fish_data_dir/man/man1/*.1
|
|
|
|
string replace -r '.*/([^/]+)\.1$' '$1\t1: fish command' -- $files
|
2018-03-03 21:26:20 +08:00
|
|
|
end
|
2016-05-29 20:31:12 +08:00
|
|
|
else
|
|
|
|
return 1
|
2016-11-28 13:27:22 +08:00
|
|
|
end
|
2016-05-29 20:31:12 +08:00
|
|
|
return 0
|
2006-02-15 10:22:28 +08:00
|
|
|
end
|