From e621b45753951b9136135f8412b0424c6fa110d5 Mon Sep 17 00:00:00 2001 From: Frank Brehm Date: Mon, 9 Oct 2023 18:12:04 +0200 Subject: [PATCH] Updating update-env.sh and requirements.txt --- requirements.txt | 2 +- update-env.sh | 127 +++++++++++++++-------------------------------- 2 files changed, 41 insertions(+), 88 deletions(-) diff --git a/requirements.txt b/requirements.txt index a90700b..891199d 100644 --- a/requirements.txt +++ b/requirements.txt @@ -9,4 +9,4 @@ requests six setuptools wheel -git+https://github.com/fbrehm/python_fb_tools.git@master +fb_tools diff --git a/update-env.sh b/update-env.sh index 19a4b4d..47b758e 100755 --- a/update-env.sh +++ b/update-env.sh @@ -7,7 +7,7 @@ VERBOSE="n" DEBUG="n" QUIET='n' -VERSION="2.3" +VERSION="2.4" # console colors: RED="" @@ -17,19 +17,16 @@ GREEN="" CYAN="" NORMAL="" -BASENAME=$(basename "${0}") +BASENAME=$( basename "${0}" ) BASE_DIR=$( dirname "$0" ) -cd "${BASE_DIR}" || exit 99 +cd "${BASE_DIR}" BASE_DIR=$( readlink -f . ) +declare -a VALID_PY_VERSIONS=("3.10" "3.9" "3.8" "3.7" "3.6") + PIP_OPTIONS= export VIRTUAL_ENV_DISABLE_PROMPT=y -declare -a VALID_PY_VERSIONS=("3.9" "3.8" "3.7" "3.6" "3.5") -PY_VERSION_FINAL= -PYTHON= -VENV_BIN='virtualenv' - #------------------------------------------------------------------- detect_color() { @@ -58,13 +55,12 @@ detect_color() { # console colors: if [ "${use_color}" = "true" ] ; then - RED="\\033[38;5;196m" - YELLOW="\\033[38;5;226m" - GREEN="\\033[38;5;46m" - # BLUE="\\033[38;5;27m" - CYAN="\\033[38;5;36m" - NORMAL="\\033[39m" - # HAS_COLORS="y" + RED="\033[38;5;196m" + YELLOW="\033[38;5;226m" + GREEN="\033[38;5;46m" + # BLUE="\033[38;5;27m" + CYAN="\033[38;5;36m" + NORMAL="\033[39m" else RED="" YELLOW="" @@ -75,8 +71,7 @@ detect_color() { fi local my_tty - - my_tty=$(tty) + my_tty=$( tty ) if [[ "${my_tty}" =~ 'not a tty' ]] ; then my_tty='-' fi @@ -84,6 +79,7 @@ detect_color() { } detect_color +#------------------------------------------------------------------------------ my_date() { date +'%F %T.%N %:::z' } @@ -177,9 +173,6 @@ get_options() { local tmp= local short_options="dvqhV" local long_options="debug,verbose,quiet,help,version" - local py_version= - local py_found="n" - local ret= set +e tmp=$( getopt -o "${short_options}" --long "${long_options}" -n "${BASENAME}" -- "$@" ) @@ -212,7 +205,6 @@ get_options() { # BLUE="" CYAN="" NORMAL="" - # HAS_COLORS="n" shift ;; --nocolor) @@ -222,7 +214,6 @@ get_options() { # BLUE="" CYAN="" NORMAL="" - # HAS_COLORS="n" shift ;; -h|--help) @@ -255,52 +246,10 @@ get_options() { exit 1 fi - py_found="n" - info "Searching for valid Python …" - for py_version in "${VALID_PY_VERSIONS[@]}" ; do - PYTHON="python${py_version}" - debug "Testing Python binary '${CYAN}${PYTHON}${NORMAL}' …" - if type -t "${PYTHON}" >/dev/null ; then - py_found="y" - PY_VERSION_FINAL="${py_version}" - empty_line - info "Found '${GREEN}${PYTHON}${NORMAL}'." - break - fi - done - - if [[ "${py_found}" == "n" ]] ; then - empty_line >&2 - error "Did not found a usable Python version." >&2 - error "Usable Python versions are: ${YELLOW}${VALID_PY_VERSIONS[*]}${NORMAL}." >&2 - empty_line >&2 - exit 5 - fi - - info "Searching for valid virtualenv …" - VENV_BIN="virtualenv-${PY_VERSION_FINAL}" - debug "Testing '${VENV_BIN}' …" - if type -t "${VENV_BIN}" >/dev/null ; then - : - else - VENV_BIN="virtualenv" - debug "Testing '${VENV_BIN}' …" - if type -t "${VENV_BIN}" >/dev/null ; then - : - else - empty_line >&2 - error "Did not found a usable virtualenv." >&2 - error "Command '${RED}virtualenv${NORMAL}' not found, please install package '${YELLOW}python-virtualenv${NORMAL}' or appropriate." - empty_line >&2 - exit 6 - fi - fi - info "Found '${GREEN}${VENV_BIN}${NORMAL}'." - if type -t msgfmt >/dev/null ; then : else - echo "Command '${RED}msgfmt${NORMAL}' not found, please install package '${YELLOW}gettext${NORMAL}' or appropriate." >&2 + echo "Command '${RED}msgfmt${NORMAL}' not found, please install package '${YELLOW}gettext${NORMAL}' or appropriate." >&2 exit 6 fi @@ -315,6 +264,10 @@ get_options() { #------------------------------------------------------------------------------ init_venv() { + local py_version= + local python= + local found="n" + empty_line line info "Preparing virtual environment …" @@ -322,20 +275,30 @@ init_venv() { if [[ ! -f venv/bin/activate ]] ; then - - empty_line - if [[ "${VENV_BIN}" == 'virtualenv' ]] ; then - virtualenv --python="${PYTHON}" venv - else - ${VENV_BIN} venv + found="n" + for py_version in "${VALID_PY_VERSIONS[@]}" ; do + python="python${py_version}" + debug "Testing Python binary '${CYAN}${python}${NORMAL}' …" + if type -t "${python}" >/dev/null ; then + found="y" + empty_line + info "Found '${GREEN}${python}${NORMAL}'." + empty_line + "${python}" -m venv venv + break + fi + done + if [[ "${found}" == "n" ]] ; then + empty_line >&2 + error "Did not found a usable Python version." >&2 + error "Usable Python versions are: ${YELLOW}${VALID_PY_VERSIONS[*]}${NORMAL}." >&2 + empty_line >&2 + exit 5 fi - fi # shellcheck disable=SC1091 . venv/bin/activate || exit 5 - debug "Which pip: $(command -v pip)" - debug "Which python: $(command -v python)" } @@ -362,6 +325,8 @@ upgrade_modules() { line info "Installing and/or upgrading necessary modules …" empty_line + pip install ${PIP_OPTIONS} --upgrade --upgrade-strategy eager Babel + empty_line pip install ${PIP_OPTIONS} --upgrade --upgrade-strategy eager --requirement requirements.txt empty_line } @@ -390,18 +355,6 @@ compile_i18n() { fi } -#------------------------------------------------------------------------------ -compile_i18n() { - - if [[ -x compile-xlate-msgs.sh ]]; then - line - info "Updating i18n files in ${BASE_DIR} …" - empty_line - ./compile-xlate-msgs.sh - empty_line - fi -} - ################################################################################ ## ## Main @@ -429,4 +382,4 @@ main "$@" exit 0 -# vim: ts=4 +# vim: ts=4 list -- 2.39.5