summaryrefslogtreecommitdiff
path: root/distrib/miniroot/install.sub
diff options
context:
space:
mode:
authorKenneth R Westerback <krw@cvs.openbsd.org>2002-09-29 22:45:45 +0000
committerKenneth R Westerback <krw@cvs.openbsd.org>2002-09-29 22:45:45 +0000
commita6321893b1758c8210305f2b2f1bc3fdb39e7a32 (patch)
treeaa98c92cc0821d9b3d52ea81e5c18041a2031498 /distrib/miniroot/install.sub
parent885aa3d8ca4bb79ac52a1e5c7487af99579a73aa (diff)
Modify makedev so that it does not attempt to create network interface
devices, to allow ask_which() to be used for interface configuration. Rework network interface configuration logic to use ask_which() instead of local code. This 1) May fix the problem noted by David Norman, where the prompts are somehow broken, since no such problems have been noted with the ask_which() code. 2) Shrinks the install output by a few lines. 3) Makes the install script smaller and clearer. 4) Makes interface configuration consistant with other 'device' configurations. 5) Makes it impossible for a user to configure an interface more than once. Add the interface name to the 'IP address (or dhcp)' question. This makes it more informative, especially if a '!' or '!foo' shell escape has been used and overwritten the list of interfaces and the display of the name of the one being configured.
Diffstat (limited to 'distrib/miniroot/install.sub')
-rw-r--r--distrib/miniroot/install.sub31
1 files changed, 11 insertions, 20 deletions
diff --git a/distrib/miniroot/install.sub b/distrib/miniroot/install.sub
index 6e7d5c35584..a1945d2a8c2 100644
--- a/distrib/miniroot/install.sub
+++ b/distrib/miniroot/install.sub
@@ -1,4 +1,4 @@
-# $OpenBSD: install.sub,v 1.260 2002/09/28 23:35:12 krw Exp $
+# $OpenBSD: install.sub,v 1.261 2002/09/29 22:45:44 krw Exp $
# $NetBSD: install.sub,v 1.5.2.8 1996/09/02 23:25:02 pk Exp $
#
# Copyright (c) 1997-2002 Todd Miller, Theo de Raadt, Ken Westerback
@@ -422,6 +422,9 @@ __EOT
makedev() {
local _d=$1
+ # Don't need to make network interface devices.
+ isin $_d $IFDEVS && return
+
if [ ! -c /dev/r${_d}c ]; then
if [ -r /dev/MAKEDEV ]; then
(cd /dev; sh MAKEDEV $_d)
@@ -510,29 +513,17 @@ do_selection_list() {
}
configure_all_interfaces() {
- local _ifsdone _ifs
+ local _IFDEVS=$IFDEVS _ifs
while : ; do
- cat << __EOT
+ _IFDEVS=`rmel "$_ifs" $_IFDEVS`
-Available network interfaces ([X] == already configured) are:
+ ask_which "interface" "do you wish to initialize?" "$_IFDEVS" "`echo $_IFDEVS | cutword 1`"
-__EOT
- do_selection_list "$IFDEVS" "$_ifsdone" "Configure which interface?"
+ [ "$resp" = "done" ] && break
- case $resp in
- "done") break
- ;;
- *) _ifs=$resp
- if isin $_ifs $IFDEVS ; then
- if configure_ifs $_ifs ; then
- _ifsdone="$_ifs $_ifsdone"
- fi
- else
- echo "Invalid response: '$resp' is not in list"
- fi
- ;;
- esac
+ _ifs=$resp
+ configure_ifs $_ifs || _ifs=
done
}
@@ -562,7 +553,7 @@ configure_ifs() {
# Get IP address
resp=
while [ -z "$resp" ] ; do
- ask "IP address${_dhcp_prompt}?" "$_if_ip"
+ ask "IP address for ${_if_name}${_dhcp_prompt}?" "$_if_ip"
if [ ! -x /sbin/dhclient -a "$resp" == "dhcp" ]; then
echo "DHCP is not supported."
resp=