Add getopts (to allow user to choose whiptail or dialog)
This commit is contained in:
parent
815dfe19dc
commit
5d8e97eab1
|
@ -1,33 +1,82 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
|
usage() {
|
||||||
|
cat << EOF
|
||||||
|
usage: ${0##*/} [command]
|
||||||
|
-h Print this help message.
|
||||||
|
-w Use whiptail.
|
||||||
|
-d Use dialog.
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
checkParameters() {
|
||||||
|
local counter=0
|
||||||
|
while getopts ':hwd' flag; do
|
||||||
|
if [ $((counter++)) -eq 1 ]; then
|
||||||
|
usage
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
case $flag in
|
||||||
|
h)
|
||||||
|
usage
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
w)
|
||||||
|
checkForDependencies "libnewt"
|
||||||
|
displayDialog=useWhiptail
|
||||||
|
;;
|
||||||
|
d)
|
||||||
|
checkForDependencies "dialog"
|
||||||
|
displayDialog=useDialog
|
||||||
|
;;
|
||||||
|
?)
|
||||||
|
printf '%s: invalid option - '\''%s'\'\\n "${0##*/}" "$OPTARG"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ $counter -eq 0 ]; then
|
||||||
|
checkForDependencies "libnewt"
|
||||||
|
displayDialog=useWhiptail
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
getGitconfigData() {
|
getGitconfigData() {
|
||||||
whiptail --yesno "Would you like to set up gitconfig?" 0 0
|
$displayDialog --yesno "Would you like to set up gitconfig?"
|
||||||
if [ $? -eq 1 ]; then
|
if [ $? -eq 1 ]; then
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
|
|
||||||
whiptail --msgbox "Now, I will ask you for data to set up gitconfig personal account." 10 60
|
$displayDialog --msgbox "Now, I will ask you for data to set up gitconfig personal account."
|
||||||
gitPersonalName=$(whiptail --inputbox "Enter a name." 0 0 3>&1 1>&2 2>&3)
|
gitPersonalName=$($displayDialog --inputbox "Enter a name." 3>&1 1>&2 2>&3)
|
||||||
gitPersonalMail=$(whiptail --inputbox "Enter an e-mail." 0 0 3>&1 1>&2 2>&3)
|
gitPersonalMail=$($displayDialog --inputbox "Enter an e-mail." 3>&1 1>&2 2>&3)
|
||||||
|
|
||||||
whiptail --msgbox "Let's continue with the work account." 0 0
|
$displayDialog --msgbox "Let's continue with the work account."
|
||||||
gitWorkPath=$(whiptail --inputbox "Enter an absolute folder path where you would like to use the work account." 0 0 3>&1 1>&2 2>&3)
|
gitWorkPath=$($displayDialog --inputbox "Enter an absolute folder path where you would like to use the work account." 3>&1 1>&2 2>&3)
|
||||||
while [[ ! -d $gitWorkPath ]]; do
|
while [[ ! -d $gitWorkPath ]]; do
|
||||||
gitWorkPath=$(whiptail --no-cancel --inputbox "Path isn't valid. Please try again" 0 0 3>&1 1>&2 2>&3)
|
gitWorkPath=$($displayDialog --no-cancel --inputbox "Path isn't valid. Please try again" 3>&1 1>&2 2>&3)
|
||||||
done
|
done
|
||||||
gitWorkName=$(whiptail --inputbox "Enter a name." 0 0 3>&1 1>&2 2>&3)
|
gitWorkName=$($displayDialog --inputbox "Enter a name." 3>&1 1>&2 2>&3)
|
||||||
gitWorkMail=$(whiptail --inputbox "Enter an e-mail." 0 0 3>&1 1>&2 2>&3)
|
gitWorkMail=$($displayDialog --inputbox "Enter an e-mail." 3>&1 1>&2 2>&3)
|
||||||
|
|
||||||
sed -e "s/PERSONAL_NAME/$gitPersonalName/g" -e "s/PERSONAL_MAIL/$gitPersonalMail/g" -e "s|WORK_PATH|${gitWorkPath}|g" ./templates/.gitconfig > ./dotfiles/.gitconfig
|
sed -e "s/PERSONAL_NAME/$gitPersonalName/g" -e "s/PERSONAL_MAIL/$gitPersonalMail/g" -e "s|WORK_PATH|${gitWorkPath}|g" ./templates/.gitconfig > ./dotfiles/.gitconfig
|
||||||
sed -e "s/WORK_NAME/$gitWorkName/g" -e "s/WORK_MAIL/$gitWorkMail/g" ./templates/.gitconfig-work > ./dotfiles/.gitconfig-work
|
sed -e "s/WORK_NAME/$gitWorkName/g" -e "s/WORK_MAIL/$gitWorkMail/g" ./templates/.gitconfig-work > ./dotfiles/.gitconfig-work
|
||||||
}
|
}
|
||||||
|
|
||||||
checkForDependencies() {
|
checkForDependencies() {
|
||||||
commOuput=$(command -v whiptail &> /dev/null)
|
if [ "$1" = "libnewt" ]; then
|
||||||
|
comm=whiptail
|
||||||
|
else
|
||||||
|
comm=$1
|
||||||
|
fi
|
||||||
|
|
||||||
|
commOuput=$(command -v ${comm} &> /dev/null)
|
||||||
if [ $? -eq 1 ]; then
|
if [ $? -eq 1 ]; then
|
||||||
unameOutput=$(uname -a | grep "arch")
|
unameOutput=$(uname -a | grep "arch")
|
||||||
if [ -f "/etc/arch-release" ] || [ $unameOutput -eq 0 ]; then
|
if [ -f "/etc/arch-release" ] || [ $unameOutput -eq 0 ]; then
|
||||||
sudo pacman --noconfirm --needed -Sy libnewt > /dev/null 2>&1
|
sudo pacman --noconfirm --needed -Sy ${1} > /dev/null 2>&1
|
||||||
if [ $? -eq 1 ]; then
|
if [ $? -eq 1 ]; then
|
||||||
echo "You must have an active internet connection." >&2
|
echo "You must have an active internet connection." >&2
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -36,26 +85,35 @@ checkForDependencies() {
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "You must install libnewt." >&2
|
echo "You must install ${1}." >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
startRice() {
|
useDialog() {
|
||||||
checkForDependencies
|
dialog "$@" 9 60
|
||||||
|
}
|
||||||
|
|
||||||
|
useWhiptail() {
|
||||||
|
whiptail "$@" 0 0
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
startRice() {
|
||||||
lastFolder=$(pwd -P)
|
lastFolder=$(pwd -P)
|
||||||
cocoRiceFolder=$(echo "$(pwd -P)" | awk '{ sub(/CocoRice.*/, "CocoRice"); print }')
|
cocoRiceFolder=$(echo "$(pwd -P)" | awk '{ sub(/CocoRice.*/, "CocoRice"); print }')
|
||||||
cd $cocoRiceFolder
|
cd $cocoRiceFolder
|
||||||
|
|
||||||
whiptail --title "CocoRice" --msgbox "Hi! This script will auto install my dotfiles." 0 0
|
$displayDialog --title "CocoRice" --msgbox "Hi! This script will auto install my dotfiles."
|
||||||
getGitconfigData
|
getGitconfigData
|
||||||
sh scripts/linkFiles.sh
|
sh scripts/linkFiles.sh
|
||||||
sh scripts/install.sh
|
sh scripts/install.sh
|
||||||
whiptail --title "CocoRice" --msgbox "All done! Enjoy..." 0 0
|
$displayDialog --title "CocoRice" --msgbox "All done! Enjoy..."
|
||||||
|
|
||||||
clear
|
clear
|
||||||
cd $lastFolder
|
cd $lastFolder
|
||||||
}
|
}
|
||||||
|
|
||||||
|
checkParameters $@
|
||||||
|
checkForDependencies
|
||||||
startRice
|
startRice
|
||||||
|
|
Loading…
Reference in New Issue