From: Jean Louis <bugs@gnu.support>
To: Michael Heerdegen <michael_heerdegen@web.de>
Cc: help-gnu-emacs@gnu.org
Subject: Re: dlet (need help): let: Symbol’s value as variable is void: wrs::variables
Date: Tue, 21 Sep 2021 07:28:47 +0300 [thread overview]
Message-ID: <YUlff+cAZCf/ZMqE@protected.localdomain> (raw)
In-Reply-To: <87pmt27s77.fsf@web.de>
* Michael Heerdegen <michael_heerdegen@web.de> [2021-09-21 02:18]:
> Jean Louis <bugs@gnu.support> writes:
>
> > I just know that this code worked, and now it doesn't:
> >
> > (dlet ((wrs::variables (make-hash-table :test 'equal))
> > (wrs::_ (puthash "areas_name" "Hyperscope" wrs::variables)))
> > )
> > [...]
> > No need to disadvise me using `dlet' as I do need it. Does anybody
> > know if this could be bug or why it does not work?
>
> I think this should be due to this:
>
> | b72f88518b Make dlet work like let, not let*
> | Mattias Engdegård <mattiase@acm.org> Sun Aug 1 17:05:48 2021 +0200
> |
> | Change `dlet` so that it has binding semantics like `let` because that
> | is what a user would expect and it allows a corresponding `dlet*` to
> | be added later should the need arise. Fortunately the change has no
> | effect where it is currently used.
>
> There was a discussion about that before the change, should not be hard
> to find if you are interested in the reasons.
>
> AFAIR there were was not much interest in adding `dlet*'.
I have dynamic binding script `rcd-template-eval'
RCD Template Interpolation System for Emacs
https://hyperscope.link/3/7/1/3/3/RCD-Template-Interpolation-System-for-Emacs.html
If I call `rcd-template-eval' from dynamic binding script, I guess
that works well.
If I call it from lexical bound script but don't use the hash to pass
it to `rcd-template-eval' that also works.
If I wish to pass a hash to function `rcd-template-eval' from lexical
bound script, that does not work without `dlet' and that is now broken
as `dlet' behaves not any more similar to `let*'
I have only 4120 WWW pages currently depending on `dlet', that is
interest large enough for function to exist.
If there is other solution that would work, I am glad to accept
it, except that I cannot and do not want to change dynamically bound
script to lexical for reasons previously explained.
--
Jean
Take action in Free Software Foundation campaigns:
https://www.fsf.org/campaigns
In support of Richard M. Stallman
https://stallmansupport.org/
prev parent reply other threads:[~2021-09-21 4:28 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-09-20 16:45 dlet (need help): let: Symbol’s value as variable is void: wrs::variables Jean Louis
2021-09-20 23:17 ` Michael Heerdegen
2021-09-21 4:28 ` Jean Louis [this message]
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
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=YUlff+cAZCf/ZMqE@protected.localdomain \
--to=bugs@gnu.support \
--cc=help-gnu-emacs@gnu.org \
--cc=michael_heerdegen@web.de \
/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.
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 read-only IMAP folder(s) and NNTP newsgroup(s).