-
Notifications
You must be signed in to change notification settings - Fork 259
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
RFC: Python 2 support #735
Comments
What will be the minimal python3 version you are aiming for, or in other words what feature(s) of python3 line you would like to start using. here we collected some notable new features with python3 versions where they were introduced. May be there is some nice concise overview already of a similar kind? |
I think my overall feeling about nibabel is that we should be pretty conservative and support as far back as we can, but outlasting CPython itself is not a good use of effort. Python 3.4 is supposed to have a final release this month, which means it will predecease 2.7 by a little bit. So my inclination would be to support 2.7 and 3.4 through nibabel 2.4.x, and jump to 3.5+ for nibabel 3.0. We won't get f-strings or data classes, but I don't see those as particularly critical to nibabel's development. The main thing I know of that 3.6+ would buy us that makes me look forward to dropping 3.5 is insertion-ordered dictionaries obviating the need for |
Sounds reasonable to me. I wonder whether we'll need Python 2 support (via 2.4) for a year or so after Python 2 end-of-life though. I doubt that would be a lot of extra work. |
That's probably true. Mostly will mean needing to take the |
Do we need maint/ prefix? I would just have release branches like 2.3.x , 2.4.x |
It's what we've been doing. At least for 2.4.x, let's continue with this trend, following the principle of least surprise. I don't have a strong commitment to the form, though, so if the population vector points in that direction, I'm okay with dropping the |
Ah right, missed that it already exists - all good then, not worth disturbing the force |
Oh, minor amendment: Forgot that by the schedule put forward in #734, 2.5 will be due out in June (give-or-take). So that would be the final Python 2-supporting series. |
Do you guys think knowing the usage extent of Chris, regarding "The order-preserving aspect of this new implementation is considered an implementation detail and should not be relied upon (this may change in the future, but it is desired to have this new dict implementation in the language for a few releases before changing the language spec to mandate order-preserving semantics for all current and future Python implementations; this also helps preserve backwards-compatibility with older versions of the language where random iteration order is still in effect, e.g. Python 3.5)." https://docs.python.org/3.6/whatsnew/3.6.html#new-dict-implementation |
I don't know the usage extent, but I believe that PyMVPA depends on nibabel and is still Python 2-only. |
I just quickly ran pypinfo, and here are the download stats for nibabel for the last 800 days (~2 years). I think there is some noise in these numbers (and some repeat downloads I believe), but the their fractions should help us give a rough idea of usage. So python 2.7 and python 2.6 account for about 34% usage.
|
It might be just that they are just still tested against and instated using pip. And there would be a sudden drop as those projects move on ;-) I really doubt that any recent 2.6 download had a human behind it. 2.7 though IMHO will still see use for a year or two on systems where 2.7 is the default one (majority of released Linux distributions ATM? ;-)) |
True - it is possible a non-trivial portion of the downloads for python 2.7 are from CI testing matrices. That doesn't necessarily imply they are also tested for and support python 3+. It would have been awesome if we had a way to mine the |
No, GitHub's not very good about following Python dependency graphs. Many actual dependencies will fail to be detected. |
Thanks for keeping it in mind! but don't ;) There is WiP: PyMVPA/PyMVPA#525 and if we don't get it done by the time nibabel-py3-only comes about, it is Ok ;) Bringing the codebase, pieces of which were still coded for then modern python 2.4, is so much "fun" ;) |
Here is a counter suggestion: instead of supporting older versions of nibabel, we could actually help upgrade the dependent packages (with exceptions) to Python 3! that way our collective energy is better spent moving everybody to the latest than just stuck with “fun” task of maintaining older versions.. |
Some packages will have structural limitations who won’t be able to upgrade, who would have to stick with older stable releases of nibabel (although this fraction may be negligible) |
@raamana Helping projects upgrade to Python 3 seems like a good and noble thing, and if we had a hackathon (i.e., limited timeline) environment, that would be a pretty cool contribution. I'm worried about committing to too many things, though I'm happy to provide incidental help as people work toward it. I'm not sure how to advertise that effectively, though. Possibly this year's OHBM hackathon? I think our biggest legacy users are likely to be people in scientific computing environments that use old CentOS or similar. That was the cohort that submitted 2.6 compatibility patches after we officially dropped support. So probably the best thing we can do for people in that situation is to make sure that Python 2 users can't upgrade to nibabel 3.0 through normal installation procedures (pip, conda, apt-get, yum). @ignatenkobrain Are you still the yum packager? And @TheChymera were you packaging for Gentoo? |
Yes, I am packaging stuff for Gentoo. The Gentoo philosophy is to not break things unless they're broken, so python2* support will remain available for as long as any significant amount of ppl will be using it. Currently ~1500 of the Python packages we provide lack 3.* support in upstream, so the plug will not be pulled anytime soon. Regarding nipype in particular: each time I version bump it, the test suite is run for all selected python implementations, so as long as we mark it as supporting py2* I will be able to spot py2* bugs and report them, and for the reasons mentioned above, py2* will likely remain selectable for a very long time. Personally, I have moved to py3* on account of blender not supporting py2*, the only reason I continue to test things for py2* is because Gentoo makes it so easy. |
So Debian resolves this by having |
Dependency management on Gentoo can be as fine-grained as it needs to be, depending on whether I do something or nothing one of the following scenarios will happen (but I'm ok with whatever you do):
Note that none of these limitations affect people who only select a subset of the |
but since nibabel won't continue to develop their py2 compatible branch, I don't think slotting is a sustainable feature. |
Not sure if it affects your thinking here, but nipype 2.0 will be Python 3.6+, but the 1.x series is likely to continue for a while. I don't know if there will be a point at which 1.x also drops 2.7 support, or if that will simply be when 1.x development is finally abandoned. |
That simply means that the problem disappears for |
Chris @effigies - I don't mean to suggest we take any responsibility/commitment. I just mean to suggest we spend our time providing guidance: link to existing 2to3 How-Tos and tutorials, be a source of nipy-related issues/solutions, and suggest how to approach a big transition/port (if any). And in some truly subtle/complicated cases (likely rare), we can certainly fork/debug/port it. Hackathons would be a perfect opportunity to spread this activity - in fact, I might suggest this as part of TrainTrack (adds to guidance as above). |
But I also see your point on the trade-off: depending on the number of requests for help, and how small the change is (inside nibabel) to support python 2, it might be more efficient to fix it in nibabel, and encourage them migrate them on their own. Perhaps other core and long-term contributors of nipy ecosystem can weigh in here. |
@TheChymera Nipype 2 is very nearly a complete rewrite with a new architecture, so backports aren't likely to apply. Once it's released, 1.x will probably drop to mostly bug fixes. |
Hm, ok, so I'm going to continue testing for all Python versions currently marked as compatible, until you drop one and it fails and I remember you had told me here that you would drop it. Starting then I will drop the support, which will limit Gentoo users who concomitantly use python 2.7 and a more recent version to |
Sounds completely reasonable to me. Thanks! |
Just a quick note that numpy support for 3.5 began in 1.10, so that will be the new minimum numpy when we drop 2.7 and 3.4. Anything earlier and we'd need to build wheels for CI tests, which doesn't seem worth it. |
In case anybody on this thread isn't subscribed to nibabel in general, #787 is the PR for removing support for Python < 3.5.1. It also bumps the minimum numpy version to 1.12 and drops Any concerns? I assume Debian, Gentoo and Fedora (cc @sanjayankur31) are all packaging much newer numpys anyway. |
Python 2 support has officially elapsed. If someone is interested in continuing to maintain the 2.5.x series, please get in touch. |
As I'm sure we're all aware, CPython 2 support ends on January 1, 2020, and a number of projects have committed to cutting off Python 2 support in the coming year, some already having effected the change in
master
. In particular, numpy, scipy, scikit-learn and scikit-image, which nibabel either depends on or is often used in conjunction with, have all committed to ending their Python 2 support.We cannot realistically extend our support of Python 2 much farther, even if we want to. I would like to propose the upcoming 2.4 series as the last series with any Python 2 support at all, and commit to bug-fixes in 2.4.x until January 2020. This is a short timeline, but hopefully piggy-backing on the zeitgeist will help keep it from being too jarring.
I am open to someone else maintaining the 2.4.x branch for a short while after January 2020, but I think it should be short.
Assuming we settle on this scheme, nibabel 3.0 will remove all Python 2 support, and I'll do my best to ensure that the PyPI metadata will require Python 3+, so that Python 2's
pip
will not attempt to installnibabel>=3
.@nipy/core @nipy/team-nibabel @GaelVaroquaux @pauldmccarthy @afni-rickr
The text was updated successfully, but these errors were encountered: