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


Groups > gnu.bash.bug > #11467

Re: Inconsistent arithmetic evaluation of parameters

From Greg Wooledge <wooledg@eeg.ccf.org>
Newsgroups gnu.bash.bug
Subject Re: Inconsistent arithmetic evaluation of parameters
Date 2015-09-02 11:48 -0400
Message-ID <mailman.405.1441208931.19560.bug-bash@gnu.org> (permalink)
References (5 earlier) <CANaoh6+s+GQCHozQpN_jO7SLHb=e+HQnCDivi+ADYz1gH6r=ow@mail.gmail.com> <mvmk2s9thoc.fsf@hawking.suse.de> <CANaoh6K2WBBv7EDbgeCBGe5tbBC_YfDW7x3ORgBVTdt2Ynfn7Q@mail.gmail.com> <20150902151948.GT4309@eeg.ccf.org> <55E714BA.9020904@case.edu>

Show all headers | View raw


On Wed, Sep 02, 2015 at 11:24:42AM -0400, Chet Ramey wrote:
> On 9/2/15 11:19 AM, Greg Wooledge wrote:
> > On Wed, Sep 02, 2015 at 10:16:14AM -0500, Dennis Williamson wrote:
> >> The $ is implied.
> > 
> > That is completely absurd.  (And wrong.)
> 
> Not exactly.  When the arithmetic evaluator encounters a token that is of
> the form of a shell identifier (`bar'), in a context where an operand is
> needed, it treats it as a shell variable and looks up the variable's
> value.  In that sense, it's an expansion.
> 
> The difference between bash and dash is what each shell does with that
> value.

$foo and foo are not equivalent in dash, as we've already discussed:

$ dash
$ foo=bar bar=5
$ echo $((foo))
dash: 4: Illegal number: bar
$ echo $(($foo))
5

They are also not equivalent in bash, if I may be permitted to change
the context slightly:

$ bash
$ foo='$(id >&2)'
$ echo $((x[foo]))
bash: $(id >&2): syntax error: operand expected (error token is "$(id >&2)")
$ echo $((x[$foo]))
uid=563(wooledg) gid=22(pgmr) groups=1002(webauth),208(opgmr)
0

So "The $ is implied" is false, in both shells, although there are some
contexts where they happen to produce the same result.

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


Thread

Re: Inconsistent arithmetic evaluation of parameters Greg Wooledge <wooledg@eeg.ccf.org> - 2015-09-02 11:48 -0400

csiph-web