Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > gnu.bash.bug > #14417
| Path | csiph.com!goblin3!goblin1!goblin.stu.neva.ru!usenet.stanford.edu!not-for-mail |
|---|---|
| From | Grisha Levit <grishalevit@gmail.com> |
| Newsgroups | gnu.bash.bug |
| Subject | Re: segfault w/ localvar_inherit and associative array insert |
| Date | Sun, 29 Jul 2018 22:26:00 -0400 |
| Lines | 76 |
| Approved | bug-bash@gnu.org |
| Message-ID | <mailman.4402.1532917576.1292.bug-bash@gnu.org> (permalink) |
| References | <CAMu=BroMwXaqDTT3qusycRGRdXevmxiwC0RpR8+wGooo83pWgg@mail.gmail.com> <2e51ae31-5fb0-633b-6d7b-faab8df39585@case.edu> <CAMu=Brpvrg2GHwy8zs5hiWN_cReUupa=014JmfCNKMxaJws2Bw@mail.gmail.com> <54c2fc17-c47f-ed94-23a5-8f23f3c6cb87@case.edu> |
| NNTP-Posting-Host | lists.gnu.org |
| Mime-Version | 1.0 |
| Content-Type | text/plain; charset="UTF-8" |
| X-Trace | usenet.stanford.edu 1532917576 15608 208.118.235.17 (30 Jul 2018 02:26:16 GMT) |
| X-Complaints-To | action@cs.stanford.edu |
| Cc | bug-bash <bug-bash@gnu.org> |
| To | Chester Ramey <chet.ramey@case.edu> |
| Envelope-to | bug-bash@gnu.org |
| DKIM-Signature | v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=gkZR03NZdhM5rXVTc/SX0PGrWQ9bW7U+9XxD3ycpDsk=; b=UYyLGPTbymn7wQJGhTn3BITkOfB9/LvBq/8fyfBY1pkLID7ARRFUZA9X5uui4TiX8+ Dq1X8Rn4JED/X1DthXQ0FIiVulFPETKnL+3t157lGzN4sDJl2fWHgiJ+kl2l75eigc3b WydINJ9z2tWkQFX7sMjpRBRl7//rwLjZCrI5a6FaSeAunEJv0JnkVAvcjk2BwUE5UqCn JwbCqa9mqwDU0Ml/N7DYALS9c06HhqQRRf9as5ESMOASbznWumS1D35mzydDQUs1UoD8 SUsEhLVH77tzWCY19aQUBwf8SXma3/QthCO7mr6FqNpjqHLAHBCaK2pAhFGrrT4f9MFV zwwA== |
| X-Google-DKIM-Signature | v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=gkZR03NZdhM5rXVTc/SX0PGrWQ9bW7U+9XxD3ycpDsk=; b=ojMBlln2XmI+pXtDzsH+HjD7MkoIY2zxHTgik/HIZY6x16AIYq4fLct6ld/OkhGxF5 QS30YNdgMrKPa6NR8PwQrmWbPbxUwds0KEnQ1VrpTvC+2jnp60myomsAIrNm7zrRry5F zCf/GcLOmO+3N/Ez9zE3T9IIyNrFE2cMMheJgJ1IksK1RuigHZ6w24ALs6va7Jz2/Sx+ 823cv8XgVJytLmiSefLQyPBeeIzA3Gm1EH2bbwuk8uNpDUnWjYWfNoxv3p3/MeRG2tCZ WCEEvMCe/3pERY2C+inLJxTWlBvi2Cv9Kff4emRvHzUwEqseQJ11sUh9LavNnJXYJwzp xo5g== |
| X-Gm-Message-State | AOUpUlHRdVVJH14GVn0UrdVoiuizX7ukuDhHquTCAr5mhCy970m/mFhg WJcLoi1P6tuquGxAMA/ksDoJaFmhqsGHMHsCin95lAsY |
| X-Google-Smtp-Source | AAOMgpciw+HaX9HijTQvkoabocOpP7RIlvLyyLrm8lRAM+SD/aD4naLCeT2eaVglexczdyEsMBT1y4yTCMwchFe2Sf0= |
| X-Received | by 2002:a2e:2bd7:: with SMTP id r84-v6mr11733414ljr.40.1532917571414; Sun, 29 Jul 2018 19:26:11 -0700 (PDT) |
| In-Reply-To | <54c2fc17-c47f-ed94-23a5-8f23f3c6cb87@case.edu> |
| X-detected-operating-system | by eggs.gnu.org: Genre and OS details not recognized. |
| X-Received-From | 2a00:1450:4864:20::22d |
| X-BeenThere | bug-bash@gnu.org |
| X-Mailman-Version | 2.1.21 |
| Precedence | list |
| List-Id | Bug reports for the GNU Bourne Again SHell <bug-bash.gnu.org> |
| List-Unsubscribe | <https://lists.gnu.org/mailman/options/bug-bash>, <mailto:bug-bash-request@gnu.org?subject=unsubscribe> |
| List-Archive | <http://lists.gnu.org/archive/html/bug-bash/> |
| List-Post | <mailto:bug-bash@gnu.org> |
| List-Help | <mailto:bug-bash-request@gnu.org?subject=help> |
| List-Subscribe | <https://lists.gnu.org/mailman/listinfo/bug-bash>, <mailto:bug-bash-request@gnu.org?subject=subscribe> |
| Xref | csiph.com gnu.bash.bug:14417 |
Show key headers only | View raw
Though my motivation in reporting this was to point out the segfault, I'm a
bit confused by why compound assignment should be an error here.
> Bash is consistent in defaulting to indexed array variables when you don't
> specify -A and assign a value using the compound assignment syntax.
Since localvar_inherit is new behavior anyway, I'm not sure why the above must
be the controlling default. I think a less surprising-to-the-user default
might be "when this option is set, Bash consistently inherits the
previous-scope variable's value/attributes before performing any new
value/attribute modifications".
In the alternative, it seems that Bash should be consistent in also
defaulting to indexed arrays in the case of `array[subscript]' assignments
with no -A specified?
i.e. if the following should be an error:
$ declare -A A; f() { local A=([Y]=Y); declare -p A; }; f
Segmentation fault: 11
should the following produce a local indexed array/an error as well (instead
of the associative array assignment it currently does)?
$ declare -A A; f() { local A[Y]=Y; declare -p A; }; f
declare -A A=([Y]="Y" )
----
> So you create a local indexed array variable, and when you attempt to
> inherit the value from a global associative array before performing any
> specified assignment, you should either ignore the inherited value or
> throw an error.
I feel like this doesn't seem very apparent from the documentation (though
it's not strictly contradictory, the step where we first check the RHS to see
if it is a compound array assignment seems surprising):
localvar_inherit
If set, local variables inherit the value and attributes of a variable
of the same name that exists at a previous scope *before any new value
is assigned*.
----
There's also an issue that only a value of a matching type is inherited and
the usual scalar-to-array[0] conversion is not performed. I'm not sure if
this is intentional but I do want to point it out as potentially surprising:
$ unset a s; a=(X) s=X
$ shopt -s localvar_inherit
$ f() { local -a a s; declare -p a s; }; f
declare -a a=([0]="X")
declare -a s=()
$ f() { local a+=(Y) s+=(Y); declare -p a s; }; f
declare -a a=([0]="X" [1]="Y")
declare -a s=([0]="Y")
$ f() { local -a a+=Y s+=Y; declare -p a s; }; f
declare -a a=([0]="XY")
declare -a s=([0]="Y")
----
Maybe I'm missing the intended use of the option but based on the description
in the man page, I guess I'm expecting `declare var' with localvar_inherit to
be roughly the same as `eval $(declare -p var 2>/dev/null); declare var'
without it (except for namerefs). Is there maybe a use case for the
differences in behavior?
As a side note: I wonder if this functionality, regardless or edge case
handling, would be more useful as an option supplied to `declare' and so
applied explicitly so specific variables, rather than a global shell option.
Back to gnu.bash.bug | Previous | Next | Find similar | Unroll thread
Re: segfault w/ localvar_inherit and associative array insert Grisha Levit <grishalevit@gmail.com> - 2018-07-29 22:26 -0400
csiph-web