Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > gnu.bash.bug > #11477
| 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> |
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
Re: Inconsistent arithmetic evaluation of parameters Stephane Chazelas <stephane.chazelas@gmail.com> - 2015-09-03 14:45 +0100
csiph-web