2020-10-01 13:04:11 +00:00
|
|
|
if not type -q apropos
|
|
|
|
function __fish_apropos
|
|
|
|
end
|
|
|
|
exit
|
|
|
|
end
|
|
|
|
|
2021-04-01 23:48:32 +00:00
|
|
|
# Check for macOS Catalina or above. This is Darwin 19.x or above. See unames reported here:
|
|
|
|
# https://en.wikipedia.org/wiki/Darwin_(operating_system)
|
|
|
|
set -l sysver (uname -sr | string match -r "(Darwin) (\d\d)"\.)
|
|
|
|
|
2021-04-02 14:58:34 +00:00
|
|
|
if test $status -eq 0 -a (count $sysver) -eq 3
|
2021-08-01 16:40:56 +00:00
|
|
|
and test $sysver[2] = Darwin -a $sysver[3] -ge 19
|
2021-08-04 16:55:01 +00:00
|
|
|
and test -x /usr/libexec/makewhatis
|
2021-04-01 23:48:32 +00:00
|
|
|
|
2021-04-30 18:09:56 +00:00
|
|
|
set -l dir
|
2021-04-01 23:48:32 +00:00
|
|
|
if test -n "$XDG_CACHE_HOME"
|
|
|
|
set dir $XDG_CACHE_HOME/fish
|
|
|
|
else
|
|
|
|
set dir (getconf DARWIN_USER_CACHE_DIR)"fish"
|
|
|
|
end
|
2020-10-01 13:04:11 +00:00
|
|
|
|
2021-04-01 23:48:32 +00:00
|
|
|
function __fish_apropos -V dir
|
|
|
|
# macOS 10.15 "Catalina" has a read only filesystem where the whatis database should be.
|
|
|
|
# The whatis database is non-existent, so apropos tries (and fails) to create it every time,
|
|
|
|
# which can take seconds.
|
|
|
|
#
|
|
|
|
# Instead, we build a whatis database in the user cache directory
|
|
|
|
# and override the MANPATH using that directory before we run `apropos`
|
|
|
|
#
|
|
|
|
# the cache is rebuilt once a week.
|
2021-04-30 18:07:20 +00:00
|
|
|
set -l whatis $dir/whatis
|
2021-04-02 09:08:26 +00:00
|
|
|
set -l max_age 600000 # like a week
|
2020-10-01 13:04:11 +00:00
|
|
|
set -l age $max_age
|
|
|
|
|
2021-04-01 23:48:32 +00:00
|
|
|
if test -f "$whatis"
|
2020-10-09 16:58:35 +00:00
|
|
|
# Some people use GNU tools on macOS, and GNU stat works differently.
|
|
|
|
# However it's currently guaranteed that the macOS stat is in /usr/bin,
|
|
|
|
# so we use that explicitly.
|
2021-04-01 23:48:32 +00:00
|
|
|
set age (math (date +%s) - (/usr/bin/stat -f %m $whatis))
|
2020-10-01 13:04:11 +00:00
|
|
|
end
|
|
|
|
|
2021-04-30 17:16:57 +00:00
|
|
|
MANPATH="$dir" apropos "^$argv"
|
2020-10-04 00:08:13 +00:00
|
|
|
|
2020-10-01 13:04:11 +00:00
|
|
|
if test $age -ge $max_age
|
2021-04-01 23:48:32 +00:00
|
|
|
test -d "$dir" || mkdir -m 700 -p $dir
|
|
|
|
/usr/libexec/makewhatis -o "$whatis" (man --path | string split :) >/dev/null 2>&1 </dev/null &
|
2020-10-01 13:04:11 +00:00
|
|
|
end
|
|
|
|
end
|
2021-04-01 23:48:32 +00:00
|
|
|
else
|
|
|
|
function __fish_apropos
|
|
|
|
apropos $argv
|
|
|
|
end
|
2020-10-09 16:58:35 +00:00
|
|
|
end
|