mirror of
https://github.com/zardus/ctf-tools
synced 2024-12-13 22:42:38 +00:00
fixed weird indentation fails and added 'set -eu -o pipefail' at the top of the script
This commit is contained in:
parent
6dd094a8a9
commit
98c76cefde
1 changed files with 48 additions and 50 deletions
|
@ -1,5 +1,6 @@
|
|||
#!/bin/bash -e
|
||||
# set -evx
|
||||
#!/bin/bash
|
||||
set -eu -o pipefail
|
||||
# set -x
|
||||
|
||||
function usage()
|
||||
{
|
||||
|
@ -43,66 +44,63 @@ function detect_distribution()
|
|||
|
||||
function base_build_setup_ubuntu()
|
||||
{
|
||||
PACKAGE_REQS="build-essential libtool g++ gcc linuxtexinfo curl wget automake autoconf python-dev git subversion unzip"
|
||||
PACKAGE_COUNT=$(echo $PACKAGE_REQS | tr ' ' '\n' | wc -l)
|
||||
if [ $(dpkg -l $PACKAGE_REQS | grep "^ii" | wc -l) -ne $PACKAGE_COUNT ]
|
||||
then
|
||||
if [ "$ALLOW_SUDO" -eq 1 ]
|
||||
then
|
||||
sudo apt-get -y install $PACKAGE_REQS
|
||||
else
|
||||
TOOL=SETUP tool_log "Please install the following packages: $PACKAGE_REQS"
|
||||
fi
|
||||
fi
|
||||
PACKAGE_REQS="build-essential libtool g++ gcc linuxtexinfo curl wget automake autoconf python-dev git subversion unzip"
|
||||
PACKAGE_COUNT=$(echo $PACKAGE_REQS | tr ' ' '\n' | wc -l)
|
||||
if [ $(dpkg -l $PACKAGE_REQS | grep "^ii" | wc -l) -ne $PACKAGE_COUNT ]
|
||||
then
|
||||
if [ "$ALLOW_SUDO" -eq 1 ]; then
|
||||
sudo apt-get -y install $PACKAGE_REQS
|
||||
else
|
||||
TOOL=SETUP tool_log "Please install the following packages: $PACKAGE_REQS"
|
||||
fi
|
||||
fi
|
||||
|
||||
if ! dpkg --print-foreign-architectures | grep -q i386
|
||||
then
|
||||
if [ "$ALLOW_SUDO" -eq 1 ]
|
||||
then
|
||||
sudo dpkg --add-architecture i386
|
||||
sudo apt-get update
|
||||
else
|
||||
TOOL=SETUP tool_log "Certain tools need i386 libraries (enable with 'dpkg --add-architecture i386; apt-get update')."
|
||||
fi
|
||||
fi
|
||||
if ! dpkg --print-foreign-architectures | grep -q i386
|
||||
then
|
||||
if [ "$ALLOW_SUDO" -eq 1 ]
|
||||
then
|
||||
sudo dpkg --add-architecture i386
|
||||
sudo apt-get update
|
||||
else
|
||||
TOOL=SETUP tool_log "Certain tools need i386 libraries (enable with 'dpkg --add-architecture i386; apt-get update')."
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
function base_build_setup_arch()
|
||||
{
|
||||
PACKAGE_REQS="curl wget python2 python3 git subversion unzip"
|
||||
if [ "$ALLOW_SUDO" -eq 1 ]; then
|
||||
sudo pacman -Syu --noconfirm $PACKAGE_REQS
|
||||
sudo pacman -Syu --noconfirm base-devel || true
|
||||
else
|
||||
TOOL=SETUP tool_log "Please install the following packages: $PACKAGE_REQS"
|
||||
fi
|
||||
PACKAGE_REQS="curl wget python2 python3 git subversion unzip"
|
||||
if [ "$ALLOW_SUDO" -eq 1 ]; then
|
||||
sudo pacman -Syu --noconfirm $PACKAGE_REQS
|
||||
sudo pacman -Syu --noconfirm base-devel || true
|
||||
else
|
||||
TOOL=SETUP tool_log "Please install the following packages: $PACKAGE_REQS"
|
||||
fi
|
||||
|
||||
|
||||
if ! grep "^\[multilib\]$" /etc/pacman.conf >/dev/null; then
|
||||
if [ "$ALLOW_SUDO" -eq 1 ]
|
||||
then
|
||||
sudo sh -c 'cat >> /etc/pacman.conf' <<EOF
|
||||
if ! grep "^\[multilib\]$" /etc/pacman.conf >/dev/null; then
|
||||
if [ "$ALLOW_SUDO" -eq 1 ]; then
|
||||
sudo sh -c 'cat >> /etc/pacman.conf' <<EOF
|
||||
|
||||
[multilib]
|
||||
Include = /etc/pacman.d/mirrorlist
|
||||
EOF
|
||||
else
|
||||
TOOL=SETUP tool_log "Certain tools need i386 libraries (enable multilib in /etc/pacman.conf')."
|
||||
return
|
||||
fi
|
||||
fi
|
||||
else
|
||||
TOOL=SETUP tool_log "Certain tools need i386 libraries (enable multilib in /etc/pacman.conf')."
|
||||
return
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ "$ALLOW_SUDO" -eq 1 ] \
|
||||
&& grep "^\[multilib\]$" /etc/pacman.conf >/dev/null \
|
||||
&& ! sudo pacman -Qk gcc-multilib >/dev/null
|
||||
then
|
||||
sudo pacman -Syy --noconfirm
|
||||
#sudo pacman -Syu --noconfirm multilib-devel
|
||||
# unfortunately we cannot do --noconfirm if we might choose to replace
|
||||
# a package such as gcc with gcc-multilib, therefore this workaround
|
||||
printf "\ny\ny\ny\n" | sudo pacman -Syu multilib-devel
|
||||
fi
|
||||
if [ "$ALLOW_SUDO" -eq 1 ] \
|
||||
&& grep "^\[multilib\]$" /etc/pacman.conf >/dev/null \
|
||||
&& ! sudo pacman -Qk gcc-multilib >/dev/null
|
||||
then
|
||||
sudo pacman -Syy --noconfirm
|
||||
#sudo pacman -Syu --noconfirm multilib-devel
|
||||
# unfortunately we cannot do --noconfirm if we might choose to replace
|
||||
# a package such as gcc with gcc-multilib, therefore this workaround
|
||||
printf "\ny\ny\ny\n" | sudo pacman -Syu multilib-devel
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
|
|
Loading…
Reference in a new issue