-
-
Notifications
You must be signed in to change notification settings - Fork 388
Description
(Reposted from Jupyter Zulip)
There are some plans for ipykernel releases and branch manipulations that I am sharing here for maximum exposure. All comments gratefully received.
The latest ipykernel release was 6.29.5 in July 2024. The current main
branch has almost but not quite complete implementations of anyio
(instead of tornado
) and subshells (JEP91) and it was originally intended that these would be in a 7.0.0 release. However, there are concerns about the use of anyio
going forward so I have instead backported subshells to the current 6.x branch so it can be released without anyio
(issue #1387).
The release of ipykernel with subshells but not anyio
could have been 6.30.0 or 7.0.0, but we have decided that 7.0.0 is more sensible. Subshells do not have to be used and the implementation is backward compatible in the sense that it passes all downstream tests in the ipykernel CI but now shell channel messages are handled in a separate thread and this could break downstream projects that are assuming otherwise, or that might now receive messages with different timings or in a different order. 7.0.0 will allow downstream projects to version gate on ipykernel<7
while they check and fix such issues.
We also think it wise to make a 6.30.0 release anyway based on the 6.x branch before subshells was added so that we can support the 6.x branch whilst projects are transferring to 7.
This needs some branch manipulation in the ipykernel repo:
main
renamed toanyio
or some other name implyingfuture
or8.x
6.x
renamed tomain
6.x
before subshells were added (commit7603443b
) becomes the head of6.x
I have sufficient permissions in the ipykernel repo to make these changes, but given the potential for messing things up I will only do in the presence of another maintainer; both Jason and Zach have previously said they might be available and are good choices being members of both the Jupyter Kernels Council and the EC.
Planned sequence of changes:
- Rename
main
toanyio
, moving across all current PRs submitted againstmain
- Rename
6.x
tomain
, set as default branch and update branch rules to protect against a push. - Use commit
7603443b
as the new head of6.x
- Backport maintainance fixes from old
main
to newmain
and6.x
branches - Release 6.30.0 from
6.x
branch - Release 7.0.0 from
main
branch - Longer term discussion on the use of
anyio
vstornado
etc
I would like to start this soon, meaning weeks rather than months.