On Friday, January 11, 2013 09:48:32 PM John Kearney wrote:
> Am 11.01.2013 19:27, schrieb Dan Douglas:
> > Bash treats the variable as essentially undefined until given at least an 
> > empty value.
> >
> >     $ bash -c 'typeset -i x; [[ -v x ]]; echo "$?, ${x+foo}"; typeset -p x'
> >     1,
> >     bash: line 0: typeset: x: not found
> >     $ ksh -c 'typeset -i x; [[ -v x ]]; echo "$?, ${x+foo}"; typeset -p x'
> >     0,
> >     typeset -i x
> >
> > Zsh implicitly gives integers a zero value if none are specified and the
> > variable was previously undefined. Either the ksh or zsh ways are fine IMO.
> >
> > Also I'll throw this in:
> >
> >     $ arr[1]=test; [[ -v arr[1] ]]; echo $?
> >     1
> >
> > This now works in ksh to test if an individual element is set, though it 
> > hasn't always. Maybe Bash should do the same? -v is tricky because it adds 
> > some extra nuances to what it means for something to be defined...
> >
> 
> Personally I like the current behavior, disclaimer I use nounset.
> I see no problem with getting people to initialize variables.

How is this relevant? It's an inconsistency in the way set/unset variables
are normally handled. You don't use variadic functions? Unset variables /
parameters are a normal part of most scripts.

> it is a more robust programming approach.

I strongly disagree. (Same goes for errexit.)

-- 
Dan Douglas

Reply via email to