我有一个通用库,用于在多个脚本中解析命令行选项,但是我也希望我的个人脚本也能够处理参数...例如common.sh:func...
我有一个通用库,用于从多个脚本解析命令行选项,但我还希望我的各个脚本也能够处理参数...例如
通用.sh:
function get_options {
echo -e "in getoptions"
echo $OPTIND
while getopts ":ab:" optionName; do
[ ... processing code ... ]
done
}
灰
. ./common.sh
function get_local_options {
echo -e "in getoptions"
echo $OPTIND
while getopts ":xy:" optionName; do
[ ... processing code ... ]
done
}
get_local_options $*
OPTIND=1
get_options $*
问题是,如果我用以下命令调用 a.sh:
a.sh -x -y foo -a -b bar
get_options 在 \'foo\' 处停止处理,因为它在第一个 \'非选项\' 处停止
有什么办法可以解决这个问题而不用自己重写吗?
只需让您的通用脚本提供用于处理这些选项和函数的列表,然后让其他脚本将它们可以处理的任何选项添加到选项列表中:
通用脚本
OPTS="ab:hv"
common_usage() {
echo "Common options:"
echo " -a ..."
echo " -b arg ..."
echo " -h Show usage"
echo " -v Be verbose"
}
handle_common_opts() {
case "$1" in
a) handle_opt_a ;;
b) handle_opt_b "$2" ;;
h) usage; exit 0 ;;
v) be_verbose ;;
esac
}
灰
. common.sh
OPTS="${OPTS}xy:"
usage() {
echo "Usage: $PROG [options] [arguments...]"
echo
common_usage
echo
echo "Specific options:"
echo " -x ..."
echo " -y arg ..."
}
while getopts "$OPTS" OPT; do
handle_common_opts "$OPT" "$OPTARG"
case "$OPT" in
x) handle_opt_x ;;
y) handle_opt_y "$OPTARG" ;;
\?) usage; exit 1 ;;
esac
done
shift $((OPTIND-1))
handle_remaining_args "$@"
这样做有以下优点:不需要对 的内部管理进行任何改动 getopts
,用户可以以任何顺序指定常用和特定的选项,它可以在一个地方处理无法识别的选项,并且使使用功能更易于维护。