-
-
Notifications
You must be signed in to change notification settings - Fork 30.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
sub-interpreters: datetime segfaults if imported from two sub-interpreters #110415
Comments
Sorry but this does not look like a bug report. The content of the issue is a bit unrelated to the title. Could you paste your code in a minimum reproducible example so we can track it down? |
Sorry @gaogaotiantian, here is a bit of code that should demonstrate the segfault on 3.12+:
|
I'm not able to repro it with |
I am able to repro it on |
If you scan over |
The datetime module is not fully isolated. I started working on it last year, but I took a break from module isolation work around the 3.12 feature freeze, and I haven't found the energy needed to restart that work. You can take a look at the existing issue/PR: |
Duplicate of #71587 |
The major pain point of isolating |
Also, I prefer a more structured approach similar to my draft PR; a large scale change like #110420 is not optimal wrt. debugging and bisecting. I prefer to implement such changes in more manageable batches. See for example the PRs related to isolating |
Well, you might want to ask the Steering Council for confirmation, but if third-party libraries are expected to use it, then I'd call it C-API -- which means it's covered by PEP-387. |
Meta: either we close this issue as a duplicate and continue the discussion on the original issue (gh-71587), or we close the original issue as superseded. I'm +1 for the former. |
I couldn't find the old bug when I had looked for one, and this was a nice excuse for me to dip my toes in the code a little bit. Very happy to wait for the old issue/PR to be resurrected. I was considering sub-interpreters for something we wanted to do at work, but there's sadly far too many blockers like this for that to be feasible right now. Also happy to contribute in the other discussion in my own time, I find the isolated sub-interpreters to be quite a promising idea. |
Well, it is not easy to spot the old issue; the symptom is not the same, but OTOH the prescription is :) I started working with Victor on the old PR. It should be possible to split it up in manageable sizes relatively quickly. I'll ping you if you want to join. |
Bug report
Bug description:
I've started putting a branch together that moves all the global state into a module-level state object.
If that looks useful, I'll continue to work on it and can rebase on main.
It passes tests and "works on my machine".
I haven't looked at python internals in some time, so apologies if I'm a little rusty!
CPython versions tested on:
3.12, CPython main branch
Operating systems tested on:
Linux
Linked PRs
The text was updated successfully, but these errors were encountered: