Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
One possible answer to typeset vs. unset
- X-seq: zsh-workers 47697
- From: Bart Schaefer <schaefer@xxxxxxxxxxxxxxxx>
- To: Zsh hackers list <zsh-workers@xxxxxxx>
- Subject: One possible answer to typeset vs. unset
- Date: Sat, 28 Nov 2020 11:49:12 -0800
- Archived-at: <https://zsh.org/workers/47697>
- Archived-at: <http://www.zsh.org/sympa/arcsearch_id/zsh-workers/2020-11/CAH%2Bw%3D7Zh8URUiLF2n1x-ZrvKO%2B%3DJC8wf%2Bn692sRsFTRbkJrzXw%40mail.gmail.com>
- Authentication-results: zsh.org; iprev=pass (mail-oi1-f171.google.com) smtp.remote-ip=209.85.167.171; dkim=pass header.d=brasslantern-com.20150623.gappssmtp.com header.s=20150623 header.a=rsa-sha256; dmarc=none header.from=brasslantern.com; arc=none
- Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=brasslantern-com.20150623.gappssmtp.com; s=20150623; h=mime-version:from:date:message-id:subject:to; bh=Y6mCZ8aiaH4KVbraUUsC90V/9oF4Cz5D9/PSXhAkPAw=; b=VF1Z7cS4+ZBGnTDvpVpO73Sw6a8UL/UfoD8BuLAewcbFVbCrPDIZ0SPPE/zIUqMX4i co9IC9LDihdhpH0xpnWfykfegGQMu7YLCUEc12gxPIU5QYHGfZbrb/XGhoqWmZnzdDLg /JQ9Oe+Q9PWz6YYVnk39NpWamB8TnOTsogSga6cTSf8YyeM6kfQTNtBzT5yFgpztSwIJ axKvfES2NPLvOvzzrxZkqfLrqbNJB0VIlNz8Si7DeKbwheNO9hhH9YA1n0ZEgxYumO8h FlX5ydaX15/pizUqLYE5OZOFlGasepTLOInQYpqKodaZPvtgU13dhYFmK1DXlCDuaBHo 9g1g==
- List-archive: <http://www.zsh.org/sympa/arc/zsh-workers>
- List-help: <mailto:sympa@zsh.org?subject=help>
- List-id: <zsh-workers.zsh.org>
- List-owner: <mailto:zsh-workers-request@zsh.org>
- List-post: <mailto:zsh-workers@zsh.org>
- List-subscribe: <mailto:sympa@zsh.org?subject=subscribe%20zsh-workers>
- List-unsubscribe: <mailto:sympa@zsh.org?subject=unsubscribe%20zsh-workers>
- Sender: zsh-workers-request@xxxxxxx
Those of you who get zsh repository commit messages will have seen
this already. Rather than send a patch here (yet), I've taken
Daniel's suggestion and created a new branch. The changes address the
issue that "typeset foo" creates $foo set to an empty string, by
concealing the internal value rather than altering the way internal
values are defaulted.
You can see these changes by checking out the "declarednull" branch.
I did not (yet) introduce an option or emulation control of this,
though I did test a build where it was predicated on emulation, and
the current default behavior is unchanged in that case.
This imposes the following changes, most of which can be amended if desired:
A typeset variable with no assignment triggers NO_UNSET warnings when
the name is used in parameter expansion or math. Incidentally, there
is no existing test that covers this; that is, NO_UNSET is tested only
with names that have never been declared or names that have been
explicitly unset.
The typeset -AEFHLRTZailux options are applied upon the first
assignment to the variable. Explicit unset before the first assignment
discards all of those properties. If any option is applied to an
existing name, historic behavior is unchanged.
Consequent to the foregoing, the (t) parameter expansion flag prints
nothing until after the first assignment, and the (i) and (I)
subscript flags also print nothing. I think the latter is one of the
more problematic consequences, especially for some completion
functions.
One that I forgot in the commit log: The behavior of "typeset foo;
typeset foo" is changed. Previously the second typeset would output
the current setting of foo:
foo=''
With these changes, that outputs nothing. However, once a value has
been assigned the historic behavior is restored, so "typeset foo=bar;
typeset foo" outputs
foo=bar
Furthermore, "typeset foo; typeset -p foo" outputs only
typeset foo
The bash behavior of "unset foo; typeset -p foo" is NOT used. This is
called out as an emulation distinction, not a change.
The test cases have not been updated, so several now fail. The test
harness has been updated to declare default values, because otherwise
the harness itself is the first thing that breaks.
Messages sorted by:
Reverse Date,
Date,
Thread,
Author