2012-05-18 20:27:25 +04:00
|
|
|
#!/bin/bash
|
|
|
|
|
2012-08-09 18:23:28 +04:00
|
|
|
STAGE=0
|
2012-08-17 11:08:15 +04:00
|
|
|
NICE_CMD="nice -n 19 ionice -c2"
|
2013-01-13 16:26:42 +04:00
|
|
|
let QUIET=0
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2013-01-20 23:18:26 +04:00
|
|
|
[ -f /etc/make.conf ] && source /etc/make.conf
|
|
|
|
[ -f /etc/portage/make.conf ] && source /etc/portage/make.conf
|
2012-05-18 20:27:25 +04:00
|
|
|
[ -f /etc/gentoo-upgrade.conf ] && source /etc/gentoo-upgrade.conf
|
|
|
|
|
|
|
|
# available parameters
|
2013-01-13 16:26:42 +04:00
|
|
|
eval set -- "`getopt -o hs:q --long help,stage:,quiet -- \"$@\"`"
|
2012-05-18 20:27:25 +04:00
|
|
|
|
|
|
|
while true ; do
|
|
|
|
case "$1" in
|
|
|
|
-h|--help)
|
|
|
|
echo "Usage: upgrade-gentoo.sh [keys]..."
|
|
|
|
echo "Keys:"
|
|
|
|
echo -e "-h, --help\t\t\tShow this help and exit."
|
2013-01-13 16:26:42 +04:00
|
|
|
echo -e "-s [STAGE], --stage [STAGE]\tGo to STAGE upgrade level."
|
|
|
|
echo -e "-q, --quiet\t\t\tMake kernel configuration non-interactive."
|
2012-05-18 20:27:25 +04:00
|
|
|
echo
|
|
|
|
echo -e "This program works on any GNU/Linux with GNU Baurne's shell"
|
|
|
|
echo -e "Report bugs to <mecareful@gmail.com>"
|
|
|
|
exit 0
|
|
|
|
;;
|
|
|
|
-s|--stage) STAGE=$2 ; shift 2 ;;
|
2013-01-13 16:26:42 +04:00
|
|
|
-q|--quiet) let QUIET=1 ; shift ;;
|
|
|
|
--) shift ; break ;;
|
|
|
|
*) echo "Internal error!" ; exit -1 ;;
|
2012-05-18 20:27:25 +04:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
function in_list()
|
|
|
|
{
|
|
|
|
[ -z "$1" ] && return 1
|
|
|
|
|
|
|
|
elem=$1
|
|
|
|
shift 1
|
|
|
|
list=($@)
|
|
|
|
|
|
|
|
for i in ${list[@]}; do
|
|
|
|
[ $i == $elem ] && return 0
|
|
|
|
done
|
|
|
|
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
|
|
|
TRUE_LIST=(TRUE True true YES Yes yes 1)
|
|
|
|
FALSE_LIST=(FALSE False false NO No no 0)
|
2012-10-10 20:50:19 +04:00
|
|
|
STAGE_CNT=0
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# remounting file systems ro->rw
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-08-09 18:23:28 +04:00
|
|
|
echo "======= STAGE $STAGE: remounting file systems ro->rw ======="
|
|
|
|
for fs in $RW_REMOUNT; do
|
2012-08-17 11:46:40 +04:00
|
|
|
echo "remounting $fs -> rw"
|
2012-08-09 18:23:28 +04:00
|
|
|
mount -o remount,rw $fs
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: mount -o remount,rw $fs failed ;-( =======" && exit $STAGE
|
|
|
|
done
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-08-09 18:23:28 +04:00
|
|
|
|
2012-10-10 20:58:04 +04:00
|
|
|
# Pull portage config changes
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-10-13 23:00:01 +04:00
|
|
|
if [ -d /etc/portage/.git ]; then
|
|
|
|
echo "======= STAGE $STAGE: pull portage config changes ======="
|
2012-10-22 08:55:27 +04:00
|
|
|
cd /etc/portage && git pull origin `git rev-parse --abbrev-ref HEAD`
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cd /etc/portage && git pull origin `git rev-parse --abbrev-ref HEAD` failed ;-( =======" && exit $STAGE
|
2012-10-13 23:00:01 +04:00
|
|
|
fi
|
2012-10-10 20:58:04 +04:00
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
|
|
|
|
2012-10-10 21:26:48 +04:00
|
|
|
# Update gentoo-upgrade script
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
|
|
|
echo "======= STAGE $STAGE: Updating gentoo-upgrade script ======="
|
|
|
|
if [ `which smart-live-rebuild 2>/dev/null` ]; then
|
2015-05-20 11:07:02 +03:00
|
|
|
$NICE_CMD smart-live-rebuild -ET16 -f app-admin/gentoo-upgrade
|
2012-10-10 21:26:48 +04:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: Updating gentoo-upgrade script failed ;-( =======" && exit $STAGE
|
|
|
|
fi
|
|
|
|
|
2012-12-18 17:43:26 +04:00
|
|
|
exec $0 -s $((STAGE+1))
|
|
|
|
|
|
|
|
echo "Stage $STAGE: Bash translator in unreachable code ;-(" && exit $STAGE
|
|
|
|
|
2012-10-10 21:26:48 +04:00
|
|
|
let STAGE++
|
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
2012-10-10 20:58:04 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# sync portage tree
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: sync portage tree ======="
|
|
|
|
SYNC_TYPE=
|
|
|
|
expr match "$SYNC" "git://" >/dev/null && SYNC_TYPE=git
|
|
|
|
expr match "$SYNC" "rsync://" >/dev/null && SYNC_TYPE=rsync
|
|
|
|
if [[ "rsync" == "$SYNC_TYPE" && 0 -ne `expr match "$PORTAGE_RSYNC_EXTRA_OPTS" ".*rsync.excludes"` ]]; then
|
|
|
|
# generate portage exclude list
|
|
|
|
RSYNC_EXCLUDES_FILE=/etc/portage/rsync.excludes
|
|
|
|
echo "Generating $RSYNC_EXCLUDES_FILE list..."
|
|
|
|
ninstalled=0
|
|
|
|
installed=
|
|
|
|
for p in `qlist -IC`; do
|
|
|
|
installed[ninstalled]=$p
|
|
|
|
let ninstalled++
|
|
|
|
done
|
|
|
|
|
|
|
|
idx=0
|
|
|
|
cd /usr/portage/
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: /usr/portage/ does not exist ;-( =======" && exit $STAGE
|
|
|
|
|
|
|
|
echo -n >$RSYNC_EXCLUDES_FILE
|
|
|
|
dir_list=`ls -1 --color=never -d *-*/ virtual/ | sed 's~/$~~' | sort`
|
|
|
|
for d in $dir_list ; do
|
|
|
|
d=${d%/}
|
|
|
|
if [[ `qlist -IC $d | wc -l` == 0 ]]; then
|
|
|
|
echo $d/ >>$RSYNC_EXCLUDES_FILE
|
|
|
|
echo metadata/cache/$d/ >>$RSYNC_EXCLUDES_FILE
|
|
|
|
else
|
|
|
|
pn_list=`ls -1 --color=never -d ${d}/*/ | sed 's~/$~~' | sort`
|
|
|
|
for pn in $pn_list; do
|
|
|
|
pn=${pn%/}
|
|
|
|
|
|
|
|
while [[ "${installed[$idx]}" < "$pn" && $idx -lt $ninstalled ]]; do
|
|
|
|
let idx++
|
|
|
|
done
|
|
|
|
|
|
|
|
if [[ "$pn" == "${installed[$idx]}" ]]; then
|
|
|
|
let idx++
|
|
|
|
else
|
|
|
|
echo $pn/ >>$RSYNC_EXCLUDES_FILE
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
2014-02-13 10:53:25 +04:00
|
|
|
# /etc/eix-sync.conf:* and we don't need to call layman manually
|
|
|
|
## layman syncronization
|
|
|
|
#if [ `which layman 2>/dev/null` ]; then
|
|
|
|
# $NICE_CMD layman -S
|
|
|
|
# [ 0 -ne $? ] && echo "Stage $STAGE: layman synchronization failed ;-( =======" && exit $STAGE
|
|
|
|
#fi
|
2012-11-25 12:06:56 +04:00
|
|
|
|
2014-02-11 16:26:05 +04:00
|
|
|
# sync portage tree
|
|
|
|
$NICE_CMD eix-sync || $NICE_CMD emerge --sync
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: portage tree synchronization failed ;-( =======" && exit $STAGE
|
2012-05-18 20:27:25 +04:00
|
|
|
|
|
|
|
# Update metadata cache
|
|
|
|
in_list "$EGENCACHE" ${TRUE_LIST[@]} &&
|
|
|
|
if [[ "git" == "$SYNC_TYPE" ]]; then
|
|
|
|
echo "---------- Updating metadata cache for Git portage tree ----------"
|
2013-01-10 13:49:27 +04:00
|
|
|
$NICE_CMD egencache --repo=gentoo --update --jobs=$((`getconf _NPROCESSORS_ONLN`+1))
|
2014-02-11 16:26:05 +04:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: Metadata update failed ;-( =======" && exit $STAGE
|
|
|
|
fi
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2014-02-11 16:26:05 +04:00
|
|
|
# clear exclude list
|
|
|
|
if [ "rsync" == "$SYNC_TYPE" ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo -n > /etc/portage/rsync.excludes
|
2014-02-11 16:26:05 +04:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: failed to clear /etc/portage/rsync.excludes ;-( =======" && exit $STAGE
|
2012-05-18 20:27:25 +04:00
|
|
|
fi
|
|
|
|
|
2014-02-11 16:26:05 +04:00
|
|
|
# eix-remote update
|
|
|
|
if [ `which eix-remote 2>/dev/null` ]; then
|
2017-01-17 14:32:13 +03:00
|
|
|
$NICE_CMD eix-remote update
|
2014-10-28 15:33:09 +03:00
|
|
|
# Don't check command status as gpo.zugaina.org sometimes gets broken archive for a long time
|
|
|
|
# [ 0 -ne $? ] && echo "Stage $STAGE: 1'st eix-remote update failed ;-( =======" && exit $STAGE
|
2014-02-11 16:26:05 +04:00
|
|
|
fi
|
2013-01-14 11:24:42 +04:00
|
|
|
|
2014-02-11 16:26:05 +04:00
|
|
|
# remind to upgrade Xorg input drivers
|
|
|
|
tmp=`qlist -IC x11-base/xorg-server`
|
|
|
|
if [ "" != "$tmp" ]; then
|
|
|
|
if [ "0" -ne "`emerge -uNp x11-base/xorg-server 2>&1 | grep '^\[' | wc -l`" ]; then
|
|
|
|
touch /etc/portage/need_upgrade_xorg_input_drivers
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cann't touch /etc/portage/need_upgrade_xorg_input_drivers ;-( =======" && exit $STAGE
|
|
|
|
fi
|
|
|
|
fi
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2014-02-11 16:26:05 +04:00
|
|
|
let STAGE++
|
2013-03-09 09:52:49 +04:00
|
|
|
|
|
|
|
# recreate portage squashfs files
|
|
|
|
if [[ -x /etc/init.d/squash_portage && "" != "`mount | grep '^aufs' | grep $PORTDIR`" ]]; then
|
|
|
|
/etc/init.d/squash_portage restart
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cann't restart squash_portage ;-( =======" && exit $STAGE
|
|
|
|
fi
|
2017-02-05 06:32:50 +03:00
|
|
|
|
|
|
|
# recreate layman squashfs files
|
|
|
|
if [[ -x /etc/init.d/squash_layman && "" != "`mount | grep '^aufs' | grep $PORTDIR`" ]]; then
|
|
|
|
/etc/init.d/squash_layman restart
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cann't restart squash_layman ;-( =======" && exit $STAGE
|
|
|
|
fi
|
2012-05-18 20:27:25 +04:00
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# upgrading portage package
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: upgrading portage package ======="
|
|
|
|
emerge -uq1v portage
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: portage package upgrading failed ;-( =======" && exit $STAGE
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# Test for necessity to upgrade toolchain packages
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: Test for necessity to upgrade toolchain packages ======="
|
2013-10-30 18:55:35 +04:00
|
|
|
gcc_config_c=`gcc-config -c | cut -d- -f5`
|
|
|
|
cur_gcc_ver=`qlist -ICve sys-devel/gcc | cut -d- -f3-5 | grep --color=never $gcc_config_c`
|
|
|
|
new_gcc_ver=`(qlist -ICve sys-devel/gcc | cut -d- -f3-5; emerge -uNp sys-devel/gcc | grep '^\[' | sed 's~.*/gcc-~~ ; s~\ .*~~' | grep --color=never -v ebuild) | sort -V | tail -n1`
|
2012-05-18 20:27:25 +04:00
|
|
|
if [[ "" != "$new_gcc_ver" && "`echo $cur_gcc_ver | sed 's~\([0-9]*\.[0-9]*\).*~\1~'`" != "`echo $new_gcc_ver | sed 's~\([0-9]*\.[0-9]*\).*~\1~'`" ]]; then
|
|
|
|
touch /etc/portage/need_toolchain_rebuild
|
2012-12-18 17:20:45 +04:00
|
|
|
touch /etc/portage/need_kernel_rebuild
|
2012-05-18 20:27:25 +04:00
|
|
|
else
|
|
|
|
if [ "`echo $cur_gcc_ver | sed 's~[0-9]*\.[0-9]*\.\([0-9]*\).*~\1~'`" != "`echo $cur_gcc_ver | sed 's~[0-9]*\.[0-9]*\.\([0-9]*\).*~\1~'`" ]; then
|
|
|
|
touch /etc/portage/need_libtool_rebuild
|
|
|
|
fi
|
|
|
|
if [ 0 -ne "`emerge -uNp sys-kernel/linux-headers 2>&1 | grep '^\[' | wc -l`" ]; then
|
|
|
|
touch /etc/portage/need_glibc_rebuild
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# Toolchain packages rebuild and possibly 1'th full toolchain rebuild
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: 1'th toolchain build ======="
|
|
|
|
|
|
|
|
if [ -f /etc/portage/need_libtool_rebuild ]; then
|
|
|
|
emerge -1vq sys-devel/libtool
|
|
|
|
rm /etc/portage/need_libtool_rebuild
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_libtool_rebuild ;-( =======" && exit $STAGE
|
|
|
|
fi
|
|
|
|
if [ -f /etc/portage/need_glibc_rebuild ]; then
|
2012-07-27 12:26:59 +04:00
|
|
|
emerge -1vq sys-kernel/linux-headers sys-libs/glibc
|
2012-05-18 20:27:25 +04:00
|
|
|
rm /etc/portage/need_glibc_rebuild
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_glibc_rebuild ;-( =======" && exit $STAGE
|
|
|
|
fi
|
|
|
|
if [ -f /etc/portage/need_toolchain_rebuild ]; then
|
|
|
|
# remove old binary packages
|
|
|
|
pkgdir=$(portageq pkgdir)
|
|
|
|
rm -rf $pkgdir
|
|
|
|
install -d -o portage -g portage -m775 $pkgdir
|
|
|
|
|
|
|
|
# first toolchain build
|
2012-12-18 13:52:26 +04:00
|
|
|
emerge -1uvq sys-kernel/linux-headers sys-libs/glibc sys-devel/binutils \
|
|
|
|
sys-devel/gcc-config sys-devel/gcc sys-devel/binutils-config sys-devel/libtool
|
2012-05-18 20:27:25 +04:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: 1'th toolchain build failed ;-( =======" && exit $STAGE
|
|
|
|
rm /etc/portage/need_toolchain_rebuild
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_toolchain_rebuild ;-( =======" && exit $STAGE
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
|
|
|
|
# skip next toolchain upgrade stages
|
|
|
|
else
|
2020-04-28 19:12:21 +03:00
|
|
|
let STAGE+=3
|
2012-05-18 20:27:25 +04:00
|
|
|
fi
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# switching gcc and binutils
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: switching gcc and binutils ======="
|
|
|
|
gcc_regex=`gcc-config -c | sed 's~[0-9]*\.[0-9]*\.[0-9]*~[0-9]*\.[0-9]*\.[0-9]*~'`
|
|
|
|
[ "" == "$gcc_regex" ] && echo "Stage $STAGE: failed to build gcc_regex ;-( =======" && exit $STAGE
|
|
|
|
binutils_regex=`binutils-config -c | sed 's~[0-9]*\.[0-9]*\.[0-9]*~[0-9]*\.[0-9]*\.[0-9]*~'`
|
|
|
|
[ "" == "$binutils_regex" ] && echo "Stage $STAGE: failed to build binutils_regex ;-( =======" && exit $STAGE
|
|
|
|
new_gcc=`gcc-config -l | cut -d" " -f3 | grep ^$gcc_regex$ | sort -V | tail -n1`
|
|
|
|
[ "" == "$gcc_regex" ] && echo "Stage $STAGE: failed to find new_gcc ;-( =======" && exit $STAGE
|
|
|
|
new_binutils=`binutils-config -l | cut -d" " -f3 | grep ^$binutils_regex$ | sort -V | tail -n1`
|
|
|
|
[ "" == "$binutils_regex" ] && echo "Stage $STAGE: failed to find new_binutils ;-( =======" && exit $STAGE
|
|
|
|
gcc-config $new_gcc
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: failed to switch gcc to $new_gcc ;-( =======" && exit $STAGE
|
|
|
|
binutils-config $new_binutils
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: failed to switch binutils to $new_binutils ;-( =======" && exit $STAGE
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# 2'nd toolchain build
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: 2'nd toolchain build ======="
|
|
|
|
source /etc/profile
|
2013-03-12 11:38:51 +04:00
|
|
|
emerge -1bv sys-libs/glibc sys-devel/binutils sys-devel/gcc sys-apps/portage
|
2012-05-18 20:27:25 +04:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: 2'nd toolchain build failed ;-( ========" && exit $STAGE
|
|
|
|
|
2020-04-28 19:12:21 +03:00
|
|
|
touch /etc/portage/need_system_rebuild
|
|
|
|
touch /etc/portage/need_world_rebuild
|
2012-05-18 20:27:25 +04:00
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2019-12-16 12:50:24 +03:00
|
|
|
# Check if we should run perl-cleaner or haskell-updater
|
2013-12-16 15:24:36 +04:00
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
|
|
|
|
|
|
|
echo 'Test and remember if we should run perl-cleaner after @system upgrade'
|
|
|
|
if [[ 0 -ne `qlist -IC dev-lang/perl | wc -l`
|
|
|
|
&& 0 -ne `emerge -uNp dev-lang/perl 2>&1 | grep '^\[' | wc -l` ]]; then
|
|
|
|
touch /etc/portage/need_upgrade_perl
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo 'Test and remember if we should run haskell-updater after @system upgrade'
|
|
|
|
if [[ 0 -ne `qlist -IC dev-lang/ghc | wc -l`
|
|
|
|
&& 0 -ne `emerge -uNp dev-lang/ghc 2>&1 | grep '^\[' | wc -l` ]]; then
|
|
|
|
touch /etc/portage/need_upgrade_haskell
|
|
|
|
fi
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
|
|
|
|
2019-12-16 12:50:24 +03:00
|
|
|
# Perl upgrade
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
|
|
|
echo "======= STAGE $STAGE: Perl upgrade ======="
|
|
|
|
|
|
|
|
if [ -f /etc/portage/need_upgrade_perl ]; then
|
2020-06-06 16:18:51 +03:00
|
|
|
emerge -uq1v perl
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: perl package upgrading failed ;-( =======" && exit $STAGE
|
2019-12-16 12:50:24 +03:00
|
|
|
echo "Running perl-cleaner..."
|
|
|
|
$NICE_CMD perl-cleaner --reallyall
|
|
|
|
[ 0 != $? ] && echo "Stage $STAGE: perl-cleaner failed ;-( =======" && exit $STAGE
|
|
|
|
rm /etc/portage/need_upgrade_perl
|
|
|
|
[ 0 != $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_upgrade_perl ;-( =======" && exit $STAGE
|
|
|
|
else
|
|
|
|
echo "------- Not need to upgrade perl -------"
|
|
|
|
fi
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
|
|
|
|
2013-12-09 15:14:07 +04:00
|
|
|
# Python upgrade
|
2012-10-10 20:50:19 +04:00
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2013-12-09 15:14:07 +04:00
|
|
|
echo "======= STAGE $STAGE: Python upgrade ======="
|
2013-01-11 12:39:54 +04:00
|
|
|
|
2013-12-09 15:14:07 +04:00
|
|
|
echo 'Test and remember if we should run python-updater after Python upgrade'
|
|
|
|
if [ 0 -ne `emerge -uNp dev-lang/python 2>&1 | grep '^\[' | wc -l` ]; then
|
|
|
|
touch /etc/portage/need_upgrade_python
|
2015-08-30 18:29:41 +03:00
|
|
|
echo '------- Upgrading Python package -------'
|
2017-01-01 00:34:28 +03:00
|
|
|
emerge -1uDNvt python
|
2015-08-30 18:29:41 +03:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: Python upgrade failed ;-( =======" && exit $STAGE
|
2013-12-09 15:14:07 +04:00
|
|
|
fi
|
2012-05-18 20:27:25 +04:00
|
|
|
|
|
|
|
available_python_list=`eselect python list | cut -d" " -f6 | grep -v ^$ | sort -rV`
|
|
|
|
[ "" == "$available_python_list" ] && echo "Stage $STAGE: empty available_python_list ;-( =======" && exit $STAGE
|
|
|
|
|
|
|
|
let ndeps=0
|
|
|
|
new_python=`echo $available_python_list | cut -d" " -f1`
|
|
|
|
|
|
|
|
for p in $available_python_list ; do
|
|
|
|
pkgname=`echo $p | sed 's~^python~python-~'`
|
2013-12-09 15:14:07 +04:00
|
|
|
pkgnamever=`qlist -ICv dev-lang/$pkgname`
|
|
|
|
let ndeps_tmp=`equery d =$pkgnamever | cut -d" " -f1 | wc -l`
|
|
|
|
[ $ndeps_tmp -gt $ndeps ] && new_python=$p && let ndeps=$ndeps_tmp
|
2012-05-18 20:27:25 +04:00
|
|
|
done
|
|
|
|
|
|
|
|
old_python=`eselect python show 2>/dev/null`
|
|
|
|
|
|
|
|
if [[ "$old_python" != "$new_python" || -f /etc/portage/need_upgrade_python ]]; then
|
|
|
|
echo "Running python-updater..."
|
|
|
|
touch /etc/portage/need_upgrade_python
|
2013-01-11 12:39:54 +04:00
|
|
|
[ 0 != $? ] && echo "Stage $STAGE: cann't touch /etc/portage/need_upgrade_python ;-( =======" && exit $STAGE
|
2016-09-02 18:40:12 +03:00
|
|
|
in_list "$PYTHON_ESELECT" ${TRUE_LIST[@]}
|
|
|
|
if [ 0 -eq $? ]; then
|
|
|
|
eselect python set $new_python
|
|
|
|
[ 0 != $? ] && echo "Stage $STAGE: cann't switch to another python version ;-( =======" && exit $STAGE
|
|
|
|
fi
|
2013-12-09 15:14:07 +04:00
|
|
|
|
2016-08-17 10:37:58 +03:00
|
|
|
if [ `which python-updater 2>/dev/null` ]; then
|
|
|
|
$NICE_CMD python-updater
|
|
|
|
[ 0 != $? ] && echo "Stage $STAGE: python-updater failed ;-( =======" && exit $STAGE
|
|
|
|
fi
|
2012-05-18 20:27:25 +04:00
|
|
|
rm /etc/portage/need_upgrade_python
|
2013-01-11 12:39:54 +04:00
|
|
|
[ 0 != $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_upgrade_python ;-( =======" && exit $STAGE
|
2012-05-18 20:27:25 +04:00
|
|
|
else
|
|
|
|
echo "------- Not need to upgrade python -------"
|
|
|
|
fi
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2013-12-09 15:14:07 +04:00
|
|
|
# @system upgrade
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
|
|
|
echo "======= STAGE $STAGE: @system upgrade ======="
|
|
|
|
|
|
|
|
echo '------- Upgrading @system packages -------'
|
2017-04-19 02:15:44 +03:00
|
|
|
emerge -1uDNvt --keep-going=y @system
|
2020-04-28 19:12:21 +03:00
|
|
|
#[ 0 -ne $? ] && echo "Stage $STAGE: @system upgrade failed ;-( =======" && exit $STAGE
|
2013-12-09 15:14:07 +04:00
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
|
|
|
|
2013-01-11 12:39:54 +04:00
|
|
|
# Haskell upgrade
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
|
|
|
echo "======= STAGE $STAGE: Haskell upgrade ======="
|
|
|
|
|
|
|
|
if [ -f /etc/portage/need_upgrade_haskell ]; then
|
|
|
|
echo "Running haskell-updater..."
|
2016-08-21 12:15:45 +03:00
|
|
|
if [ `which haskell-updater 2>/dev/null` ]; then
|
|
|
|
$NICE_CMD haskell-updater --upgrade
|
|
|
|
[ 0 != $? ] && echo "Stage $STAGE: haskell-updater --upgrade failed ;-( =======" && exit $STAGE
|
|
|
|
fi
|
2013-01-11 12:39:54 +04:00
|
|
|
rm /etc/portage/need_upgrade_haskell
|
|
|
|
[ 0 != $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_upgrade_haskell ;-( =======" && exit $STAGE
|
|
|
|
else
|
|
|
|
echo "------- Not need to upgrade Haskell -------"
|
|
|
|
fi
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# @world upgrade
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: @world upgrade ======="
|
|
|
|
echo 'Looking for necessity to upgrade @world packages...'
|
2023-01-19 04:01:07 +03:00
|
|
|
emerge -1uDNvt --backtrack=50 @world
|
2012-05-25 17:08:39 +04:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: @world upgrade failed ;-( =======" && exit $STAGE
|
2012-05-18 20:27:25 +04:00
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# Xorg server upgrades
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: Xorg server upgrades ======="
|
|
|
|
if [ -f /etc/portage/need_upgrade_xorg_input_drivers ]; then
|
|
|
|
echo '------- Upgrading Xorg input drivers -------'
|
2013-03-12 11:38:51 +04:00
|
|
|
emerge -1v @x11-module-rebuild `qlist -IC xf86-input xorg-drivers`
|
2013-01-11 12:22:23 +04:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: Xorg input drivers upgrade failed ;-( =======" && exit $STAGE
|
|
|
|
rm /etc/portage/need_upgrade_xorg_input_drivers
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_upgrade_xorg_input_drivers ;-( =======" && exit $STAGE
|
2012-05-18 20:27:25 +04:00
|
|
|
else
|
|
|
|
echo '------- No Xorg server upgrades! -------'
|
|
|
|
fi
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-11-25 00:52:51 +04:00
|
|
|
# Upgrading live packages
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2014-08-10 21:55:39 +04:00
|
|
|
if [ `which smart-live-rebuild 2>/dev/null` ]; then
|
|
|
|
echo "======= STAGE $STAGE: Upgrading live packages ======="
|
2015-05-20 11:07:02 +03:00
|
|
|
smart-live-rebuild -ET16
|
2014-08-10 21:55:39 +04:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: Upgrading live packages failed ;-( =======" && exit $STAGE
|
|
|
|
fi
|
2012-11-25 00:52:51 +04:00
|
|
|
|
2014-08-10 21:55:39 +04:00
|
|
|
let STAGE++
|
2012-11-25 00:52:51 +04:00
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# Cleaning
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: Cleaning ======="
|
|
|
|
emerge -c
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: emerge -c failed ;-( =======" && exit $STAGE
|
|
|
|
if [ `which localepurge 2>/dev/null` ]; then
|
2012-08-17 10:51:32 +04:00
|
|
|
$NICE_CMD localepurge &>/dev/null
|
2012-05-18 20:27:25 +04:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: localepurge failed ;-( =======" && exit $STAGE
|
|
|
|
fi
|
|
|
|
if [ `which eclean 2>/dev/null` ]; then
|
2012-12-03 13:50:15 +04:00
|
|
|
$NICE_CMD eclean -d packages
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: eclean -d packages failed ;-( =======" && exit $STAGE
|
2012-05-28 13:50:51 +04:00
|
|
|
|
|
|
|
in_list "$ECLEAN_DISTFILES" ${TRUE_LIST[@]}
|
|
|
|
if [ 0 -eq $? ]; then
|
2012-12-03 13:50:15 +04:00
|
|
|
$NICE_CMD eclean -d distfiles
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: eclean -d distfiles failed ;-( =======" && exit $STAGE
|
2012-05-28 13:50:51 +04:00
|
|
|
fi
|
2012-05-18 20:27:25 +04:00
|
|
|
fi
|
2018-05-29 18:46:34 +03:00
|
|
|
PORTAGE_TMPDIR=$(emerge --info --color=n | grep --color=never PORTAGE_TMPDIR | cut -d\" -f2)
|
2013-04-10 17:21:23 +04:00
|
|
|
[ -z "${PORTAGE_TMPDIR}" ] && PORTAGE_TMPDIR=/var/tmp
|
2013-04-10 17:26:41 +04:00
|
|
|
rm -rf "${PORTAGE_TMPDIR}"/portage/*
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: rm -rf "${PORTAGE_TMPDIR}"/portage/* failed ;-( =======" && exit $STAGE
|
2012-05-18 20:27:25 +04:00
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# Scan for missed shared libraries
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: Scan for old versions of shared libraries ======="
|
2013-03-12 11:38:51 +04:00
|
|
|
emerge -1v @preserved-rebuild
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: emerge -1v @preserved-rebuild failed ;-( =======" && exit $STAGE
|
2012-05-18 20:27:25 +04:00
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# Scan for vulnearable packages and try to fix them
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: Scan for vulnearable packages ======="
|
|
|
|
if [ `which glsa-check 2>/dev/null` ]; then
|
2012-08-17 10:51:32 +04:00
|
|
|
$NICE_CMD glsa-check -f affected
|
2012-05-18 20:27:25 +04:00
|
|
|
# [ 0 -ne $? ] && echo "Stage $STAGE: glsa-check fix failed ;-( =======" && exit $STAGE
|
|
|
|
fi
|
|
|
|
|
2017-04-19 02:15:44 +03:00
|
|
|
emerge -1v @security
|
2012-07-31 12:26:08 +04:00
|
|
|
|
2012-05-18 20:27:25 +04:00
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# Upgrade kernel
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: Upgrade kernel ======="
|
2012-12-18 17:20:45 +04:00
|
|
|
|
2013-01-13 16:26:42 +04:00
|
|
|
[ 1 -eq $QUIET ] && KERNEL_GETLAST_OPTS="$KERNEL_GETLAST_OPTS --quiet"
|
|
|
|
|
2012-12-18 17:20:45 +04:00
|
|
|
if [ -f /etc/portage/need_kernel_rebuild ]; then
|
2013-01-13 16:26:42 +04:00
|
|
|
kernel-getlast.sh --force-rebuild --mrproper $KERNEL_GETLAST_OPTS
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: kernel-getlast.sh --force-rebuild $KERNEL_GETLAST_OPTS failed ;-( =======" && exit $STAGE
|
2012-12-18 17:20:45 +04:00
|
|
|
rm /etc/portage/need_kernel_rebuild
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_kernel_rebuild ;-( =======" && exit $STAGE
|
|
|
|
else
|
2013-01-13 16:26:42 +04:00
|
|
|
kernel-getlast.sh $KERNEL_GETLAST_OPTS
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: kernel-getlast.sh $KERNEL_GETLAST_OPTS failed ;-( =======" && exit $STAGE
|
2012-12-18 17:20:45 +04:00
|
|
|
fi
|
2012-05-18 20:27:25 +04:00
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# Update config files
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-05-18 20:27:25 +04:00
|
|
|
echo "======= STAGE $STAGE: Update config files ======="
|
|
|
|
etc-update
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: etc-update failed ;-( =======" && exit $STAGE
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-05-18 20:27:25 +04:00
|
|
|
|
2020-04-28 19:12:21 +03:00
|
|
|
# rebuild @system
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
|
|
|
if [ -f /etc/portage/need_system_rebuild ]; then
|
|
|
|
echo "======= STAGE $STAGE: rebuild @system ======="
|
|
|
|
source /etc/profile
|
|
|
|
emerge -1bkev --keep-going=y @system
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: @system rebuild failed ;-( =======" && exit $STAGE
|
|
|
|
rm /etc/portage/need_system_rebuild
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_system_rebuild ;-( =======" && exit $STAGE
|
|
|
|
fi
|
2021-03-11 18:09:18 +03:00
|
|
|
|
|
|
|
let STAGE++
|
2020-04-28 19:12:21 +03:00
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
|
|
|
|
|
|
|
# rebuild @world
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
|
|
|
if [ -f /etc/portage/need_world_rebuild ]; then
|
|
|
|
echo "======= STAGE $STAGE: rebuild @world ======="
|
|
|
|
source /etc/profile
|
2023-01-24 03:57:17 +03:00
|
|
|
emerge -1kev --keep-going=y --backtrack=50 @world
|
2020-04-28 19:12:21 +03:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: @world rebuild failed ;-( =======" && exit $STAGE
|
|
|
|
rm /etc/portage/need_world_rebuild
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_world_rebuild ;-( =======" && exit $STAGE
|
|
|
|
fi
|
2021-03-11 18:09:18 +03:00
|
|
|
|
|
|
|
let STAGE++
|
2020-04-28 19:12:21 +03:00
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
|
|
|
|
|
|
|
|
|
|
|
# Prelink libraries
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
|
|
|
echo "======= STAGE $STAGE: Prelink libraries ======="
|
|
|
|
if [ `which prelink 2>/dev/null` ]; then
|
|
|
|
$NICE_CMD prelink -avmqR
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: prelink -avmqR failed ;-( =======" && exit $STAGE
|
|
|
|
fi
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# remounting file systems rw->ro
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-08-09 18:23:28 +04:00
|
|
|
echo "======= STAGE $STAGE: remounting file systems rw->ro ======="
|
|
|
|
for fs in $RO_REMOUNT; do
|
2012-08-17 11:46:40 +04:00
|
|
|
echo "remounting $fs -> ro"
|
2013-05-02 18:29:48 +04:00
|
|
|
mount -o remount,ro -force $fs
|
2013-04-01 17:47:47 +04:00
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: mount -o remount,ro -force $fs failed ;-( =======" && exit $STAGE
|
2012-08-09 18:23:28 +04:00
|
|
|
done
|
|
|
|
|
|
|
|
let STAGE++
|
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
2012-08-09 18:23:28 +04:00
|
|
|
|
2012-10-10 20:50:19 +04:00
|
|
|
# Enabling e4rat data collection
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
2012-08-31 13:35:46 +04:00
|
|
|
echo "======= STAGE $STAGE: Enabling e4rat data collection ======="
|
2014-08-07 15:42:17 +04:00
|
|
|
if [ `which e4rat-collect 2>/dev/null` ]; then
|
|
|
|
e4rat_switch.sh collect
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: Enabling e4rat data collection failed ;-( =======" && exit $STAGE
|
|
|
|
fi
|
2012-08-31 13:35:46 +04:00
|
|
|
|
|
|
|
let STAGE++
|
2012-08-31 15:40:45 +04:00
|
|
|
fi
|
2012-10-10 20:50:19 +04:00
|
|
|
let STAGE_CNT++
|
|
|
|
|
2013-01-11 13:14:38 +04:00
|
|
|
# Collect data for file/package database
|
|
|
|
if [ $STAGE_CNT -eq $STAGE ]; then
|
|
|
|
echo "======= STAGE $STAGE: Collect data for file/package database ======="
|
|
|
|
if [ `which pfl 2>/dev/null` ]; then
|
|
|
|
pfl
|
|
|
|
[ 0 -ne $? ] && echo "Stage $STAGE: Collect data for file/package database failed ;-( =======" && exit $STAGE
|
|
|
|
else
|
|
|
|
echo "app-portage/pfl is not installed ;-("
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
let STAGE_CNT++
|
|
|
|
|
2012-05-18 20:27:25 +04:00
|
|
|
exit 0
|