From: Ray Andrews <rayandrews@eastlink.ca>
To: zsh-users@zsh.org
Subject: Re: uninvited members of associative array
Date: Sat, 17 Dec 2022 13:52:22 -0800 [thread overview]
Message-ID: <a6eb3a46-5220-5c1e-ffc4-5d990c705169@eastlink.ca> (raw)
In-Reply-To: <7a12a4c0-d423-4538-a194-18e9cf932fe9@app.fastmail.com>
On 2022-12-17 13:07, Lawrence Velázquez wrote:
>
> I'm not sure why you brought this up. Are you using "set +A"
> somewhere?
No, but I'm still curious as to how my array got fouled. As just
discussed with Roman, I'd been using a global 'IN' and thus it will
contain whatever was in it at the next assignment, and it seemed to me
that a possibility was that the overwrite was not clean. Reading up on
it, there's that +A and -- tho I don't really understand --, it seemed
possible that it might force a complete overwrite. But I'm absolutely
happy with my local IN, that's got to be better anyway. And, per your
advice, I have 'typeset -p's locked and loaded all over the place.
Commented, but ready to spring into action at the next sign of trouble.
This is another lesson in how one can't take arrays for granted,
especially, it seems, AAs. BTW tx for example of what +A does, now I
understand. Easy if it's explained clearly.
Bart:
> ... assign to array" where "array" may
be either normal or associative. But if the array doesn't already
exist, it is implicitly created as a normal array. So you must
pre-declare names with "local -A" or similar if you want them treated
as associative.
Too bad it's not created as the same type as the input. Indeed, aren't
there cases where even declared types are changed? Like, don't scalars
convert to integers when you perform arithmetic on them? By the same
logic one might expect IN to become associative by virtue of the
assignment even if it was a plain vanilla '-a' previously.
next prev parent reply other threads:[~2022-12-17 21:53 UTC|newest]
Thread overview: 45+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-12-15 23:48 Ray Andrews
2022-12-16 0:05 ` Lawrence Velázquez
2022-12-16 0:48 ` Ray Andrews
2022-12-16 1:29 ` Lawrence Velázquez
2022-12-16 2:09 ` Dominik Vogt
2022-12-16 2:56 ` Ray Andrews
2022-12-16 3:21 ` Lawrence Velázquez
2022-12-16 4:16 ` Ray Andrews
2022-12-16 10:05 ` Dominik Vogt
2022-12-16 14:13 ` Ray Andrews
2022-12-16 15:19 ` Dominik Vogt
2022-12-16 19:14 ` Ray Andrews
2022-12-16 16:30 ` Daniel Shahaf
2022-12-16 18:21 ` Ray Andrews
2022-12-16 19:04 ` Dominik Vogt
2022-12-16 20:10 ` Ray Andrews
2022-12-16 21:15 ` Dominik Vogt
2022-12-16 21:33 ` Bart Schaefer
2022-12-16 21:59 ` Dominik Vogt
2022-12-16 22:15 ` Bart Schaefer
2022-12-16 23:33 ` Ray Andrews
2022-12-17 12:47 ` Pier Paolo Grassi
2022-12-17 17:32 ` Ray Andrews
2022-12-17 18:10 ` Ray Andrews
2022-12-17 18:19 ` Roman Perepelitsa
2022-12-17 20:31 ` Ray Andrews
2022-12-17 20:49 ` Bart Schaefer
2022-12-17 21:07 ` Lawrence Velázquez
2022-12-17 21:52 ` Ray Andrews [this message]
2022-12-17 22:10 ` Bart Schaefer
2022-12-17 23:41 ` Daniel Shahaf
2022-12-18 0:15 ` Ray Andrews
2022-12-18 0:25 ` Daniel Shahaf
2022-12-18 2:13 ` Ray Andrews
2022-12-18 20:12 ` Daniel Shahaf
2022-12-18 20:26 ` Bart Schaefer
2022-12-18 20:41 ` Ray Andrews
2022-12-18 3:44 ` Lawrence Velázquez
2022-12-17 23:25 ` Daniel Shahaf
2022-12-16 21:33 ` Ray Andrews
2022-12-16 20:25 ` Daniel Shahaf
2022-12-16 21:43 ` Dominik Vogt
2022-12-16 3:20 ` Bart Schaefer
2022-12-16 4:15 ` Ray Andrews
2022-12-16 8:12 ` Roman Perepelitsa
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=a6eb3a46-5220-5c1e-ffc4-5d990c705169@eastlink.ca \
--to=rayandrews@eastlink.ca \
--cc=zsh-users@zsh.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.vuxu.org/mirror/zsh/
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).