summaryrefslogtreecommitdiff
path: root/distrib
diff options
context:
space:
mode:
authorTodd C. Miller <millert@cvs.openbsd.org>1998-04-14 17:25:32 +0000
committerTodd C. Miller <millert@cvs.openbsd.org>1998-04-14 17:25:32 +0000
commitf77cf5ff943cd57b50bcaf35f884d15be8ce9534 (patch)
treeb9922062af37fa74c683fd2fbc0e643c429a8938 /distrib
parent0cf349a642ef565bddb7db809bcf9492e44076fa (diff)
1) If the user selects a set multiple times in a session only
extract once. This is a problem now that default sets are selected automatically. 2) Don't select any default sets that have already been installed.
Diffstat (limited to 'distrib')
-rw-r--r--distrib/miniroot/install.sub72
1 files changed, 46 insertions, 26 deletions
diff --git a/distrib/miniroot/install.sub b/distrib/miniroot/install.sub
index 97807903c4e..8441f406a5e 100644
--- a/distrib/miniroot/install.sub
+++ b/distrib/miniroot/install.sub
@@ -1,5 +1,5 @@
#!/bin/sh
-# $OpenBSD: install.sub,v 1.73 1998/04/13 16:12:28 deraadt Exp $
+# $OpenBSD: install.sub,v 1.74 1998/04/14 17:25:31 millert Exp $
# $NetBSD: install.sub,v 1.5.2.8 1996/09/02 23:25:02 pk Exp $
#
# Copyright (c) 1997,1998 Todd Miller, Theo de Raadt
@@ -132,6 +132,26 @@ isin() {
return 1
}
+addel() {
+# add first argument to list formed by the remaining arguments
+# adds to the tail if the element does not already exist
+ local _a
+ local _seen
+
+ _seen=""
+ _a=$1; shift
+ while [ $# != 0 ]; do
+ echo "$1"
+ if [ "$_a" = "$1" ]; then
+ _seen="yes"
+ fi
+ shift
+ done
+ if [ "X$_seen" = "X" ]; then
+ echo "$_a"
+ fi
+}
+
rmel() {
# remove first argument from list formed by the remaining arguments
local _a
@@ -139,7 +159,7 @@ rmel() {
_a=$1; shift
while [ $# != 0 ]; do
if [ "$_a" != "$1" ]; then
- echo "$1";
+ echo "$1"
fi
shift
done
@@ -907,8 +927,10 @@ _osetsdone="$_setsdone"
for _f in $_sets $_kernel; do
case "$_f" in
base*.tar.gz|base*.tgz|etc*.tar.gz|etc*.tgz|bsd)
- _get_files="${_get_files} ${_f}"
- _setsdone="${_f} ${_setsdone}"
+ if ! isin ${_f} ${_setsdone}; then
+ _get_files=`addel ${_f} ${_get_files}`
+ _setsdone=`addel ${_f} ${_setsdone}`
+ fi
;;
esac
done
@@ -930,8 +952,6 @@ while : ; do
echo "${_file_list}"
continue
elif [ "X${resp}" = X"all" ]; then
- # XXX - setting _setsdone like this
- # is not entirely correct.
_get_files="$_sets $_kernel"
_setsdone="$_sets $_kernel"
break
@@ -954,11 +974,11 @@ while : ; do
case \$_f in
$resp) # Add/remove file to extraction list
if [ "\$_action" = "add" ]; then
- _get_files="\${_get_files} \$_f"
- _setsdone="\$_f \$_setsdone"
+ _get_files=\`addel \${_f} \${_get_files}\`
+ _setsdone=\`addel \${_f} \${_setsdone}\`
elif [ "\$_action" = "remove" ]; then
- _get_files=\`rmel \$_f \$_get_files\`
- _setsdone=\`rmel \$_f \$_setsdone\`
+ _get_files=\`rmel \${_f} \${_get_files}\`
+ _setsdone=\`rmel \${_f} \${_setsdone}\`
else
echo "Unknown action: \$_action"
fi
@@ -1053,11 +1073,11 @@ while test -n "${_get_files}" ; do
case \$_f in
$resp) # Add/remove file to extraction list
if [ "\$_action" = "add" ]; then
- _get_files="\${_get_files} \$_f"
- _setsdone="\$_f \$_setsdone"
+ _get_files=\`addel \${_f} \${_get_files}\`
+ _setsdone=\`addel \${_f} \${_setsdone}\`
elif [ "\$_action" = "remove" ]; then
- _get_files=\`rmel \$_f \$_get_files\`
- _setsdone=\`rmel \$_f \$_setsdone\`
+ _get_files=\`rmel \${_f} \${_get_files}\`
+ _setsdone=\`rmel \${_f} \${_setsdone}\`
else
echo "Unknown action: \$_action"
fi
@@ -1155,8 +1175,10 @@ _osetsdone="$_setsdone"
for _f in $_sets $_kernel; do
case "$_f" in
base*.tar.gz|base*.tgz|etc*.tar.gz|etc*.tgz|bsd)
- _get_files="${_get_files} ${_f}"
- _setsdone="${_f} ${_setsdone}"
+ if ! isin ${_f} ${_setsdone}; then
+ _get_files=`addel ${_f} ${_get_files}`
+ _setsdone=`addel ${_f} ${_setsdone}`
+ fi
;;
esac
done
@@ -1178,8 +1200,6 @@ while : ; do
( cd $1 && ls )
continue
elif [ "X${resp}" = X"all" ]; then
- # XXX - setting _setsdone like this
- # is not entirely correct.
_get_files="$_sets $_kernel"
_setsdone="$_sets $_kernel"
break
@@ -1202,11 +1222,11 @@ while : ; do
case \$_f in
$resp) # Add/remove file to extraction list
if [ "\$_action" = "add" ]; then
- _get_files="\${_get_files} \$_f"
- _setsdone="\$_f \$_setsdone"
+ _get_files=\`addel \${_f} \${_get_files}\`
+ _setsdone=\`addel \${_f} \${_setsdone}\`
elif [ "\$_action" = "remove" ]; then
- _get_files=\`rmel \$_f \$_get_files\`
- _setsdone=\`rmel \$_f \$_setsdone\`
+ _get_files=\`rmel \${_f} \${_get_files}\`
+ _setsdone=\`rmel \${_f} \${_setsdone}\`
else
echo "Unknown action: \$_action"
fi
@@ -1301,11 +1321,11 @@ while test -n "${_get_files}" ; do
case \$_f in
$resp) # Add/remove file to extraction list
if [ "\$_action" = "add" ]; then
- _get_files="\${_get_files} \$_f"
- _setsdone="\$_f \$_setsdone"
+ _get_files=\`addel \${_f} \${_get_files}\`
+ _setsdone=\`addel \${_f} \${_setsdone}\`
elif [ "\$_action" = "remove" ]; then
- _get_files=\`rmel \$_f \$_get_files\`
- _setsdone=\`rmel \$_f \$_setsdone\`
+ _get_files=\`rmel \${_f} \${_get_files}\`
+ _setsdone=\`rmel \${_f} \${_setsdone}\`
else
echo "Unknown action: \$_action"
fi