(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 to anyio or some other name implying future or 8.x
6.x renamed to main
6.x before subshells were added (commit 7603443b) becomes the head of 6.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 to anyio, moving across all current PRs submitted against main
- Rename
6.x to main, set as default branch and update branch rules to protect against a push.
- Use commit
7603443b as the new head of 6.x
- Backport maintainance fixes from old
main to new main and 6.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 vs tornado etc
I would like to start this soon, meaning weeks rather than months.
(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
mainbranch has almost but not quite complete implementations ofanyio(instead oftornado) 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 ofanyiogoing forward so I have instead backported subshells to the current 6.x branch so it can be released withoutanyio(issue #1387).The release of ipykernel with subshells but not
anyiocould 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 onipykernel<7while 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:
mainrenamed toanyioor some other name implyingfutureor8.x6.xrenamed tomain6.xbefore subshells were added (commit7603443b) becomes the head of6.xI 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:
maintoanyio, moving across all current PRs submitted againstmain6.xtomain, set as default branch and update branch rules to protect against a push.7603443bas the new head of6.xmainto newmainand6.xbranches6.xbranchmainbranchanyiovstornadoetcI would like to start this soon, meaning weeks rather than months.