mirror of
https://github.com/kvz/bash3boilerplate.git
synced 2025-01-22 11:57:59 +00:00
Merge pull request #72 from mstreuhofer/vade-retro-eval
removed all usage of eval, proper usage of unset Safer code, ✨ 💯 @mstreuhofer
This commit is contained in:
commit
2c91db3faa
45
main.sh
45
main.sh
@ -32,8 +32,8 @@ if [ "${BASH_SOURCE[0]}" != "${0}" ]; then
|
|||||||
__b3bp_tmp_source_idx=1
|
__b3bp_tmp_source_idx=1
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
[ ! -z "${__usage+x}" ] && unset __usage
|
[ ! -z "${__usage+x}" ] && unset -v __usage
|
||||||
[ ! -z "${__helptext+x}" ] && unset __helptext
|
[ ! -z "${__helptext+x}" ] && unset -v __helptext
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Set magic variables for current file, directory, os, etc.
|
# Set magic variables for current file, directory, os, etc.
|
||||||
@ -159,21 +159,17 @@ while read -r __b3bp_tmp_line; do
|
|||||||
__b3bp_tmp_long_opt="${__b3bp_tmp_long_opt%% *}"
|
__b3bp_tmp_long_opt="${__b3bp_tmp_long_opt%% *}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
__b3bp_tmp_long_opt_mangled="${__b3bp_tmp_long_opt//-/_}"
|
|
||||||
|
|
||||||
# map long name back to short name
|
# map long name back to short name
|
||||||
__b3bp_tmp_varname="__b3bp_tmp_short_opt_${__b3bp_tmp_long_opt_mangled}"
|
printf -v "__b3bp_tmp_short_opt_${__b3bp_tmp_long_opt//-/_}" '%s' "${__b3bp_tmp_opt}"
|
||||||
eval "${__b3bp_tmp_varname}=\"${__b3bp_tmp_opt}\""
|
|
||||||
|
|
||||||
# check if option takes an argument
|
# check if option takes an argument
|
||||||
__b3bp_tmp_varname="__b3bp_tmp_has_arg_${__b3bp_tmp_opt}"
|
|
||||||
if [[ ! "${__b3bp_tmp_line}" =~ \[.*\] ]]; then
|
if [[ ! "${__b3bp_tmp_line}" =~ \[.*\] ]]; then
|
||||||
__b3bp_tmp_init="0" # it's a flag. init with 0
|
__b3bp_tmp_init="0" # it's a flag. init with 0
|
||||||
eval "${__b3bp_tmp_varname}=0"
|
printf -v "__b3bp_tmp_has_arg_${__b3bp_tmp_opt:0:1}" '%s' "0"
|
||||||
else
|
else
|
||||||
__b3bp_tmp_opt="${__b3bp_tmp_opt}:" # add : if opt has arg
|
__b3bp_tmp_opt="${__b3bp_tmp_opt}:" # add : if opt has arg
|
||||||
__b3bp_tmp_init="" # it has an arg. init with ""
|
__b3bp_tmp_init="" # it has an arg. init with ""
|
||||||
eval "${__b3bp_tmp_varname}=1"
|
printf -v "__b3bp_tmp_has_arg_${__b3bp_tmp_opt:0:1}" '%s' "1"
|
||||||
fi
|
fi
|
||||||
__b3bp_tmp_opts="${__b3bp_tmp_opts:-}${__b3bp_tmp_opt}"
|
__b3bp_tmp_opts="${__b3bp_tmp_opts:-}${__b3bp_tmp_opt}"
|
||||||
fi
|
fi
|
||||||
@ -186,11 +182,19 @@ while read -r __b3bp_tmp_line; do
|
|||||||
|
|
||||||
if [ "${!__b3bp_tmp_varname}" = "1" ]; then
|
if [ "${!__b3bp_tmp_varname}" = "1" ]; then
|
||||||
__b3bp_tmp_init="${__b3bp_tmp_line##*Default=}"
|
__b3bp_tmp_init="${__b3bp_tmp_line##*Default=}"
|
||||||
|
__b3bp_tmp_re='^"(.*)"$'
|
||||||
|
if [[ "${__b3bp_tmp_init}" =~ ${__b3bp_tmp_re} ]]; then
|
||||||
|
__b3bp_tmp_init="${BASH_REMATCH[1]}"
|
||||||
|
else
|
||||||
|
__b3bp_tmp_re="^'(.*)'$"
|
||||||
|
if [[ "${__b3bp_tmp_init}" =~ ${__b3bp_tmp_re} ]]; then
|
||||||
|
__b3bp_tmp_init="${BASH_REMATCH[1]}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
__b3bp_tmp_varname="arg_${__b3bp_tmp_opt:0:1}"
|
printf -v "arg_${__b3bp_tmp_opt:0:1}" '%s' "${__b3bp_tmp_init}"
|
||||||
eval "${__b3bp_tmp_varname}=\"${__b3bp_tmp_init}\""
|
|
||||||
done <<< "${__usage:-}"
|
done <<< "${__usage:-}"
|
||||||
|
|
||||||
# run getopts only if options were specified in __usage
|
# run getopts only if options were specified in __usage
|
||||||
@ -213,17 +217,18 @@ if [ -n "${__b3bp_tmp_opts:-}" ]; then
|
|||||||
if [[ "${OPTARG}" =~ .*=.* ]]; then
|
if [[ "${OPTARG}" =~ .*=.* ]]; then
|
||||||
# --key=value format
|
# --key=value format
|
||||||
__b3bp_tmp_long_opt=${OPTARG/=*/}
|
__b3bp_tmp_long_opt=${OPTARG/=*/}
|
||||||
__b3bp_tmp_long_opt_mangled="${__b3bp_tmp_long_opt//-/_}"
|
|
||||||
# Set opt to the short option corresponding to the long option
|
# Set opt to the short option corresponding to the long option
|
||||||
eval "__b3bp_tmp_opt=\"\${__b3bp_tmp_short_opt_${__b3bp_tmp_long_opt_mangled}}\""
|
__b3bp_tmp_varname="__b3bp_tmp_short_opt_${__b3bp_tmp_long_opt//-/_}"
|
||||||
|
printf -v "__b3bp_tmp_opt" '%s' "${!__b3bp_tmp_varname}"
|
||||||
OPTARG=${OPTARG#*=}
|
OPTARG=${OPTARG#*=}
|
||||||
else
|
else
|
||||||
# --key value format
|
# --key value format
|
||||||
# Map long name to short version of option
|
# Map long name to short version of option
|
||||||
__b3bp_tmp_long_opt_mangled="${OPTARG//-/_}"
|
__b3bp_tmp_varname="__b3bp_tmp_short_opt_${OPTARG//-/_}"
|
||||||
eval "__b3bp_tmp_opt=\"\${__b3bp_tmp_short_opt_${__b3bp_tmp_long_opt_mangled}}\""
|
printf -v "__b3bp_tmp_opt" '%s' "${!__b3bp_tmp_varname}"
|
||||||
# Only assign OPTARG if option takes an argument
|
# Only assign OPTARG if option takes an argument
|
||||||
eval "OPTARG=\"\${@:OPTIND:\${__b3bp_tmp_has_arg_${__b3bp_tmp_opt}}}\""
|
__b3bp_tmp_varname="__b3bp_tmp_has_arg_${__b3bp_tmp_opt}"
|
||||||
|
printf -v "OPTARG" '%s' "${@:OPTIND:${!__b3bp_tmp_varname}}"
|
||||||
# shift over the argument if argument is expected
|
# shift over the argument if argument is expected
|
||||||
((OPTIND+=__b3bp_tmp_has_arg_${__b3bp_tmp_opt}))
|
((OPTIND+=__b3bp_tmp_has_arg_${__b3bp_tmp_opt}))
|
||||||
fi
|
fi
|
||||||
@ -237,7 +242,7 @@ if [ -n "${__b3bp_tmp_opts:-}" ]; then
|
|||||||
__b3bp_tmp_value="1"
|
__b3bp_tmp_value="1"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
eval "${__b3bp_tmp_varname}=\"${__b3bp_tmp_value}\""
|
printf -v "${__b3bp_tmp_varname}" '%s' "${__b3bp_tmp_value}"
|
||||||
debug "cli arg ${__b3bp_tmp_varname} = ($__b3bp_tmp_default) -> ${!__b3bp_tmp_varname}"
|
debug "cli arg ${__b3bp_tmp_varname} = ($__b3bp_tmp_default) -> ${!__b3bp_tmp_varname}"
|
||||||
done
|
done
|
||||||
set -o nounset # no more unbound variable references expected
|
set -o nounset # no more unbound variable references expected
|
||||||
@ -252,17 +257,17 @@ fi
|
|||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
for __tmp_varname in ${!__b3bp_tmp_*}; do
|
for __tmp_varname in ${!__b3bp_tmp_*}; do
|
||||||
eval "unset ${__tmp_varname}"
|
unset -v "${__tmp_varname}"
|
||||||
done
|
done
|
||||||
|
|
||||||
unset __tmp_varname
|
unset -v __tmp_varname
|
||||||
|
|
||||||
|
|
||||||
### Externally supplied __usage. Nothing else to do here
|
### Externally supplied __usage. Nothing else to do here
|
||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
if [ "${__b3bp_external_usage:-}" = "true" ]; then
|
if [ "${__b3bp_external_usage:-}" = "true" ]; then
|
||||||
unset __b3bp_external_usage
|
unset -v __b3bp_external_usage
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
ACCPTST:STDIO_REPLACE_DATETIMES
|
ACCPTST:STDIO_REPLACE_DATETIMES
|
||||||
{datetime} UTC [32m[ info][0m arg_1: 0
|
{datetime} UTC [32m[ info][0m arg_1: 0
|
||||||
{datetime} UTC [32m[ info][0m arg_2: 0
|
{datetime} UTC [32m[ info][0m arg_2: 0
|
||||||
{datetime} UTC [32m[ info][0m arg_3: THREE
|
{datetime} UTC [32m[ info][0m arg_3: 'THREE'
|
||||||
{datetime} UTC [32m[ info][0m arg_4: FOUR
|
{datetime} UTC [32m[ info][0m arg_4: "FOUR"
|
||||||
{datetime} UTC [32m[ info][0m arg_5: OOOPS
|
{datetime} UTC [32m[ info][0m arg_5: OOOPS
|
||||||
{datetime} UTC [32m[ info][0m arg_6:
|
{datetime} UTC [32m[ info][0m arg_6:
|
||||||
|
@ -16,12 +16,12 @@ read -r -d '' __usage <<-'EOF' || true # exits non-zero when EOF encountered
|
|||||||
More description.
|
More description.
|
||||||
-2 --two Do two things.
|
-2 --two Do two things.
|
||||||
More description. Default="TWO"
|
More description. Default="TWO"
|
||||||
-3 --three [arg] Do three things. Default="THREE"
|
-3 --three [arg] Do three things. Default="'THREE'"
|
||||||
More description.
|
More description.
|
||||||
-4 --four [arg] Do four things.
|
-4 --four [arg] Do four things.
|
||||||
More description. Default="FOUR"
|
More description. Default='"FOUR"'
|
||||||
-5 --five [arg] Do five things. Default="FIVE"
|
-5 --five [arg] Do five things. Default="FIVE"
|
||||||
More description. Default="OOOPS"
|
More description. Default='OOOPS'
|
||||||
-6 --six [arg] Do six things.
|
-6 --six [arg] Do six things.
|
||||||
More description.
|
More description.
|
||||||
EOF
|
EOF
|
||||||
|
Loading…
Reference in New Issue
Block a user