Date: Sun, 22 Aug 2010 16:01:18 +0200 From: Jilles Tjoelker <jilles@stack.nl> To: Alexander Leidinger <Alexander@Leidinger.net> Cc: jhell <jhell@DataIX.net>, FreeBSD Stable <freebsd-stable@freebsd.org> Subject: Re: daily run output 800.scrub-zfs fixups Message-ID: <20100822140118.GA42636@stack.nl> In-Reply-To: <20100822150842.00005129@unknown> References: <4C6F5344.6040808@DataIX.net> <20100822150842.00005129@unknown>
next in thread | previous in thread | raw e-mail | index | archive | help
On Sun, Aug 22, 2010 at 03:08:42PM +0200, Alexander Leidinger wrote: > On Sat, 21 Aug 2010 00:17:08 -0400 jhell <jhell@DataIX.net> wrote: > > Hi Alexander, > > Attached is a fix for one problem and one slight overlook for > > 800.scrub-zfs. > > The first & second change was probably just an oversight but none the > > less they both give a false impression of actions taken. > > Change1: > > ${daily_scrub_zfs_default_threshold=30} is missng the ':' > > which would ultimately reset the users supplied value in > > periodic.conf to 30. > Sorry, but it is not missing the ':'. There is one in front of it. A > lot of start scripts in ports use this. You need to use a := instead of > a = if you use > var=${var:=default_val} > but not if you use > : ${var=default_val} > I have the impression that the ':' in front of the variable is the way > it is supposed to be in the start scripts in ports. I adopted this > style (one variable name less to type... specially with expressive > names this is some amount less to type). As described in sh(1) and POSIX, ${var=default_val} assigns the default if var was not set, while ${var:=default_val} assigns the default if var was not set or if it was set to the empty string. The double assignment in the construct var=${var:=default_val} is a workaround for bugs in very old Bourne shells (see Autoconf documentation for more). Our sh(1) has never had that bug, so simply : "${var:=default_val}" is better. The double-quotes prevent unnecessary pathname generation, which could be slow. However, even without the double-quotes, the correct value is assigned and no other side effects occur. > And I remember to have tested a lot of cases for the timeout value, > overriding a pool specific value and overriding the default where some > of them and all worked. > If you have a case where it does not work, it would be nice if you > could add a "set -x" in the beginning of the script and send me the > output of a failing run. -- Jilles Tjoelker
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20100822140118.GA42636>