From: Philip Howard Date: Tue, 16 Jul 2019 13:47:06 +0000 (+0100) Subject: Merge pull request #14 from tanyafish/master X-Git-Url: https://zdv2.bktei.com/gitweb/EVA-2020-02-2.git/commitdiff_plain/c44453f6712b1dbdd47339d1b6a4f6d5f690c772?hp=95b2a7c614880e28fdfe0ae318afd74adc707963 Merge pull request #14 from tanyafish/master add example for those without a PM sensor --- diff --git a/install.sh b/install.sh index 5cde03b..1fec5c8 100755 --- a/install.sh +++ b/install.sh @@ -3,6 +3,94 @@ CONFIG=/boot/config.txt DATESTAMP=`date "+%Y-%M-%d-%H-%M-%S"` CONFIG_BACKUP=false +APT_HAS_UPDATED=false +USER_HOME=/home/$SUDO_USER +RESOURCES_TOP_DIR=$USER_HOME/Pimoroni +WD=`pwd` + +user_check() { + if [ $(id -u) -ne 0 ]; then + printf "Script must be run as root. Try 'sudo ./install.sh'\n" + exit 1 + fi +} + +confirm() { + if [ "$FORCE" == '-y' ]; then + true + else + read -r -p "$1 [y/N] " response < /dev/tty + if [[ $response =~ ^(yes|y|Y)$ ]]; then + true + else + false + fi + fi +} + +prompt() { + read -r -p "$1 [y/N] " response < /dev/tty + if [[ $response =~ ^(yes|y|Y)$ ]]; then + true + else + false + fi +} + +success() { + echo -e "$(tput setaf 2)$1$(tput sgr0)" +} + +inform() { + echo -e "$(tput setaf 6)$1$(tput sgr0)" +} + +warning() { + echo -e "$(tput setaf 1)$1$(tput sgr0)" +} + +function do_config_backup { + if [ ! $CONFIG_BACKUP == true ]; then + CONFIG_BACKUP=true + FILENAME="config.preinstall-$LIBRARY_NAME-$DATESTAMP.txt" + inform "Backing up $CONFIG to /boot/$FILENAME\n" + cp $CONFIG /boot/$FILENAME + mkdir -p $RESOURCES_TOP_DIR/config-backups/ + cp $CONFIG $RESOURCES_TOP_DIR/config-backups/$FILENAME + if [ -f "$UNINSTALLER" ]; then + echo "cp $RESOURCES_TOP_DIR/config-backups/$FILENAME $CONFIG" >> $UNINSTALLER + fi + fi +} + +function apt_pkg_install { + PACKAGES=() + PACKAGES_IN=("$@") + for ((i = 0; i < ${#PACKAGES_IN[@]}; i++)); do + PACKAGE="${PACKAGES_IN[$i]}" + printf "Checking for $PACKAGE\n" + dpkg -L $PACKAGE > /dev/null 2>&1 + if [ "$?" == "1" ]; then + PACKAGES+=("$PACKAGE") + fi + done + PACKAGES="${PACKAGES[@]}" + if ! [ "$PACKAGES" == "" ]; then + echo "Installing missing packages: $PACKAGES" + if [ ! $APT_HAS_UPDATED ]; then + apt update + APT_HAS_UPDATED=true + fi + apt install -y $PACKAGES + if [ -f "$UNINSTALLER" ]; then + echo "apt uninstall -y $PACKAGES" + fi + fi +} + +user_check + +apt_pkg_install python-configparser CONFIG_VARS=`python - < /dev/null 2>&1 - if [ "$?" == "1" ]; then - PACKAGES+=("$PACKAGE") - fi - done - PACKAGES="${PACKAGES[@]}" - if ! [ "$PACKAGES" == "" ]; then - echo "Installing missing packages: $PACKAGES" - sudo apt update - sudo apt install -y $PACKAGES - fi -} +RESOURCES_DIR=$RESOURCES_TOP_DIR/$LIBRARY_NAME +UNINSTALLER=$RESOURCES_DIR/uninstall.sh -eval $CONFIG_VARS +mkdir -p $RESOURCES_DIR -printf "$LIBRARY_NAME $LIBRARY_VERSION Python Library: Installer\n\n" +cat << EOF > $UNINSTALLER +printf "It's recommended you run these steps manually.\n" +printf "If you want to run the full script, open it in\n" +printf "an editor and remove 'exit 1' from below.\n" +exit 1 +EOF -if [ $(id -u) -ne 0 ]; then - printf "Script must be run as root. Try 'sudo ./install.sh'\n" - exit 1 -fi +printf "$LIBRARY_NAME $LIBRARY_VERSION Python Library: Installer\n\n" cd library printf "Installing for Python 2..\n" apt_pkg_install "${PY2_DEPS[@]}" -python setup.py install +python setup.py install > /dev/null +if [ $? -eq 0 ]; then + success "Done!\n" + echo "pip uninstall $LIBRARY_NAME" >> $UNINSTALLER +fi if [ -f "/usr/bin/python3" ]; then printf "Installing for Python 3..\n" apt_pkg_install "${PY3_DEPS[@]}" - python3 setup.py install + python3 setup.py install > /dev/null + if [ $? -eq 0 ]; then + success "Done!\n" + echo "pip3 uninstall $LIBRARY_NAME" >> $UNINSTALLER + fi fi -cd .. +cd $WD for ((i = 0; i < ${#SETUP_CMDS[@]}; i++)); do CMD="${SETUP_CMDS[$i]}" @@ -97,7 +172,7 @@ for ((i = 0; i < ${#CONFIG_TXT[@]}; i++)); do CONFIG_LINE="${CONFIG_TXT[$i]}" if ! [ "$CONFIG_LINE" == "" ]; then do_config_backup - printf "Adding $CONFIG_LINE to $CONFIG\n" + inform "Adding $CONFIG_LINE to $CONFIG\n" sed -i "s/^#$CONFIG_LINE/$CONFIG_LINE/" $CONFIG if ! grep -q "^$CONFIG_LINE" $CONFIG; then printf "$CONFIG_LINE\n" >> $CONFIG @@ -105,4 +180,14 @@ for ((i = 0; i < ${#CONFIG_TXT[@]}; i++)); do fi done -printf "Done!\n" +if [ -d "examples" ]; then + if confirm "Would you like to copy examples to $RESOURCES_DIR?"; then + inform "Copying examples to $RESOURCES_DIR" + cp -r examples/ $RESOURCES_DIR + echo "rm -r $RESOURCES_DIR" >> $UNINSTALLER + fi +fi + +success "\nAll done!" +inform "If this is your first time installing you should reboot for hardware changes to tkae effect.\n" +inform "Find uninstall steps in $UNINSTALLER\n" diff --git a/library/setup.cfg b/library/setup.cfg index 0e6f54f..ed7cef7 100644 --- a/library/setup.cfg +++ b/library/setup.cfg @@ -26,6 +26,14 @@ classifiers = Topic :: Software Development :: Libraries Topic :: System :: Hardware +[options] +install_requires = + pimoroni-bme280 + pms5003 + ltr559 + st7735 + ads1015 + [flake8] exclude = .tox, @@ -39,13 +47,15 @@ ignore = [pimoroni] py2deps = + python-pip python-numpy python-smbus - python-pil + python-pil py3deps = + python3-pip python3-numpy python3-smbus - python3-pil + python3-pil configtxt = dtoverlay=pi3-miniuart-bt commands =