#! /usr/bin/env sh # defaults [ "${CD_DNS}" ] || CD_DNS="\ 9.9.9.9 \ " [ "${CD_GIT_CHILD}" ] || CD_GIT_CHILD="cd" [ "${CD_GIT_PARENT}" ] || CD_GIT_PARENT="rwx" # main cd_main () { cd_set_environment_variables cd_set_packages_repositories cd_set_packages_configuration # cd_list_working_directory cd_set_https_verification_off cd_set_dns_resolving cd_update_packages_catalog cd_install_packages_tools cd_install_ca_certificates cd_write_ca_certificates cd_update_ca_certificates cd_set_https_verification_on cd_update_packages_catalog cd_upgrade_packages cd_install_git cd_install_python # TODO move to Python cd_install_rsync # TODO move to Python cd_install_ssh cd_clean_packages_cache cd_install_python_modules cd_write_python_module cd_switch_to_python "${@}" } # steps cd_set_environment_variables () { cd_step "Set environment variables" # set path CD_PATH="$(realpath "${0}")" cd_echo "CD_PATH" # set operating system id CD_OS_ID="$(cd_grep_os ID)" case "${CD_OS_ID}" in "almalinux") CD_OS_ID="${CD_OS_ALMA}" ;; "alpine") CD_OS_ID="${CD_OS_ALPINE}" ;; "arch") CD_OS_ID="${CD_OS_ARCH}" ;; "debian") CD_OS_ID="${CD_OS_DEBIAN}" ;; "fedora") CD_OS_ID="${CD_OS_FEDORA}" ;; "rocky") CD_OS_ID="${CD_OS_ROCKY}" ;; "ubuntu") CD_OS_ID="${CD_OS_UBUNTU}" ;; *) cd_error_os "CD_OS_ID" ;; esac # set operating system version case "${CD_OS_ID}" in "${CD_OS_ALMA}"|"${CD_OS_ARCH}"|"${CD_OS_FEDORA}"|"${CD_OS_ROCKY}") CD_OS_VERSION=$(cd_grep_os VERSION_ID \ | sed "s|^\([0-9]\+\)\..*|\1|") ;; "${CD_OS_ALPINE}") CD_OS_VERSION=$(cd_grep_os VERSION_ID \ | sed "s|^\([0-9]\+\.[0-9]\+\)\..*|\1|") ;; "${CD_OS_DEBIAN}"|"${CD_OS_UBUNTU}") CD_OS_VERSION="$(cd_grep_os VERSION_CODENAME)" ;; esac # check operating system version case "${CD_OS_ID}" in "${CD_OS_ALMA}"|"${CD_OS_ROCKY}") case "${CD_OS_VERSION}" in "8"|"9") ;; *) cd_error_os "CD_OS_VERSION" ;; esac ;; "${CD_OS_ALPINE}") case "${CD_OS_VERSION}" in "3.18"|"3.19") ;; *) cd_error_os "CD_OS_VERSION" ;; esac ;; "${CD_OS_ARCH}") case "${CD_OS_VERSION}" in "20231112"|"20240101") ;; *) cd_error_os "CD_OS_VERSION" ;; esac ;; "${CD_OS_DEBIAN}") case "${CD_OS_VERSION}" in "bookworm"|"bullseye") ;; *) cd_error_os "CD_OS_VERSION" ;; esac ;; "${CD_OS_FEDORA}") case "${CD_OS_VERSION}" in "39"|"40") ;; *) cd_error_os "CD_OS_VERSION" ;; esac ;; "${CD_OS_UBUNTU}") case "${CD_OS_VERSION}" in "jammy"|"noble") ;; *) cd_error_os "CD_OS_VERSION" ;; esac ;; esac cd_split cd_echo "CD_OS_ID" "CD_OS_VERSION" # universal CD_DNS_FILE="/etc/resolv.conf" CD_PKG_CA="ca-certificates" CD_PKG_GIT="git" # TODO move to Python CD_PKG_RSYNC="rsync" CD_PYTHON_ALIAS="python3" cd_split cd_echo "CD_DNS_FILE" "CD_PKG_CA" "CD_PKG_GIT" "CD_PYTHON_ALIAS" # set ca command & root case "${CD_OS_ID}" in "${CD_OS_ALMA}"|"${CD_OS_FEDORA}"|"${CD_OS_ROCKY}") CD_CA_ROOT="/etc/pki/ca-trust/source/anchors" CD_CMD_CA="update-ca-trust" ;; "${CD_OS_ALPINE}") CD_CA_ROOT="/usr/local/share/ca-certificates" CD_CMD_CA="update-ca-certificates" ;; "${CD_OS_ARCH}") CD_CA_ROOT="/etc/ca-certificates/trust-source/anchors" CD_CMD_CA="update-ca-trust" ;; "${CD_OS_DEBIAN}"|"${CD_OS_UBUNTU}") CD_CA_ROOT="/usr/local/share/ca-certificates" CD_CMD_CA="update-ca-certificates" ;; esac cd_split cd_echo "CD_CA_ROOT" "CD_CMD_CA" # set package manager case "${CD_OS_ID}" in "${CD_OS_ALPINE}") CD_PM="${CD_PM_APK}" ;; "${CD_OS_DEBIAN}"|"${CD_OS_UBUNTU}") CD_PM="${CD_PM_APT}" ;; "${CD_OS_ALMA}"|"${CD_OS_FEDORA}"|"${CD_OS_ROCKY}") CD_PM="${CD_PM_DNF}" ;; "${CD_OS_ARCH}") CD_PM="${CD_PM_PACMAN}" ;; esac cd_split cd_echo "CD_PM" case "${CD_PM}" in "${CD_PM_DNF}") CD_PM_CLEAN="dnf clean all" CD_PM_INSTALL="dnf install --assumeyes" CD_PM_QUERY="rpm --query" CD_PM_UPDATE="dnf makecache" CD_PM_UPGRADE="dnf upgrade --assumeyes" CD_PKG_PKG="" CD_PM_CONF_PATH="/etc/dnf/dnf.conf" CD_PM_CONF_TEXT="\ [main] best=True clean_requirements_on_remove=True gpgcheck=1 installonly_limit=3 skip_if_unavailable=False " CD_PM_HTTPS_PATH="/etc/dnf/dnf.conf.d/https.conf" CD_PM_HTTPS_TEXT="\ sslverify=False " ;; "${CD_PM_APK}") CD_PM_CLEAN="apk cache purge" CD_PM_INSTALL="apk add" CD_PM_QUERY="apk info" CD_PM_UPDATE="apk update" CD_PM_UPGRADE="apk upgrade" CD_PKG_PKG="" CD_PM_CONF_PATH="" CD_PM_CONF_TEXT="" CD_PM_HTTPS_PATH="/etc/apk/repositories.d/https" CD_PM_HTTPS_TEXT="\ --no-verify " ;; "${CD_PM_PACMAN}") CD_PM_CLEAN="pacman --sync --clean --noconfirm" CD_PM_INSTALL="pacman --sync --noconfirm" CD_PM_QUERY="pacman --query" CD_PM_UPDATE="pacman --sync --refresh" CD_PM_UPGRADE="pacman --sync --sysupgrade --noconfirm" CD_PKG_PKG="" CD_PM_CONF_PATH="" CD_PM_CONF_TEXT="" CD_PM_HTTPS_PATH="/etc/pacman.d/https.conf" CD_PM_HTTPS_TEXT="\ SSLVerify = No " ;; "${CD_PM_APT}") CD_PM_CLEAN="apt-get clean" CD_PM_INSTALL="apt-get install --assume-yes" CD_PM_QUERY="dpkg-query --show" CD_PM_UPDATE="apt-get update" CD_PM_UPGRADE="apt-get upgrade --assume-yes" CD_PKG_PKG="apt-utils" CD_PM_CONF_PATH="/etc/apt/apt.conf.d/apt.conf" CD_PM_CONF_TEXT="\ Acquire::Check-Valid-Until True; APT::Get::Show-Versions True; APT::Install-Recommends False; APT::Install-Suggests False; Dir::Etc::SourceParts \"\"; " CD_PM_HTTPS_PATH="/etc/apt/apt.conf.d/https" CD_PM_HTTPS_TEXT="\ Acquire::https::Verify-Peer False; " ;; esac cd_split cd_echo "CD_PM_CLEAN" \ "CD_PM_INSTALL" "CD_PM_QUERY" "CD_PM_UPDATE" "CD_PM_UPGRADE" cd_split cd_echo "CD_PKG_PKG" "CD_PM_CONF_PATH" "CD_PM_HTTPS_PATH" # specific case "${CD_OS_ID}" in "${CD_OS_ALMA}") CD_URL_DEFAULT="https://repo.almalinux.org/almalinux" ;; "${CD_OS_ALPINE}") CD_URL_DEFAULT="https://dl-cdn.alpinelinux.org/alpine" ;; "${CD_OS_ARCH}") CD_URL_DEFAULT="https://geo.mirror.pkgbuild.com" ;; "${CD_OS_DEBIAN}") CD_URL_DEFAULT="http://deb.debian.org/debian" ;; "${CD_OS_FEDORA}") CD_URL_DEFAULT="http://download.example/pub/fedora/linux/releases" ;; "${CD_OS_ROCKY}") CD_URL_DEFAULT="http://dl.rockylinux.org/\$contentdir" ;; "${CD_OS_UBUNTU}") CD_URL_DEFAULT="http://archive.ubuntu.com/ubuntu" ;; esac CD_URL_CHOSEN="${CD_URL_DEFAULT}" case "${CD_OS_ID}" in "${CD_OS_ALMA}") [ "${CD_URL_ALMA}" ] && CD_URL_CHOSEN="${CD_URL_ALMA}" ;; "${CD_OS_ALPINE}") [ "${CD_URL_ALPINE}" ] && CD_URL_CHOSEN="${CD_URL_ALPINE}" ;; "${CD_OS_ARCH}") [ "${CD_URL_ARCH}" ] && CD_URL_CHOSEN="${CD_URL_ARCH}" ;; "${CD_OS_DEBIAN}") [ "${CD_URL_DEBIAN}" ] && CD_URL_CHOSEN="${CD_URL_DEBIAN}" \ || CD_URL_CHOSEN="https://deb.debian.org/debian" ;; "${CD_OS_FEDORA}") [ "${CD_URL_FEDORA}" ] && CD_URL_CHOSEN="${CD_URL_FEDORA}" \ || CD_URL_CHOSEN="https://rpmfind.net/linux/fedora/linux/releases" ;; "${CD_OS_ROCKY}") [ "${CD_URL_ROCKY}" ] && CD_URL_CHOSEN="${CD_URL_ROCKY}" \ || CD_URL_CHOSEN="https://dl.rockylinux.org/\$contentdir" ;; "${CD_OS_UBUNTU}") [ "${CD_URL_UBUNTU}" ] && CD_URL_CHOSEN="${CD_URL_UBUNTU}" \ || CD_URL_CHOSEN="https://ubuntu.mirrors.ovh.net/ubuntu" ;; esac cd_split cd_echo "CD_URL_DEFAULT" "CD_URL_CHOSEN" # set python command & package case "${CD_OS_ID}" in "${CD_OS_ALMA}"|"${CD_OS_ROCKY}") CD_PYTHON_COMMAND="python3.11" CD_PYTHON_PACKAGE="python3.11" ;; "${CD_OS_ALPINE}") CD_PYTHON_COMMAND="python3.11" CD_PYTHON_PACKAGE="python3" ;; "${CD_OS_ARCH}") CD_PYTHON_COMMAND="python3.12" CD_PYTHON_PACKAGE="python" ;; "${CD_OS_DEBIAN}") case "${CD_OS_VERSION}" in "bookworm") CD_PYTHON_COMMAND="python3.11" ;; "bullseye") CD_PYTHON_COMMAND="python3.9" ;; esac CD_PYTHON_PACKAGE="python3" ;; "${CD_OS_FEDORA}") CD_PYTHON_COMMAND="python3.12" CD_PYTHON_PACKAGE="python3" ;; "${CD_OS_UBUNTU}") case "${CD_OS_VERSION}" in "noble") CD_PYTHON_COMMAND="python3.12" ;; "jammy") CD_PYTHON_COMMAND="python3.10" ;; esac CD_PYTHON_PACKAGE="python3" ;; esac # set python packages case "${CD_OS_ID}" in "${CD_OS_ALMA}"|"${CD_OS_FEDORA}"|"${CD_OS_ROCKY}") CD_PYTHON_PACKAGES="/usr/lib64/${CD_PYTHON_COMMAND}/site-packages" ;; "${CD_OS_ALPINE}"|"${CD_OS_ARCH}") CD_PYTHON_PACKAGES="/usr/lib/${CD_PYTHON_COMMAND}/site-packages" ;; "${CD_OS_DEBIAN}"|"${CD_OS_UBUNTU}") CD_PYTHON_PACKAGES="/usr/lib/${CD_PYTHON_ALIAS}/dist-packages" ;; esac cd_split cd_echo "CD_PYTHON_COMMAND" "CD_PYTHON_PACKAGE" "CD_PYTHON_PACKAGES" # variables [ "${CD_CA_1}" ] && CD_CA=true # continuous integration platform if [ "${GITHUB_ACTIONS}" ] ; then # github → gitea → forgejo CD_SERVER_URL="${GITHUB_SERVER_URL}" CD_PROJECTS_GROUP="$(dirname "${GITHUB_REPOSITORY}")" CD_PROJECT_NAME="$(basename "${GITHUB_REPOSITORY}")" CD_PROJECT_BRANCH="${GITHUB_REF_NAME}" elif [ "${GITLAB_CI}" ] ; then # gitlab CD_SERVER_URL="${CI_SERVER_URL}" CD_PROJECTS_GROUP="$(dirname "${CI_PROJECT_PATH}")" CD_PROJECT_NAME="$(basename "${CI_PROJECT_PATH}")" CD_PROJECT_BRANCH="${CI_COMMIT_BRANCH}" else # unsupported cd_error_ci "ø" fi [ "${CD_SERVER_URL}" ] || cd_error_ci "CD_SERVER_URL" [ "${CD_PROJECTS_GROUP}" ] || cd_error_ci "CD_PROJECTS_GROUP" [ "${CD_PROJECT_NAME}" ] || cd_error_ci "CD_PROJECT_NAME" [ "${CD_PROJECT_BRANCH}" ] || cd_error_ci "CD_PROJECT_BRANCH" # CD_PROJECTS_URL="${CD_SERVER_URL}/${CD_PROJECTS_GROUP}" CD_PROJECT_URL="${CD_PROJECTS_URL}/${CD_PROJECT_NAME}" # cd_split cd_echo "CD_CA" cd_split cd_echo "CD_SERVER_URL" \ "CD_PROJECTS_GROUP" "CD_PROJECT_NAME" "CD_PROJECT_BRANCH" cd_split cd_echo "CD_PROJECTS_URL" "CD_PROJECT_URL" # TODO move to Python case "${CD_PM}" in "${CD_PM_APK}"|"${CD_PM_APT}") CD_PKG_SSH="openssh-client" ;; "${CD_PM_DNF}") CD_PKG_SSH="openssh-clients" ;; "${CD_PM_PACMAN}") CD_PKG_SSH="openssh" ;; esac } cd_set_packages_repositories () { cd_step "Set packages repositories" case "${CD_OS_ID}" in "${CD_OS_ALMA}") case "${CD_OS_VERSION}" in "8") \ cd_set_packages_repositories__file="/etc/yum.repos.d/almalinux.repo" ;; "9") \ cd_set_packages_repositories__file="/etc/yum.repos.d/almalinux-baseos.repo" ;; esac cd_sed "${cd_set_packages_repositories__file}" \ "|^mirrorlist|# mirrorlist|" \ "|${CD_URL_DEFAULT}|${CD_URL_CHOSEN}|" \ "|^# baseurl|baseurl|" ;; "${CD_OS_ALPINE}") cd_set_packages_repositories__file="/etc/apk/repositories" cd_write "${cd_set_packages_repositories__file}" "\ ${CD_URL_CHOSEN}/v${CD_OS_VERSION}/main ${CD_URL_CHOSEN}/v${CD_OS_VERSION}/community " ;; "${CD_OS_DEBIAN}") cd_set_packages_repositories__file="/etc/apt/sources.list" cd_write "${cd_set_packages_repositories__file}" "\ deb ${CD_URL_CHOSEN} ${CD_OS_VERSION} main deb ${CD_URL_CHOSEN} ${CD_OS_VERSION}-backports main deb ${CD_URL_CHOSEN} ${CD_OS_VERSION}-updates main deb ${CD_URL_CHOSEN}-security ${CD_OS_VERSION}-security main " ;; "${CD_OS_ROCKY}") case "${CD_OS_VERSION}" in "8") \ cd_set_packages_repositories__file="/etc/yum.repos.d/Rocky-BaseOS.repo" ;; "9") \ cd_set_packages_repositories__file="/etc/yum.repos.d/rocky.repo" ;; esac cd_sed "${cd_set_packages_repositories__file}" \ "|^mirrorlist|# mirrorlist|" \ "|${CD_URL_DEFAULT}|${CD_URL_CHOSEN}|" \ "|^#baseurl|baseurl|" ;; "${CD_OS_UBUNTU}") cd_set_packages_repositories__file="/etc/apt/sources.list" cd_write "${cd_set_packages_repositories__file}" "\ deb ${CD_URL_CHOSEN} ${CD_OS_VERSION} main deb ${CD_URL_CHOSEN} ${CD_OS_VERSION}-backports main deb ${CD_URL_CHOSEN} ${CD_OS_VERSION}-updates main deb ${CD_URL_CHOSEN} ${CD_OS_VERSION}-security main " ;; esac } cd_set_packages_configuration () { cd_step "Set packages configuration" cd_write "${CD_PM_CONF_PATH}" "${CD_PM_CONF_TEXT}" case "${CD_OS_ID}" in "${CD_OS_DEBIAN}"|"${CD_OS_UBUNTU}") export DEBIAN_FRONTEND="noninteractive" ;; esac } # agnostic steps cd_list_working_directory () { cd_step "List working directory" cd_ls "$(realpath .)" } cd_set_https_verification_off () { if [ "${CD_CA}" ] || [ "${CD_PM}" = "${CD_PM_APT}" ] ; then cd_step "Set HTTPS verification off" cd_mkdir "$(dirname "${CD_PM_HTTPS_PATH}")" cd_write "${CD_PM_HTTPS_PATH}" "${CD_PM_HTTPS_TEXT}" fi } cd_set_dns_resolving () { cd_step "Set DNS resolving" for cd_set_dns_resolving__server in ${CD_DNS} ; do cd_set_dns_resolving__text="${cd_set_dns_resolving__text}\ nameserver ${cd_set_dns_resolving__server} " done cd_write "${CD_DNS_FILE}" "${cd_set_dns_resolving__text}" } cd_update_packages_catalog () { cd_step "Update packages catalog" ${CD_PM_UPDATE} || exit } cd_install_packages_tools () { cd_step "Install packages tools" cd_install_package "${CD_PKG_PKG}" } cd_install_ca_certificates () { cd_step "Install CA" cd_install_package "${CD_PKG_CA}" } cd_write_ca_certificates () { cd_step "Write CA certificates" cd_mkdir "${CD_CA_ROOT}" cd_write_ca_certificates__index=1 eval "cd_write_ca_certificates__text=\ \"\${CD_CA_${cd_write_ca_certificates__index}}\"" while [ "${cd_write_ca_certificates__text}" ] ; do cd_write_ca_certificates__path="\ ${CD_CA_ROOT}/${cd_write_ca_certificates__index}.crt" cd_split cd_write \ "${cd_write_ca_certificates__path}" \ "${cd_write_ca_certificates__text}" cd_openssl "${cd_write_ca_certificates__path}" cd_write_ca_certificates__index=$((cd_write_ca_certificates__index+1)) eval "cd_write_ca_certificates__text=\ \"\${CD_CA_${cd_write_ca_certificates__index}}\"" done } cd_update_ca_certificates () { cd_step "Update CA certificates" ${CD_CMD_CA} || exit } cd_set_https_verification_on () { cd_step "Set HTTPS verification on" cd_rm "${CD_PM_HTTPS_PATH}" } cd_upgrade_packages () { cd_step "Upgrade packages" ${CD_PM_UPGRADE} || exit } cd_install_git () { cd_step "Install Git" cd_install_package "${CD_PKG_GIT}" } cd_install_python () { cd_step "Install Python" cd_install_package "${CD_PYTHON_PACKAGE}" cd_split cd_ln_python "${CD_PYTHON_COMMAND}" } # TODO move to Python cd_install_rsync () { cd_step "Install Rsync" cd_install_package "${CD_PKG_RSYNC}" } # TODO move to Python cd_install_ssh () { cd_step "Install SSH" cd_install_package "${CD_PKG_SSH}" } cd_clean_packages_cache () { cd_step "Clean packages cache" ${CD_PM_CLEAN} || exit } cd_install_python_modules () { cd_step "Install Python modules" cd_install_python_modules__root="$(mktemp --directory)" || exit echo "→ ${cd_install_python_modules__root}" for cd_install_python_modules__repository \ in "${CD_GIT_CHILD}" "${CD_GIT_PARENT}" ; do cd_split cd_install_python_modules__url="\ ${CD_PROJECTS_URL}/${cd_install_python_modules__repository}" echo "\ ${cd_install_python_modules__url} ↓" git clone \ "${cd_install_python_modules__url}" \ "${cd_install_python_modules__root}\ /${cd_install_python_modules__repository}" \ || exit cd_install_python_modules__path="\ ${cd_install_python_modules__root}\ /${cd_install_python_modules__repository}\ /${cd_install_python_modules__repository}" echo "\ ${cd_install_python_modules__path} ↓ ${CD_PYTHON_PACKAGES}" cp --recursive \ "${cd_install_python_modules__path}" "${CD_PYTHON_PACKAGES}" \ || exit done cd_split cd_ls "${CD_PYTHON_PACKAGES}" cd_split cd_rm "${cd_install_python_modules__root}" } cd_write_python_module () { cd_step "Write Python module" cd_write "${CD_PYTHON_PACKAGES}/env.py" "\ $(cd_echo CD_OPEN CD_DOWN) $(cd_echo CD_VERT CD_SPLT) $(cd_echo CD___UP CD_SHUT) $(cd_echo CD_OS_ID CD_OS_VERSION) CD_STEP = $((CD_STEP+1)) " } cd_switch_to_python () { cd_step "Switch to Python" echo "\ ${CD_PATH} ↓ ${CD_PYTHON_PACKAGES}/${CD_GIT_CHILD}" "${CD_PYTHON_ALIAS}" -m "${CD_GIT_CHILD}" "${@}" } # functions cd_cat () { cd_cat__file="${1}" if [ "${cd_cat__file}" ] ; then cd_open "${cd_cat__file}" cat "${cd_cat__file}" || exit cd_shut "${cd_cat__file}" fi } cd_echo () { if [ "${1}" ] ; then for cd_echo__name in "${@}" ; do eval "echo ${cd_echo__name} = \\\"\${${cd_echo__name}}\\\"" done fi } cd_error_ci () { echo "× CI: ${*}" exit ${CD_ERROR_CI} } cd_error_os () { cd_error_os__variable="${1}" printf "× OS: " cd_echo "${cd_error_os__variable}" exit ${CD_ERROR_OS} } cd_grep_os () { cd_grep_os__variable="${1}" if [ "${cd_grep_os__variable}" ] ; then grep "^${cd_grep_os__variable}=" "/etc/os-release" \ | sed "s|^${cd_grep_os__variable}=||" \ | sed "s|^\"\(.*\)\"$|\1|" fi } cd_install_package () { cd_install_package__name="${1}" if [ "${cd_install_package__name}" ] ; then ${CD_PM_INSTALL} "${cd_install_package__name}" || exit fi } cd_ln_python () { cd_ln_python__command="${1}" if [ "${cd_ln_python__command}" ] ; then echo "→ ${CD_PYTHON_ALIAS} → ${cd_ln_python__command}" ln -f -s "${cd_ln_python__command}" "/usr/bin/${CD_PYTHON_ALIAS}" \ || exit fi } cd_ls () { cd_ls__path="${1}" if [ "${cd_ls__path}" ] ; then cd_open "${cd_ls__path}" ls -a -l "${cd_ls__path}" || exit cd_shut "${cd_ls__path}" fi } cd_mkdir () { cd_mkdir__path="${1}" if [ "${cd_mkdir__path}" ] ; then echo "→ ${cd_mkdir__path}" mkdir --parents "${cd_mkdir__path}" || exit fi } cd_open () { echo "${CD_OPEN}${*}" } cd_openssl () { cd_openssl__file="${1}" if [ -f "${cd_openssl__file}" ] ; then openssl x509 \ -in "${cd_openssl__file}" \ -noout -text \ || exit fi } cd_rm () { cd_rm__path="${1}" if [ -e "${cd_rm__path}" ] ; then echo "← ${cd_rm__path}" rm -r "${cd_rm__path}" || exit fi } cd_sed () { cd_sed__file="${1}" shift if [ -f "${cd_sed__file}" ] ; then cd_cat "${cd_sed__file}" for cd_sed__regex in "${@}" ; do sed --in-place "s${cd_sed__regex}g" "${cd_sed__file}" \ && cd_cat "${cd_sed__file}" \ || exit done fi } cd_shut () { echo "${CD_SHUT}${*}" } cd_split () { echo "${CD_SPLT}" } cd_step () { CD_STEP=$((CD_STEP+1)) echo "\ ${CD_DOWN} ${CD_VERT} ${CD_STEP} ${*} ${CD___UP}" } cd_write () { cd_write__file="${1}" cd_write__text="${2}" if [ "${cd_write__file}" ] ; then [ -f "${cd_write__file}" ] && cd_cat "${cd_write__file}" echo "→ ${cd_write__file}" printf "%s" "${cd_write__text}" > "${cd_write__file}" || exit cd_cat "${cd_write__file}" fi } # constants CD_BOX_DOWN="╭" CD_BOX_LEFT="╴" CD_BOX_RIGHT="╶" CD_BOX_UP="╰" CD_BOX_VERTICAL="│" CD_ERROR_CI=2 CD_ERROR_OS=1 CD_OS_ALMA="alma" CD_OS_ALPINE="alpine" CD_OS_ARCH="arch" CD_OS_DEBIAN="debian" CD_OS_FEDORA="fedora" CD_OS_ROCKY="rocky" CD_OS_UBUNTU="ubuntu" CD_PM_APK="apk" CD_PM_APT="apt" CD_PM_DNF="dnf" CD_PM_PACMAN="pacman" CD_HORIZONTAL="────╌╌╌╌┄┄┄┄┈┈┈┈" CD_OPEN="${CD_BOX_DOWN}${CD_BOX_LEFT}" CD_DOWN="${CD_BOX_DOWN}${CD_HORIZONTAL}" CD_VERT="${CD_BOX_VERTICAL}" CD_SPLT="${CD_BOX_RIGHT}${CD_HORIZONTAL}" CD___UP="${CD_BOX_UP}${CD_HORIZONTAL}" CD_SHUT="${CD_BOX_UP}${CD_BOX_LEFT}" # run cd_main "${@}"