[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: Inconsistent arithmetic evaluation of parameters
From: |
Stephane Chazelas |
Subject: |
Re: Inconsistent arithmetic evaluation of parameters |
Date: |
Thu, 3 Sep 2015 14:45:29 +0100 |
User-agent: |
Mutt/1.5.21 (2010-09-15) |
2015-09-01 16:23:08 -0400, Greg Wooledge:
> On Tue, Sep 01, 2015 at 03:13:57PM -0500, Dennis Williamson wrote:
> > The version of dash I have handy (0.5.7) has math support which IMHO is
> > broken:
> >
> > $ foo=bar
> > $ bar=5
> > $ echo $foo
> > bar
> > $ echo $((foo))
> > dash: 4: Illegal number: bar
> > $ echo $(($foo))
> > 5
> > $ echo $((bar))
> > 5
> > $ echo $(($bar))
> > 5
> >
> > Note the inconsistency in support of omitting the inner dollar sign.
>
> $foo is expanded to bar, so the following two lines are always going to
> be equivalent:
>
> echo $(($foo))
> echo $((bar))
>
> POSIX also specifies (vaguely!!) that $((x)) and $(($x)) are equivalent.
Note that while POSIX may (vaguely indeed) say $((x)) and
$(($x)) are equivalent at least when x contains a litteral
number, $((-x)) and $((-$x)) are not equivalent in all shells if
$x contains a negative number.
$ a=0 x=-1 bash -c 'echo $((a-$x))'
bash: a--1: syntax error in expression (error token is "1")
$ a=0 x=-1 bash -c 'echo $((a-x))'
1
(they're OK in shells that don't implement the (optional in
posix) -- and ++ operators like dash.
Or you can add spaces to make it more reliable: $((a - $x))
In ksh/zsh/bash, see also the difference between:
$ a=1+1; echo $((a*2))
4
$ a=1+1; echo $(($a*2))
3
--
Stephane
>
>
- Re: Inconsistent arithmetic evaluation of parameters, (continued)
- Re: Inconsistent arithmetic evaluation of parameters, Dennis Williamson, 2015/09/01
- Re: Inconsistent arithmetic evaluation of parameters, Andreas Schwab, 2015/09/01
- Re: Inconsistent arithmetic evaluation of parameters, Dennis Williamson, 2015/09/01
- Re: Inconsistent arithmetic evaluation of parameters, Andreas Schwab, 2015/09/02
- Re: Inconsistent arithmetic evaluation of parameters, Dennis Williamson, 2015/09/02
- Re: Inconsistent arithmetic evaluation of parameters, Greg Wooledge, 2015/09/02
- Re: Inconsistent arithmetic evaluation of parameters, Chet Ramey, 2015/09/02
- Re: Inconsistent arithmetic evaluation of parameters, Greg Wooledge, 2015/09/02
- Re: Inconsistent arithmetic evaluation of parameters, Chet Ramey, 2015/09/03
- Re: Inconsistent arithmetic evaluation of parameters, Chet Ramey, 2015/09/02
- Re: Inconsistent arithmetic evaluation of parameters,
Stephane Chazelas <=
- Re: Inconsistent arithmetic evaluation of parameters, Dennis Williamson, 2015/09/03
- Re: Inconsistent arithmetic evaluation of parameters, Chet Ramey, 2015/09/02
Re: Inconsistent arithmetic evaluation of parameters, Chet Ramey, 2015/09/02