From owner-freebsd-hackers Wed Apr 23 17:29:03 1997 Return-Path: Received: (from root@localhost) by hub.freebsd.org (8.8.5/8.8.5) id RAA02889 for hackers-outgoing; Wed, 23 Apr 1997 17:29:03 -0700 (PDT) Received: from unique.usn.blaze.net.au (unique.usn.blaze.net.au [203.17.53.17]) by hub.freebsd.org (8.8.5/8.8.5) with ESMTP id RAA02881 for ; Wed, 23 Apr 1997 17:28:57 -0700 (PDT) Received: from unique.usn.blaze.net.au (local [127.0.0.1]) by unique.usn.blaze.net.au (8.8.5/8.8.5) with ESMTP id KAA21258; Thu, 24 Apr 1997 10:28:34 +1000 (EST) Message-Id: <199704240028.KAA21258@unique.usn.blaze.net.au> X-Mailer: exmh version 2.0gamma 1/27/96 To: "Jordan K. Hubbard" cc: hackers@freebsd.org Subject: Re: /etc/netstart bogons.. In-reply-to: Your message of "Wed, 23 Apr 1997 11:05:56 MST." <2911.861818756@time.cdrom.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Date: Thu, 24 Apr 1997 10:28:33 +1000 From: David Nugent Sender: owner-hackers@freebsd.org X-Loop: FreeBSD.org Precedence: bulk > In /etc/netstart (and elsewhere) we have constructs of the form: [.. deletia ..] > And so on. This is, needless to say, DEEPLY DEEPLY EVIL since it will > cause these features to be turned on in the _absence_ of any such flag > setting, say because you have an old /etc/sysconfig file. Yes, exactly this has happened to me a few times, when I've either forgotten to update sysconfig or accidently missed an addition. > Any objection to reversing the polarity on these various ifs? If > there's no variable or it's not explicitly set to YES, the operation > should fail. Speak now or hold your peace, please.. The problem is that it isn't always a "YES" that the variable is set to. A test for an empty variable should, however, be made the equivalent of "NO". That isn't always the case, though, but for consistency's sake, it SHOULD always be like that. The question is, how do you allow for an empty variable? Separate the test and its use, of course. BTW, since our /bin/sh groks functions, why aren't these blocks a function? Something along the lines of: conditional_run() { var=$1 prog=$2 show=$3 # Allow two args if [ "x$show" = "x" ]; then show=$prog fi tvar="x$var" if [ "$tvar" != "x" -a "$tvar" != "xNO" ]; then echo -n " $show"; eval $prog fi } [Of course, this is only an example - I have not thoroughly tested it ;-)] Then: conditional_run "$nisflags" "ypserv" conditional_run "$tcp_extensions" \ "sysctl -w net.inet.tcp.rfc1323=0;\ sysctl -w net.inet.tcp.rfc1644=0" \ "" conditional_run "$gateway" \ "sysctl -w net.inet.ip.forwarding=1 >/dev/null 2>&1" \ "configuring host as a gateway." conditional_run "$router" \ "${router} ${routerflags}" \ "starting routing daemon: ${router}" and so on. This makes /etc/{rc*,netstart} a hell of a lot more configurable. OF course, some of these blocks also test for the existence of a file, but that could be done easily too, either by extending the above function or adding another similar one. For complex blocks of code, define another function and pass the function name as the 'prog'. Regards, David Nugent - Unique Computing Pty Ltd - Melbourne, Australia Voice +61-3-9791-9547 Data/BBS +61-3-9792-3507 3:632/348@fidonet davidn@freebsd.org davidn@blaze.net.au http://www.blaze.net.au/~davidn/