aboutsummaryrefslogtreecommitdiff
path: root/usr.sbin/freebsd-update/freebsd-update.sh
diff options
context:
space:
mode:
authorEd Maste <emaste@FreeBSD.org>2019-01-17 21:38:57 +0000
committerEd Maste <emaste@FreeBSD.org>2019-01-17 21:38:57 +0000
commit0d5c5243af7d7bea2398ee5ebf582ff83fd28b3a (patch)
tree625811624c85c9964739e3c436b2935144580664 /usr.sbin/freebsd-update/freebsd-update.sh
parent50d503b78162af52bf881d3bc6db9eb82fc4ddfc (diff)
downloadsrc-0d5c5243af7d7bea2398ee5ebf582ff83fd28b3a.tar.gz
src-0d5c5243af7d7bea2398ee5ebf582ff83fd28b3a.zip
freebsd-update: Clarify unsupported release upgrade error message
Notify users that upgrading from -CURRENT or -STABLE is unsupported by freebsd-update. Also ensure --currently-running provides a correctly formatted release (as done by -r). PR: 234771 Submitted by: Gerald Aryeetey <aryeeteygerald_rogers.com> Reported by: yuri Reviewed by: bcran MFC after: 1 month Sponsored by: The FreeBSD Foundation Differential Revision: https://reviews.freebsd.org/D18803
Notes
Notes: svn path=/head/; revision=343122
Diffstat (limited to 'usr.sbin/freebsd-update/freebsd-update.sh')
-rw-r--r--usr.sbin/freebsd-update/freebsd-update.sh23
1 files changed, 22 insertions, 1 deletions
diff --git a/usr.sbin/freebsd-update/freebsd-update.sh b/usr.sbin/freebsd-update/freebsd-update.sh
index 9817f2e80517..837703731914 100644
--- a/usr.sbin/freebsd-update/freebsd-update.sh
+++ b/usr.sbin/freebsd-update/freebsd-update.sh
@@ -304,6 +304,14 @@ config_TargetRelease () {
fi
}
+# Pretend current release is FreeBSD $1
+config_SourceRelease () {
+ UNAME_r=$1
+ if echo ${UNAME_r} | grep -qE '^[0-9.]+$'; then
+ UNAME_r="${UNAME_r}-RELEASE"
+ fi
+}
+
# Define what happens to output of utilities
config_VerboseLevel () {
if [ -z ${VERBOSELEVEL} ]; then
@@ -442,7 +450,8 @@ parse_cmdline () {
NOTTYOK=1
;;
--currently-running)
- shift; export UNAME_r="$1"
+ shift
+ config_SourceRelease $1 || usage
;;
# Configuration file equivalents
@@ -658,6 +667,18 @@ fetchupgrade_check_params () {
FETCHDIR=${RELNUM}/${ARCH}
PATCHDIR=${RELNUM}/${ARCH}/bp
+ # Disallow upgrade from a version that is not `-RELEASE`
+ if ! echo "${RELNUM}" | grep -qE -- "-RELEASE$"; then
+ echo -n "`basename $0`: "
+ cat <<- EOF
+ Cannot upgrade from a version that is not a '-RELEASE' using `basename $0`.
+ Instead, FreeBSD can be directly upgraded by source or upgraded to a
+ RELEASE/RELENG version prior to running `basename $0`.
+ EOF
+ echo "System version: ${RELNUM}"
+ exit 1
+ fi
+
# Figure out what directory contains the running kernel
BOOTFILE=`sysctl -n kern.bootfile`
KERNELDIR=${BOOTFILE%/kernel}