[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: Circular records: how do I best handle them? (The new correct warni
From: |
Stefan Monnier |
Subject: |
Re: Circular records: how do I best handle them? (The new correct warning position branch now bootstraps in native compilation!) |
Date: |
Sun, 26 Dec 2021 15:35:35 -0500 |
User-agent: |
Gnus/5.13 (Gnus v5.13) Emacs/29.0.50 (gnu/linux) |
>> Hmm... circularity is quite normal in data structures, yes.
>> But presumably this is only applied to source code where circularity is
>> very rare. Could it be that you end up recursing in elements which
>> actually aren't part of the source code (and hence can't have
>> symbols-with-positions)?
> I honestly don't know at the moment.
I think it's worth the effort to try and track this down. Maybe we can
completely circumvent the problem.
>> Also, I see in `byte-compile-strip-s-p-1` that you only look inside conses
>> and vectors. So I'm not sure what makes you say the recursion was in
>> records since records are similar to vectors but aren't `vectorp` so
>> AFAICT your code won't recurse into them.
>
> byte-compile-strip-s-p-1 has been enhanced to handle records, too,
> though I haven't committed that bit yet (along with quite a lot of other
> amendments, too).
Hmm... now that I think about it, you only generate
symbols-with-positions (symposes) when byte-compiling, right?
And you can restrict this to the case where we byte-compile into a file
(as opposed to the rare case where we just call `byte-compile`).
So the symposes can end up in 2 places:
- in the .elc file: no need to strip the pos here, just make sure the
symbols get printed without their position.
- elsewhere: that's the problematic part because this only occurs where
the source code gets stealthy passed elsewhere, e.g. when a macro
calls (put ARG1 'foo ARG2) during the macro expansion (rather than
returning that chunk of code in the expansion). Here we don't have
much control over where the symposes end up and I don't think
`byte-compile-strip-s-p` can help us (unless we call it before passing
the result to the macro, but I don't think that's what we want to do).
So where/why do we need `byte-compile-strip-s-p`?
>> That's what we do elsewhere, yes, except that history taught us that
>> a hash-table is a better choice to avoid scalability problems.
>> Tho in your case you'd only need to keep the stack of objects inside of
>> which you're currently recursing, so maybe a list is good enough.
> I've tried the list approach (using memq to check for an already
> processed cons/vector/record. It fell flat on its face with
> lisp/leim/ja-dic/ja-dec.el, which has a list with over 60,000 strings
> in it.
Oh, right, we have to add to the list all the conses rather than only
the head conses, so you definitely want to use a hash-table.
Stefan