From: Jonas Bernoulli <jonas@bernoul.li>
To: Stefan Monnier <monnier@iro.umontreal.ca>
Cc: emacs-devel@gnu.org
Subject: Re: [elpa] externals/transient 667ce2b287 18/23: Use transient-default-value in transient-init-value(suffix)
Date: Fri, 27 Dec 2024 20:09:43 +0100 [thread overview]
Message-ID: <87y101osco.fsf@bernoul.li> (raw)
In-Reply-To: <jwv34i96mix.fsf-monnier+emacs@gnu.org>
Stefan Monnier <monnier@iro.umontreal.ca> writes:
>> The reason I am using Eieio's "this is not bound", is that I am doing an
>> Eieio thing here. It's not a "not bound" slot but the "not bound"
>> return value of a generic function, which isn't the same thing, but
>> pretty damn close.
>
> 🙂
>
>> Sure I can invent a new symbol just for this one case, but it would be
>> (IMO unnecessary) noise and the only reasons I would be doing it is to
>> make you happy and to avoid having a conversation about it.
I think I'll leave it as-is. Since the effect of this function
returning eieio--unbound is that the caller keeps using eieio--unbound
as the "not-a-value" marker of this slot, I think that using this symbol
is more appropriate than using any other symbol, which would obfuscate
this relationship.
> Sorry about this conversation. I'm not bothered by your use of
> `eieio--unbound`, to be honest, I was just curious.
>
> [ If I were you, I think I'd just use something like `:unbound` or
> `:transient--unbound` because it's literally less code than what you
> currently have and it would save me from having to worry about the
> annoying guy breaking compatibility again. ]
Luckily I though about this remark long enough to realize that you were
not calling me "the annoying guy". But wording that sentence like this
was a bit risky...
Anyway, sorry for the saltiness of my previous message.
>>> IOW, is there a good reason to break the abstraction here?
>> I am not sure what "the abstraction" and "here" refer to exactly.
>
> One of the abstractions is just that the `eieio--` prefix implies it's an
> internal entity to EIEIO so shouldn't be used from outside of EIEIO's
> own code.
>
> The other is that `eieio--unbound` is a value that ideally noone should
> ever see, just like `Qunbound` in Emacs's C code. Every time you use it
> you increase the risk that someone ends up storing it inside an
> EIEIO object.
My other package which uses eieio--unbound is closql, whose purpose is
to store eieio object in a sqlite database. Since Eieio support unbound
slots, I have no choice but to deal with them.
And in this package I indeed have to be super careful when dealing with
this symbol. Especially because it crosses the Lisp/SQLite border at
which point the distinction whether eieio--unbound is interned or not is
lost. (I.e., if someone actually stored an interned eieio--unbound in
an object, then we lose.)
> [ Now that I think about it... I'm no fan of EIEIO objects, especially
> that notion of a slot being unbound, so maybe I should encourage use
> of `eieio--unbound` so as to maximize the chance of mayhem. 🙂 ]
I expect that in 5 to 10 years you will present a new object system,
until then I'll stick to this one. :P
About the unbound thing, I have mixed feelings. But we all start at the
beginning, i.e., when we know nothing about something and start learning
about it. In the case of Eieio we learn (among many other things of
course) that there is such a thing as unbound slots, and if we have no
experience with other objects systems (which was the case for me), we
cannot help but assume that there is a good reason for that feature to
exist, and then move on to think about when to use it. Over time we
learn about disadvantages of the feature and when not to use it. By now
I initialize most of my slots with ":initform nil", but in a few cases
it's still useful, and I figure if it exists, I might as well use it
when that is the case. But I probably would not argue for the "unbound
unless told otherwise" default, and if this did not exist at all, I
probably would not miss it. But at this time removing this feature also
does not sound feasible.
Happy holidays!
Jonas
next prev parent reply other threads:[~2024-12-27 19:09 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <173487507772.3820862.14263838078882905942@vcs3.savannah.gnu.org>
[not found] ` <20241222134440.C5563C5C27C@vcs3.savannah.gnu.org>
2024-12-25 14:14 ` [elpa] externals/transient 667ce2b287 18/23: Use transient-default-value in transient-init-value(suffix) Stefan Monnier
2024-12-26 14:34 ` Jonas Bernoulli
2024-12-27 18:06 ` Stefan Monnier
2024-12-27 19:09 ` Jonas Bernoulli [this message]
2024-12-28 3:15 ` Stefan Monnier
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=87y101osco.fsf@bernoul.li \
--to=jonas@bernoul.li \
--cc=emacs-devel@gnu.org \
--cc=monnier@iro.umontreal.ca \
/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.savannah.gnu.org/cgit/emacs.git
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).