Check requirements on missing binaries

As #1146 noted some installations miss hexdump. Better practice
is to check before what's needed albeit the error message when
a binary is missing does give the user a hint.
This commit is contained in:
Dirk 2018-10-16 15:32:11 +02:00
parent 032020bc4f
commit 33c7902247

View File

@ -17392,6 +17392,16 @@ create_cmd_line_string() {
printf '%s\n' "${allargs[*]}" printf '%s\n' "${allargs[*]}"
} }
check_base_requirements() {
local binary=''
for binary in 'hexdump' 'dd' 'grep' 'awk' 'tr' 'sed' 'date' 'cat' 'ps' 'kill' 'head' 'tail' 'dirname'; do
if ! type -p "${binary}" &> /dev/null; then
fatal "You need to install ${binary} for this program to work" $ERR_RESOURCE
fi
done
}
parse_cmd_line() { parse_cmd_line() {
local outfile_arg="" local outfile_arg=""
local cipher_mapping local cipher_mapping
@ -18031,6 +18041,7 @@ lets_roll() {
lets_roll init lets_roll init
initialize_globals initialize_globals
check_base_requirements # needs to come after $do_html is defined
parse_cmd_line "$@" parse_cmd_line "$@"
# html_header() needs to be called early! Otherwise if html_out() is called before html_header() and the # html_header() needs to be called early! Otherwise if html_out() is called before html_header() and the
# command line contains --htmlfile <htmlfile> or --html, it'll make problems with html output, see #692. # command line contains --htmlfile <htmlfile> or --html, it'll make problems with html output, see #692.