2011-08-12 09:33:45 +00:00
|
|
|
#!/usr/bin/env bash
|
2012-12-29 22:34:53 +00:00
|
|
|
#
|
|
|
|
# Summary: Display help for a command
|
|
|
|
#
|
|
|
|
# Usage: rbenv help [--usage] COMMAND
|
|
|
|
#
|
|
|
|
# Parses and displays help contents from a command's source file.
|
|
|
|
#
|
2012-12-30 03:50:38 +00:00
|
|
|
# A command is considered documented if it starts with a comment block
|
2012-12-30 04:05:04 +00:00
|
|
|
# that has a `Summary:' or `Usage:' section. Usage instructions can
|
|
|
|
# span multiple lines as long as subsequent lines are indented.
|
|
|
|
# The remainder of the comment block is displayed as extended
|
|
|
|
# documentation.
|
2012-12-29 22:34:53 +00:00
|
|
|
|
2011-08-12 09:33:45 +00:00
|
|
|
set -e
|
2011-09-12 15:11:59 +00:00
|
|
|
[ -n "$RBENV_DEBUG" ] && set -x
|
2011-08-10 13:53:24 +00:00
|
|
|
|
2015-11-13 20:06:29 +00:00
|
|
|
# Provide rbenv completions
|
|
|
|
if [ "$1" = "--complete" ]; then
|
|
|
|
echo --usage
|
2015-11-20 14:15:06 +00:00
|
|
|
exec rbenv-commands
|
2015-11-13 20:06:29 +00:00
|
|
|
fi
|
|
|
|
|
2012-12-29 18:06:20 +00:00
|
|
|
command_path() {
|
|
|
|
local command="$1"
|
|
|
|
command -v rbenv-"$command" || command -v rbenv-sh-"$command" || true
|
2012-12-13 04:48:28 +00:00
|
|
|
}
|
|
|
|
|
2012-12-29 18:06:20 +00:00
|
|
|
extract_initial_comment_block() {
|
|
|
|
sed -ne "
|
|
|
|
/^#/ !{
|
|
|
|
q
|
|
|
|
}
|
|
|
|
|
|
|
|
s/^#$/# /
|
|
|
|
|
|
|
|
/^# / {
|
|
|
|
s/^# //
|
|
|
|
p
|
|
|
|
}
|
|
|
|
"
|
2012-12-13 04:48:28 +00:00
|
|
|
}
|
|
|
|
|
2012-12-29 18:06:20 +00:00
|
|
|
collect_documentation() {
|
2019-10-23 10:12:38 +00:00
|
|
|
local awk
|
2021-05-05 20:42:56 +00:00
|
|
|
awk="$(type -p gawk awk 2>/dev/null | head -n1)"
|
2019-10-23 10:12:38 +00:00
|
|
|
if [ -z "$awk" ]; then
|
|
|
|
echo "rbenv: cannot find awk" >&2
|
|
|
|
return 1
|
|
|
|
fi
|
2019-10-23 06:19:16 +00:00
|
|
|
|
2017-06-23 22:12:09 +00:00
|
|
|
# shellcheck disable=SC2016
|
2019-10-23 10:12:38 +00:00
|
|
|
"$awk" '
|
2012-12-29 18:06:20 +00:00
|
|
|
/^Summary:/ {
|
|
|
|
summary = substr($0, 10)
|
|
|
|
next
|
|
|
|
}
|
|
|
|
|
|
|
|
/^Usage:/ {
|
|
|
|
reading_usage = 1
|
|
|
|
usage = usage "\n" $0
|
|
|
|
next
|
|
|
|
}
|
|
|
|
|
|
|
|
/^( *$| )/ && reading_usage {
|
|
|
|
usage = usage "\n" $0
|
|
|
|
next
|
|
|
|
}
|
|
|
|
|
2012-12-29 21:48:28 +00:00
|
|
|
{
|
2012-12-29 18:06:20 +00:00
|
|
|
reading_usage = 0
|
|
|
|
help = help "\n" $0
|
|
|
|
}
|
|
|
|
|
|
|
|
function escape(str) {
|
|
|
|
gsub(/[`\\$"]/, "\\\\&", str)
|
|
|
|
return str
|
|
|
|
}
|
|
|
|
|
|
|
|
function trim(str) {
|
2013-01-05 16:52:57 +00:00
|
|
|
sub(/^\n*/, "", str)
|
|
|
|
sub(/\n*$/, "", str)
|
2012-12-29 18:06:20 +00:00
|
|
|
return str
|
|
|
|
}
|
|
|
|
|
|
|
|
END {
|
|
|
|
if (usage || summary) {
|
|
|
|
print "summary=\"" escape(summary) "\""
|
|
|
|
print "usage=\"" escape(trim(usage)) "\""
|
|
|
|
print "help=\"" escape(trim(help)) "\""
|
|
|
|
}
|
|
|
|
}
|
|
|
|
'
|
|
|
|
}
|
|
|
|
|
|
|
|
documentation_for() {
|
2017-06-23 22:12:09 +00:00
|
|
|
local filename
|
|
|
|
filename="$(command_path "$1")"
|
2012-12-29 18:06:20 +00:00
|
|
|
if [ -n "$filename" ]; then
|
|
|
|
extract_initial_comment_block < "$filename" | collect_documentation
|
2012-12-13 04:48:28 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2012-12-29 18:06:20 +00:00
|
|
|
print_summary() {
|
|
|
|
local command="$1"
|
|
|
|
local summary usage help
|
|
|
|
eval "$(documentation_for "$command")"
|
2012-12-13 04:48:28 +00:00
|
|
|
|
2012-12-29 18:06:20 +00:00
|
|
|
if [ -n "$summary" ]; then
|
|
|
|
printf " %-9s %s\n" "$command" "$summary"
|
2012-12-13 04:48:28 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
print_summaries() {
|
2012-12-29 18:06:20 +00:00
|
|
|
for command; do
|
|
|
|
print_summary "$command"
|
2012-12-13 04:48:28 +00:00
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2012-12-29 18:06:20 +00:00
|
|
|
print_help() {
|
|
|
|
local command="$1"
|
|
|
|
local summary usage help
|
|
|
|
eval "$(documentation_for "$command")"
|
|
|
|
[ -n "$help" ] || help="$summary"
|
2011-08-10 14:23:43 +00:00
|
|
|
|
2017-06-23 22:12:09 +00:00
|
|
|
if [ -n "$usage" ] || [ -n "$summary" ]; then
|
2012-12-29 21:03:04 +00:00
|
|
|
if [ -n "$usage" ]; then
|
|
|
|
echo "$usage"
|
|
|
|
else
|
|
|
|
echo "Usage: rbenv ${command}"
|
|
|
|
fi
|
2012-12-29 18:06:20 +00:00
|
|
|
if [ -n "$help" ]; then
|
|
|
|
echo
|
|
|
|
echo "$help"
|
|
|
|
echo
|
|
|
|
fi
|
2011-08-10 14:23:43 +00:00
|
|
|
else
|
2012-12-29 18:06:20 +00:00
|
|
|
echo "Sorry, this command isn't documented yet." >&2
|
|
|
|
return 1
|
2011-08-10 14:23:43 +00:00
|
|
|
fi
|
2011-08-10 13:53:24 +00:00
|
|
|
}
|
|
|
|
|
2012-12-29 18:12:47 +00:00
|
|
|
print_usage() {
|
|
|
|
local command="$1"
|
|
|
|
local summary usage help
|
|
|
|
eval "$(documentation_for "$command")"
|
|
|
|
[ -z "$usage" ] || echo "$usage"
|
|
|
|
}
|
|
|
|
|
|
|
|
unset usage
|
|
|
|
if [ "$1" = "--usage" ]; then
|
|
|
|
usage="1"
|
|
|
|
shift
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "$1" ] || [ "$1" == "rbenv" ]; then
|
2022-09-27 00:17:50 +00:00
|
|
|
if [ -z "$usage" ] && [ -t 1 ] && type -p man >/dev/null; then
|
|
|
|
MANPATH="${BASH_SOURCE%/*}/../share/man:$MANPATH" exec man rbenv
|
|
|
|
fi
|
2012-12-29 18:06:20 +00:00
|
|
|
echo "Usage: rbenv <command> [<args>]"
|
2022-09-27 00:17:50 +00:00
|
|
|
[ -n "$usage" ] && exit
|
2012-12-29 18:06:20 +00:00
|
|
|
echo
|
|
|
|
echo "Some useful rbenv commands are:"
|
2013-01-03 16:39:48 +00:00
|
|
|
print_summaries commands local global shell install uninstall rehash version versions which whence
|
2012-12-29 18:06:20 +00:00
|
|
|
echo
|
|
|
|
echo "See \`rbenv help <command>' for information on a specific command."
|
2015-12-07 19:03:07 +00:00
|
|
|
echo "For full documentation, see: https://github.com/rbenv/rbenv#readme"
|
2012-12-29 18:06:20 +00:00
|
|
|
else
|
|
|
|
command="$1"
|
|
|
|
if [ -n "$(command_path "$command")" ]; then
|
2012-12-29 18:12:47 +00:00
|
|
|
if [ -n "$usage" ]; then
|
|
|
|
print_usage "$command"
|
|
|
|
else
|
|
|
|
print_help "$command"
|
|
|
|
fi
|
2011-09-28 15:59:02 +00:00
|
|
|
else
|
2012-12-29 18:06:20 +00:00
|
|
|
echo "rbenv: no such command \`$command'" >&2
|
2012-12-13 04:48:28 +00:00
|
|
|
exit 1
|
2011-09-28 15:59:02 +00:00
|
|
|
fi
|
2012-12-29 18:06:20 +00:00
|
|
|
fi
|