Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > gnu.bash.bug > #11477

Re: Inconsistent arithmetic evaluation of parameters

From Stephane Chazelas <stephane.chazelas@gmail.com>
Newsgroups gnu.bash.bug
Subject Re: Inconsistent arithmetic evaluation of parameters
Date 2015-09-03 14:45 +0100
Message-ID <mailman.450.1441291925.19560.bug-bash@gnu.org> (permalink)
References <61895190-83A6-4D62-B90E-65023D5E966B@gmail.com> <20150901175030.GP4309@eeg.ccf.org> <CANaoh6LNi_YyOOB56ZMR3P8thRSMfoTcDCGyW8S921nVoP1H7Q@mail.gmail.com> <20150901202308.GR4309@eeg.ccf.org>

Show all headers | View raw


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
> 
> 

Back to gnu.bash.bug | Previous | Next | Find similar


Thread

Re: Inconsistent arithmetic evaluation of parameters Stephane Chazelas <stephane.chazelas@gmail.com> - 2015-09-03 14:45 +0100

csiph-web