Gentoo-Upgrade/sbin/gentoo-upgrade.sh

625 lines
23 KiB
Bash
Raw Normal View History

2012-05-18 20:27:25 +04:00
#!/bin/bash
2012-08-09 18:23:28 +04:00
STAGE=0
NICE_CMD="nice -n 19 ionice -c2"
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
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."
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 ;;
-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
# Pull portage config changes
if [ $STAGE_CNT -eq $STAGE ]; then
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
fi
let STAGE++
fi
let STAGE_CNT++
# 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
[ 0 -ne $? ] && echo "Stage $STAGE: Updating gentoo-upgrade script failed ;-( =======" && exit $STAGE
fi
exec $0 -s $((STAGE+1))
echo "Stage $STAGE: Bash translator in unreachable code ;-(" && exit $STAGE
let STAGE++
fi
let STAGE_CNT++
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
# /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 ----------"
$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
$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
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
# 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 ======="
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
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
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
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
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
# Check if we should run perl-cleaner or haskell-updater
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++
# Perl upgrade
if [ $STAGE_CNT -eq $STAGE ]; then
echo "======= STAGE $STAGE: Perl upgrade ======="
if [ -f /etc/portage/need_upgrade_perl ]; then
emerge -uq1v perl
[ 0 -ne $? ] && echo "Stage $STAGE: perl package upgrading failed ;-( =======" && exit $STAGE
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++
# Python upgrade
2012-10-10 20:50:19 +04:00
if [ $STAGE_CNT -eq $STAGE ]; then
echo "======= STAGE $STAGE: Python upgrade ======="
2013-01-11 12:39:54 +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
echo '------- Upgrading Python package -------'
2017-01-01 00:34:28 +03:00
emerge -1uDNvt python
[ 0 -ne $? ] && echo "Stage $STAGE: Python upgrade failed ;-( =======" && exit $STAGE
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-~'`
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
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
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
# @system upgrade
if [ $STAGE_CNT -eq $STAGE ]; then
echo "======= STAGE $STAGE: @system upgrade ======="
echo '------- Upgrading @system packages -------'
emerge -1uDNvt --keep-going=y @system
#[ 0 -ne $? ] && echo "Stage $STAGE: @system upgrade failed ;-( =======" && exit $STAGE
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...'
2017-01-01 00:34:28 +03:00
emerge -1uDNvt @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
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
[ 0 -ne $? ] && echo "Stage $STAGE: Upgrading live packages failed ;-( =======" && exit $STAGE
fi
2012-11-25 00:52:51 +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
$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
$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
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
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 ======="
[ 1 -eq $QUIET ] && KERNEL_GETLAST_OPTS="$KERNEL_GETLAST_OPTS --quiet"
if [ -f /etc/portage/need_kernel_rebuild ]; then
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
rm /etc/portage/need_kernel_rebuild
[ 0 -ne $? ] && echo "Stage $STAGE: cann't remove /etc/portage/need_kernel_rebuild ;-( =======" && exit $STAGE
else
kernel-getlast.sh $KERNEL_GETLAST_OPTS
[ 0 -ne $? ] && echo "Stage $STAGE: kernel-getlast.sh $KERNEL_GETLAST_OPTS failed ;-( =======" && exit $STAGE
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
# 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++
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
emerge -1kev --keep-going=y @world
[ 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++
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"
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 ======="
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