From owner-freebsd-current@FreeBSD.ORG Sun Feb 23 19:51:51 2014 Return-Path: Delivered-To: freebsd-current@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) (using TLSv1 with cipher ADH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id A0E1134F; Sun, 23 Feb 2014 19:51:51 +0000 (UTC) Received: from mx1.fisglobal.com (mx1.fisglobal.com [199.200.24.190]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.freebsd.org (Postfix) with ESMTPS id 6514C1FAA; Sun, 23 Feb 2014 19:51:51 +0000 (UTC) Received: from smarthost.fisglobal.com ([10.132.206.193]) by ltcfislmsgpa05.fnfis.com (8.14.5/8.14.5) with ESMTP id s1NJpjCb021617 (version=TLSv1/SSLv3 cipher=AES128-SHA bits=128 verify=NOT); Sun, 23 Feb 2014 13:51:45 -0600 Received: from THEMADHATTER (10.242.181.54) by smarthost.fisglobal.com (10.132.206.193) with Microsoft SMTP Server id 14.3.174.1; Sun, 23 Feb 2014 13:51:43 -0600 From: Sender: Devin Teske To: "'David Chisnall'" , "'Allan Jude'" References: <62A9DF47-C938-464B-92B6-9A2A96B5A9C9@FreeBSD.org> <530A39BB.6070003@allanjude.com> <0DB376E3-8C7F-4F20-9DEE-4DB98C078571@FreeBSD.org> In-Reply-To: <0DB376E3-8C7F-4F20-9DEE-4DB98C078571@FreeBSD.org> Subject: RE: libinit idea Date: Sun, 23 Feb 2014 11:51:35 -0800 Message-ID: <129e01cf30d0$a9c95ab0$fd5c1010$@FreeBSD.org> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit X-Mailer: Microsoft Outlook 15.0 Thread-Index: AQISR3ofyJhDsVgc5yL7QKIkV53qPQF/+vvdAmUWq0ABcDLEW5oSZYzg Content-Language: en-us X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:5.11.87, 1.0.14, 0.0.0000 definitions=2014-02-23_02:2014-02-21,2014-02-23,1970-01-01 signatures=0 Cc: dteske@FreeBSD.org, 'FreeBSD Current' X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.17 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 23 Feb 2014 19:51:51 -0000 > -----Original Message----- > From: David Chisnall [mailto:theraven@FreeBSD.org] > Sent: Sunday, February 23, 2014 10:18 AM > To: Allan Jude > Cc: FreeBSD Current > Subject: Re: libinit idea > > On 23 Feb 2014, at 18:11, Allan Jude wrote: > > > sysrc solves this nicely, it is in base now, and is great for > > programmatically adding, removing and changing lines in rc.conf style > > files. It is also in ports for older versions of FreeBSD where it is > > not in base. > > The problem is, there is no such thing as an rc.conf style file. rc.conf is just a > shell script. If you only edit it with sysrc, or you are careful to preserve the > structure, then it's fine. Actually, sysrc is well aware that rc.conf is a shell script and sysrc will actually make certain that structure is preserved (regardless of whether you've placed shell code in rc.conf or not). > There is absolutely nothing stopping you, however, > from writing arbitrarily complex shell scripts inside rc.conf. Sure, it's a terrible > idea to do so, but when has that ever stopped anyone? > When sysrc is told to make a change, it first finds where it needs to make that change (/etc/rc.conf or /etc/rc.conf.local or one of other paths mentioned in rc_conf_files setting), it will refuse to edit the file *IF* the file doesn't first (before editing) pass a shell syntax check (using "sh -n FILE"). After making the changes in a temporarily file (produced with mktemp(1)), it again performs yet another syntax check (also using "sh -n FILE") to make sure that it continues to yield clean syntax. On top of that, it makes certain not to muck with dynamic assignments. So it will leave-alone an assignment such as "foo=$( bar )" if told to edit the variable foo -- instead opting to add a foo=newvalue after the dynamic assignment (logic is simple... sysrc wasn't responsible for putting that dynamic assignment in, so it is going to leave it as-is and put the new [static] assignment further below. So Allan was absolutely correct in stating that sysrc is for editing "rc.conf style" files -- shell scripts really. In essence, sysrc is actually a shell script modifying utility that takes extreme special care to rely on the fact that rc.conf *is* a shell script. > An rc-replacement could enforce this by only accepting purely declarative files > for configuration, guaranteeing that if they were syntactically valid they would > also be machine editable, no matter what the user does to them. > sysrc does this for you. -- Devin _____________ The information contained in this message is proprietary and/or confidential. If you are not the intended recipient, please: (i) delete the message and all copies; (ii) do not disclose, distribute or use the message in any manner; and (iii) notify the sender immediately. In addition, please be aware that any message addressed to our domain is subject to archiving and review by persons other than the intended recipient. Thank you.