X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=pxe-server;h=c19f6d2eeadbe95449003b5f12543266aa4739c1;hb=e6c8a36522847eca91819ab3eb656dd824bc3e3c;hp=9c3f917fcaceee7a488453759aa6eed44b528250;hpb=bcdb96792264d6cda20e6d2fa176728a67c87862;p=automated-distro-installer diff --git a/pxe-server b/pxe-server index 9c3f917..c19f6d2 100755 --- a/pxe-server +++ b/pxe-server @@ -22,29 +22,42 @@ # default distro is the base debian/fedora type. others are fai & arch. # for no pxe server, use a no-op like : or true. -set -eE -o pipefail -trap 'echo "$0:$LINENO:error: \"$BASH_COMMAND\" returned $?" >&2' ERR + +x="$(readlink -f "$BASH_SOURCE")"; source "${x%/*}/bash-trace" usage() { cat < tftpboot + + Note: Uses GNU getopt options parsing style EOF exit $1 @@ -52,16 +65,16 @@ EOF ##### begin command line parsing ######## -args=() redep=true acks=2 wait=false -temp=$(getopt -l help harw "$@") || usage 1 +temp=$(getopt -l help harSw "$@") || usage 1 eval set -- "$temp" while true; do case $1 in -a) wait=true; set=false; shift ;; -r) redep=false; shift ;; + -S) chboot_arg=-S; shift ;; -w) wait=true; set=true; shift ;; -h|--help) usage ;; --) shift; break ;; @@ -69,7 +82,7 @@ while true; do esac done -read host type <<<"$@" +read -r host type <<<"$@" case $# in 0|2);; @@ -80,7 +93,7 @@ case $# in ;; esac -if [[ $host ]]; then +if [[ $host && $host != default ]]; then host_tag="tag:$host," fi @@ -109,8 +122,7 @@ EOF fai() { cat </dev/null ||: fi fi