Finding $pidfile from a conf file (Was: Re: conf/153460: devd(8) cannot be restarted correctly via /etc/rc.d script)

Doug Barton dougb at FreeBSD.org
Sat Apr 23 16:03:33 UTC 2011


On 04/23/2011 03:42, Jilles Tjoelker wrote:
> On Thu, Apr 21, 2011 at 05:49:05PM -0700, Doug Barton wrote:
>> On 04/21/2011 16:28, Jilles Tjoelker wrote:
>>>> 		line="/${line%%[\"\;]*}"
>
>>> The meaning of this line depends on the version of sh(1). The correct
>>> interpretation, used by sh in 9-current and most other shells, is to
>>> strip from the first double-quote or semicolon onwards. However, sh in
>>> older FreeBSD versions will strip from the first backslash, double-quote
>>> or semicolon onwards.
>
>>> If the 9-current behaviour is desired for all FreeBSD versions, use:
>>> 		line=/${line%%[\"\;]*}
>
>> I think it's incredibly unlikely that there would actually be a
>> backslash in the text, and even if there was, it should be ok to strip
>> from there.
>
> Even if there is, it seems bad if this differs between 8.x and 9.x.

So MFC your changes. :)

> The only reasons to quote expansions in assignments are paranoia

Yeah, I'm Ok with that.

FYI, I got this in last night, using the modified pass-by-reference 
version that I mentioned in my last post (as a result of your 
suggestion). It turns out that to make this work it's necessary to run 
the routine to check the pidfile both in start and stop _precmd. That 
makes sense of course, just thought I'd mention it. I also learned that 
if you redirect stderr from the function call you miss error messages 
generated in it, so my example implementation for ports is a little 
different than what I first posted. See 
http://www.freebsd.org/cgi/query-pr.cgi?pr=156594 for what I ended up with.


Doug

-- 

	Nothin' ever doesn't change, but nothin' changes much.
			-- OK Go

	Breadth of IT experience, and depth of knowledge in the DNS.
	Yours for the right price.  :)  http://SupersetSolutions.com/



More information about the freebsd-rc mailing list