Better handle user input
This commit is contained in:
parent
b5c1d62c29
commit
ad249106cf
|
@ -4,6 +4,7 @@ ATTEMPTS_NUM=7
|
||||||
POOL_NUM=100
|
POOL_NUM=100
|
||||||
RE='^[0-9]+$'
|
RE='^[0-9]+$'
|
||||||
|
|
||||||
|
# Muestra la ayuda y sale del programa
|
||||||
usage ()
|
usage ()
|
||||||
{
|
{
|
||||||
echo "Usage: ./guess_number.sh -p 50 -a 30"
|
echo "Usage: ./guess_number.sh -p 50 -a 30"
|
||||||
|
@ -15,6 +16,7 @@ usage ()
|
||||||
exit
|
exit
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Recoge parámetros al ejecutar el script
|
||||||
while getopts a:p:h flag; do
|
while getopts a:p:h flag; do
|
||||||
case "${flag}" in
|
case "${flag}" in
|
||||||
a) ATTEMPTS_NUM=${OPTARG};;
|
a) ATTEMPTS_NUM=${OPTARG};;
|
||||||
|
@ -23,6 +25,7 @@ while getopts a:p:h flag; do
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
|
# Muestra la cantidad actual de números y vidas restantes
|
||||||
status() {
|
status() {
|
||||||
clear
|
clear
|
||||||
cat <<'END_CAT'
|
cat <<'END_CAT'
|
||||||
|
@ -39,6 +42,9 @@ END_CAT
|
||||||
echo "Intentos restantes: $ATTEMPTS_NUM"
|
echo "Intentos restantes: $ATTEMPTS_NUM"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Comprueba si el número introducido es correcto,
|
||||||
|
# si no es correcto, comprueba si es mayor o menos antes
|
||||||
|
# de devolver el resultado
|
||||||
checkWin() {
|
checkWin() {
|
||||||
if [[ "$1" == "$RANDOM_NUM" ]]; then
|
if [[ "$1" == "$RANDOM_NUM" ]]; then
|
||||||
echo "Enhorabuena! El número era $RANDOM_NUM!"
|
echo "Enhorabuena! El número era $RANDOM_NUM!"
|
||||||
|
@ -51,6 +57,11 @@ checkWin() {
|
||||||
ATTEMPTS_NUM=$((ATTEMPTS_NUM - 1))
|
ATTEMPTS_NUM=$((ATTEMPTS_NUM - 1))
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Ya se que este código podría ser considerablemente
|
||||||
|
# acortado, pero prefiero Bash lo más explícito posible
|
||||||
|
# para evitar posibles complicaciones
|
||||||
|
|
||||||
if [[ $1 -lt $RANDOM_NUM ]]; then
|
if [[ $1 -lt $RANDOM_NUM ]]; then
|
||||||
echo "El número es demasiado bajo!"
|
echo "El número es demasiado bajo!"
|
||||||
ATTEMPTS_NUM=$((ATTEMPTS_NUM - 1))
|
ATTEMPTS_NUM=$((ATTEMPTS_NUM - 1))
|
||||||
|
@ -59,6 +70,8 @@ checkWin() {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Comprueba si el número de intentos es igual a cero
|
||||||
|
# para terminar la partida
|
||||||
checkLose() {
|
checkLose() {
|
||||||
if [[ $ATTEMPTS_NUM == 0 ]]; then
|
if [[ $ATTEMPTS_NUM == 0 ]]; then
|
||||||
echo "Pierdes! El número era $RANDOM_NUM :/"
|
echo "Pierdes! El número era $RANDOM_NUM :/"
|
||||||
|
@ -66,17 +79,23 @@ checkLose() {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Función principal
|
||||||
main() {
|
main() {
|
||||||
|
# Genera un número aleatorio desde 0 hasta el número máximo
|
||||||
|
# configurado por el usuario
|
||||||
RANDOM_NUM=$(seq 0 $POOL_NUM | tr " " "\n" | shuf -n1)
|
RANDOM_NUM=$(seq 0 $POOL_NUM | tr " " "\n" | shuf -n1)
|
||||||
for (( ; ; )); do
|
|
||||||
|
|
||||||
|
for (( ; ; )); do
|
||||||
status
|
status
|
||||||
checkLose
|
checkLose
|
||||||
|
|
||||||
|
# Comprobación de entrada de usuario:
|
||||||
num_attempt="-1"
|
# Prohíbe cualquier entrada que no sea un número y que sea mayor al límite
|
||||||
while [[ ! $num_attempt =~ $RE || $num_attempt > $POOL_NUM ]]; do
|
while true; do
|
||||||
read -p "Número: " num_attempt
|
read -p "Número: " num_attempt
|
||||||
|
if [[ $num_attempt =~ $RE ]] && (( $num_attempt <= $POOL_NUM )); then
|
||||||
|
break
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
checkWin $num_attempt
|
checkWin $num_attempt
|
||||||
|
|
Loading…
Reference in New Issue