Commit 56704965 authored by Vitaly Lipatov's avatar Vitaly Lipatov

commit packed 3.60.8

parent 91095279
...@@ -20,7 +20,8 @@ ...@@ -20,7 +20,8 @@
PROGDIR=$(dirname "$0") PROGDIR=$(dirname "$0")
PROGNAME=$(basename "$0") PROGNAME=$(basename "$0")
[ -n "$EPMCURDIR" ] || export EPMCURDIR="$(pwd)" [ -n "$EPMCURDIR" ] || export EPMCURDIR="$(pwd)"
CMDSHELL="/usr/bin/env bash" CMDENV="/usr/bin/env"
[ -x "$CMDENV" ] && CMDSHELL="/usr/bin/env bash" || CMDSHELL="$SHELL"
# TODO: pwd for ./epm and which for epm # TODO: pwd for ./epm and which for epm
[ "$PROGDIR" = "." ] && PROGDIR="$EPMCURDIR" [ "$PROGDIR" = "." ] && PROGDIR="$EPMCURDIR"
if [ "$0" = "/dev/stdin" ] || [ "$0" = "sh" ] ; then if [ "$0" = "/dev/stdin" ] || [ "$0" = "sh" ] ; then
...@@ -33,7 +34,7 @@ SHAREDIR=$PROGDIR ...@@ -33,7 +34,7 @@ SHAREDIR=$PROGDIR
# will replaced with /etc/eepm during install # will replaced with /etc/eepm during install
CONFIGDIR=$PROGDIR/../etc CONFIGDIR=$PROGDIR/../etc
EPMVERSION="3.60.7" EPMVERSION="3.60.8"
# package, single (file), pipe, git # package, single (file), pipe, git
EPMMODE="package" EPMMODE="package"
...@@ -445,6 +446,8 @@ set_sudo() ...@@ -445,6 +446,8 @@ set_sudo()
fi fi
else else
# use sudo if one is tuned and tuned without password # use sudo if one is tuned and tuned without password
# hack: check twice
$SUDO_CMD -l -n >/dev/null 2>/dev/null
if ! $SUDO_CMD -l -n >/dev/null 2>/dev/null ; then if ! $SUDO_CMD -l -n >/dev/null 2>/dev/null ; then
[ "$nofail" = "nofail" ] || SUDO="fatal 'Can't use sudo (only passwordless sudo is supported here). Please run epm under root or check http://altlinux.org/sudo '" [ "$nofail" = "nofail" ] || SUDO="fatal 'Can't use sudo (only passwordless sudo is supported here). Please run epm under root or check http://altlinux.org/sudo '"
SUDO_TESTED="4" SUDO_TESTED="4"
...@@ -790,7 +793,7 @@ get_package_type() ...@@ -790,7 +793,7 @@ get_package_type()
return return
fi fi
# print extension by default # print extension by default
echo "$1" | sed -e 's|.*\.||' basename "$1" | sed -e 's|.*\.||'
return 1 return 1
;; ;;
esac esac
...@@ -3540,9 +3543,10 @@ epm_full_upgrade_help() ...@@ -3540,9 +3543,10 @@ epm_full_upgrade_help()
{ {
get_help HELPCMD $SHAREDIR/epm-full_upgrade get_help HELPCMD $SHAREDIR/epm-full_upgrade
cat <<EOF cat <<EOF
You can run with --interactive if you can skip some steps interactivelyю You can run with --interactive if you can skip some steps interactively.
Also you can comment out full_upgrade parts in /etc/eepm/eepm.conf config. Also you can comment out full_upgrade parts in /etc/eepm/eepm.conf config.
Examples: Examples:
epm full-upgrade [--auto]
epm full-upgrade [--interactive] epm full-upgrade [--interactive]
epm full-upgrade --no-flatpack epm full-upgrade --no-flatpack
EOF EOF
...@@ -3622,7 +3626,11 @@ confirm_action() ...@@ -3622,7 +3626,11 @@ confirm_action()
confirm_action "Upgrade packages installed via epm play? [Y/n]" || full_upgrade_no_epm_play=1 confirm_action "Upgrade packages installed via epm play? [Y/n]" || full_upgrade_no_epm_play=1
if [ -z "$full_upgrade_no_epm_play" ] ; then if [ -z "$full_upgrade_no_epm_play" ] ; then
[ -n "$quiet" ] || echo [ -n "$quiet" ] || echo
docmd epm $dryrun play --update all || fatal "updating of applications installed via epm play is failed." if [ -n "$force" ] ; then
docmd epm $dryrun play || fatal "updating of applications installed via epm play is failed."
else
docmd epm $dryrun play --update all || fatal "updating of applications installed via epm play is failed."
fi
fi fi
...@@ -5715,7 +5723,7 @@ __epm_pack_run_handler() ...@@ -5715,7 +5723,7 @@ __epm_pack_run_handler()
returntarname='' returntarname=''
local repackcode="$EPM_PACK_SCRIPTS_DIR/$packname.sh" local repackcode="$EPM_PACK_SCRIPTS_DIR/$packname.sh"
[ -x "$repackcode" ] || return [ -s "$repackcode" ] || return
[ -f "$repackcode.rpmnew" ] && warning "There is .rpmnew file(s) in $EPM_PACK_SCRIPTS_DIR dir. The pack script can be outdated." [ -f "$repackcode.rpmnew" ] && warning "There is .rpmnew file(s) in $EPM_PACK_SCRIPTS_DIR dir. The pack script can be outdated."
# a file to keep filename of generated tarball # a file to keep filename of generated tarball
...@@ -6076,7 +6084,7 @@ __is_app_installed() ...@@ -6076,7 +6084,7 @@ __is_app_installed()
__run_script() __run_script()
{ {
local script="$psdir/$1.sh" local script="$psdir/$1.sh"
[ -x "$script" ] || return [ -s "$script" ] || return
[ -f "$script.rpmnew" ] && warning "There is .rpmnew file(s) in $psdir dir. The play script can be outdated." [ -f "$script.rpmnew" ] && warning "There is .rpmnew file(s) in $psdir dir. The play script can be outdated."
shift shift
...@@ -6177,7 +6185,7 @@ __check_play_script() ...@@ -6177,7 +6185,7 @@ __check_play_script()
local script="$psdir/$1.sh" local script="$psdir/$1.sh"
shift shift
[ -x "$script" ] [ -s "$script" ]
} }
...@@ -10732,29 +10740,31 @@ epm_requires_files() ...@@ -10732,29 +10740,31 @@ epm_requires_files()
local pkg_files="$*" local pkg_files="$*"
[ -n "$pkg_files" ] || return [ -n "$pkg_files" ] || return
# TODO: handle separately local fl
local PKGTYPE="$(get_package_type $pkg_files)" for fl in $pkg_files ; do
local PKGTYPE="$(get_package_type $fl)"
case "$PKGTYPE" in case "$PKGTYPE" in
rpm) rpm)
assure_exists rpm >/dev/null assure_exists rpm >/dev/null
__epm_alt_rpm_requires -p $pkg_files __epm_alt_rpm_requires -p $fl
;; ;;
deb) deb)
assure_exists dpkg >/dev/null assure_exists dpkg >/dev/null
a='' docmd dpkg -I $pkg_files | grep "^ *Depends:" | sed "s|^ *Depends:||g" a='' docmd dpkg -I $fl | grep "^ *Depends:" | sed "s|^ *Depends:||g"
;; ;;
eopkg) eopkg)
showcmd eopkg info $pkg_files showcmd eopkg info $fl
LC_ALL=C eopkg info $pkg_files | grep "^Dependencies" | head -n1 | sed -e "s|Dependencies[[:space:]]*: ||" LC_ALL=C eopkg info $fl | grep "^Dependencies" | head -n1 | sed -e "s|Dependencies[[:space:]]*: ||"
;; ;;
ELF) ELF)
__epm_elf_requires $pkg_files __epm_elf_requires $fl
;; ;;
*) *)
fatal "Have no suitable command for $PKGTYPE" warning "Have no suitable command for handle file $fl with .$PKGTYPE"
;; ;;
esac esac
done
} }
epm_requires_names() epm_requires_names()
...@@ -11540,10 +11550,10 @@ case $PMTYPE in ...@@ -11540,10 +11550,10 @@ case $PMTYPE in
CMD="eopkg search --" CMD="eopkg search --"
;; ;;
yum-rpm) yum-rpm)
CMD="yum search --" CMD="yum search"
;; ;;
dnf-rpm) dnf-rpm)
CMD="dnf search --" CMD="dnf search"
;; ;;
zypper-rpm) zypper-rpm)
CMD="zypper search -d --" CMD="zypper search -d --"
...@@ -11745,7 +11755,7 @@ __alt_local_content_search() ...@@ -11745,7 +11755,7 @@ __alt_local_content_search()
update_repo_if_needed update_repo_if_needed
if [ ! -s "$ALT_CONTENTS_INDEX_LIST" ] ; then if [ ! -s "$ALT_CONTENTS_INDEX_LIST" ] ; then
fatal "Have no local contents index. Check epm repo --help." fatal "There was some error in contents index retrieving. Try run 'epm update' again."
fi fi
local CI="$(cat $ALT_CONTENTS_INDEX_LIST)" local CI="$(cat $ALT_CONTENTS_INDEX_LIST)"
...@@ -11897,10 +11907,13 @@ rsync_alt_contents_index() ...@@ -11897,10 +11907,13 @@ rsync_alt_contents_index()
__rsync_check "$URL" || return __rsync_check "$URL" || return
mkdir -p "$(dirname "$TD")" mkdir -p "$(dirname "$TD")"
[ -n "$USER" ] && sudorun chown -R $USER "$TD"
if [ -z "$quiet" ] ; then if [ -z "$quiet" ] ; then
docmd rsync --partial --inplace $3 -a --progress "$URL" "$TD" docmd rsync --partial --inplace $3 -a "$URL" "$TD"
else else
a= rsync --partial --inplace $3 -a --progress "$URL" "$TD" >/dev/null a= rsync --partial --inplace $3 -a "$URL" "$TD"
fi fi
res=$? res=$?
[ -f "$TD" ] && sudorun chmod a+rw "$TD" [ -f "$TD" ] && sudorun chmod a+rw "$TD"
...@@ -13664,7 +13677,8 @@ if distro os-release ; then ...@@ -13664,7 +13677,8 @@ if distro os-release ; then
ubuntu|reld|rhel|astra|manjaro) ubuntu|reld|rhel|astra|manjaro)
;; ;;
*) *)
[ -n "$ID_LIKE" ] && VENDOR_ID="$(echo "$ID_LIKE" | cut -d" " -f1)" # ID_LIKE can be 'rhel centos fedora', use latest word
[ -n "$ID_LIKE" ] && VENDOR_ID="$(echo "$ID_LIKE" | xargs -n1 | tail -n1)"
;; ;;
esac esac
DISTRIB_FULL_RELEASE="$DISTRIB_RELEASE" DISTRIB_FULL_RELEASE="$DISTRIB_RELEASE"
...@@ -13890,7 +13904,8 @@ elif [ "$(uname)" = "Linux" ] && is_command guix ; then ...@@ -13890,7 +13904,8 @@ elif [ "$(uname)" = "Linux" ] && is_command guix ; then
# fixme: move to up # fixme: move to up
elif [ "$(uname)" = "Linux" ] && [ -x $ROOTDIR/system/bin/getprop ] ; then elif [ "$(uname)" = "Linux" ] && [ -x $ROOTDIR/system/bin/getprop ] ; then
DISTRIB_ID="Android" DISTRIB_ID="Android"
DISTRIB_RELEASE=$(getprop | awk -F": " '/build.version.release/ { print $2 }' | tr -d '[]') DISTRIB_RELEASE=$(getprop | awk -F": " '/system.build.version.release\]/ { print $2 }' | tr -d '[]' | head -n1)
[ -n "$DISTRIB_RELEASE" ] || DISTRIB_RELEASE=$(getprop | awk -F": " '/build.version.release/ { print $2 }' | tr -d '[]' | head -n1)
elif [ "$(uname -o 2>/dev/null)" = "Cygwin" ] ; then elif [ "$(uname -o 2>/dev/null)" = "Cygwin" ] ; then
DISTRIB_ID="Cygwin" DISTRIB_ID="Cygwin"
...@@ -14136,7 +14151,7 @@ get_virt() ...@@ -14136,7 +14151,7 @@ get_virt()
fi fi
# use util-linux # use util-linux
if LC_ALL=C a= lscpu | grep "Hypervisor vendor:" | grep -q "KVM" ; then if LC_ALL=C a= lscpu 2>/dev/null | grep "Hypervisor vendor:" | grep -q "KVM" ; then
echo "kvm" && return echo "kvm" && return
fi fi
...@@ -17475,6 +17490,9 @@ check_filenames() ...@@ -17475,6 +17490,9 @@ check_filenames()
elif is_url "$opt" ; then elif is_url "$opt" ; then
has_space "$opt" && warning "There are space(s) in URL '$opt', it is not supported. Skipped" && continue has_space "$opt" && warning "There are space(s) in URL '$opt', it is not supported. Skipped" && continue
[ -n "$pkg_urls" ] && pkg_urls="$pkg_urls $opt" || pkg_urls="$opt" [ -n "$pkg_urls" ] && pkg_urls="$pkg_urls $opt" || pkg_urls="$opt"
elif echo "$opt" | grep -q "[/]" ; then
has_space "$opt" && warning "There are space(s) in filename '$opt', it is not supported. Skipped" && continue
[ -n "$pkg_files" ] && pkg_files="$pkg_files $opt" || pkg_files="$opt"
else else
has_space "$opt" && warning "There are space(s) in package name '$opt', it is not supported. Skipped." && continue has_space "$opt" && warning "There are space(s) in package name '$opt', it is not supported. Skipped." && continue
echo "$opt" | grep -q "[*]" && warning "There are forbidden symbols in package name '$opt'. Skipped." && continue echo "$opt" | grep -q "[*]" && warning "There are forbidden symbols in package name '$opt'. Skipped." && continue
......
...@@ -33,7 +33,7 @@ SHAREDIR=$PROGDIR ...@@ -33,7 +33,7 @@ SHAREDIR=$PROGDIR
# will replaced with /etc/eepm during install # will replaced with /etc/eepm during install
CONFIGDIR=$PROGDIR/../etc CONFIGDIR=$PROGDIR/../etc
EPMVERSION="3.60.7" EPMVERSION="3.60.8"
# package, single (file), pipe, git # package, single (file), pipe, git
EPMMODE="package" EPMMODE="package"
...@@ -446,6 +446,8 @@ set_sudo() ...@@ -446,6 +446,8 @@ set_sudo()
fi fi
else else
# use sudo if one is tuned and tuned without password # use sudo if one is tuned and tuned without password
# hack: check twice
$SUDO_CMD -l -n >/dev/null 2>/dev/null
if ! $SUDO_CMD -l -n >/dev/null 2>/dev/null ; then if ! $SUDO_CMD -l -n >/dev/null 2>/dev/null ; then
[ "$nofail" = "nofail" ] || SUDO="fatal 'Can't use sudo (only passwordless sudo is supported here). Please run epm under root or check http://altlinux.org/sudo '" [ "$nofail" = "nofail" ] || SUDO="fatal 'Can't use sudo (only passwordless sudo is supported here). Please run epm under root or check http://altlinux.org/sudo '"
SUDO_TESTED="4" SUDO_TESTED="4"
...@@ -791,7 +793,7 @@ get_package_type() ...@@ -791,7 +793,7 @@ get_package_type()
return return
fi fi
# print extension by default # print extension by default
echo "$1" | sed -e 's|.*\.||' basename "$1" | sed -e 's|.*\.||'
return 1 return 1
;; ;;
esac esac
...@@ -2102,7 +2104,8 @@ if distro os-release ; then ...@@ -2102,7 +2104,8 @@ if distro os-release ; then
ubuntu|reld|rhel|astra|manjaro) ubuntu|reld|rhel|astra|manjaro)
;; ;;
*) *)
[ -n "$ID_LIKE" ] && VENDOR_ID="$(echo "$ID_LIKE" | cut -d" " -f1)" # ID_LIKE can be 'rhel centos fedora', use latest word
[ -n "$ID_LIKE" ] && VENDOR_ID="$(echo "$ID_LIKE" | xargs -n1 | tail -n1)"
;; ;;
esac esac
DISTRIB_FULL_RELEASE="$DISTRIB_RELEASE" DISTRIB_FULL_RELEASE="$DISTRIB_RELEASE"
...@@ -2328,7 +2331,8 @@ elif [ "$(uname)" = "Linux" ] && is_command guix ; then ...@@ -2328,7 +2331,8 @@ elif [ "$(uname)" = "Linux" ] && is_command guix ; then
# fixme: move to up # fixme: move to up
elif [ "$(uname)" = "Linux" ] && [ -x $ROOTDIR/system/bin/getprop ] ; then elif [ "$(uname)" = "Linux" ] && [ -x $ROOTDIR/system/bin/getprop ] ; then
DISTRIB_ID="Android" DISTRIB_ID="Android"
DISTRIB_RELEASE=$(getprop | awk -F": " '/build.version.release/ { print $2 }' | tr -d '[]') DISTRIB_RELEASE=$(getprop | awk -F": " '/system.build.version.release\]/ { print $2 }' | tr -d '[]' | head -n1)
[ -n "$DISTRIB_RELEASE" ] || DISTRIB_RELEASE=$(getprop | awk -F": " '/build.version.release/ { print $2 }' | tr -d '[]' | head -n1)
elif [ "$(uname -o 2>/dev/null)" = "Cygwin" ] ; then elif [ "$(uname -o 2>/dev/null)" = "Cygwin" ] ; then
DISTRIB_ID="Cygwin" DISTRIB_ID="Cygwin"
...@@ -2574,7 +2578,7 @@ get_virt() ...@@ -2574,7 +2578,7 @@ get_virt()
fi fi
# use util-linux # use util-linux
if LC_ALL=C a= lscpu | grep "Hypervisor vendor:" | grep -q "KVM" ; then if LC_ALL=C a= lscpu 2>/dev/null | grep "Hypervisor vendor:" | grep -q "KVM" ; then
echo "kvm" && return echo "kvm" && return
fi fi
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment