-
Notifications
You must be signed in to change notification settings - Fork 392
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
New style namespace packages #576
base: develop
Are you sure you want to change the base?
Conversation
Hi @ksunden! Thanks for the feedback from the current Since this is something really breaking, I would like to add this to a new major version of Is it correct that the namespace convention is targeted to Whenever the time of setting a higher I would like to mention that CentOS 7 EOL is planned for 2024-06-30, and there the default system Python versions are 2.7 and (through EPEL) 3.6. PS: some of the failed jobs in the PR are not related to your changes, but to some update in the GitHub runner image around May 2023, which now does not allow to fetch |
As far as I can tell, there actually is no incompatibility with mixing older versions of mpl and newer versions of basemap (or vice versa) introduced here (outside of incompatibilities with python <3.3, which would be quite an old version of matplotlib at this point). Setuptools has for quite a while already been removing the So yes, the change takes effect in mpl 3.8, but it is more of a "make the packaging line up with what is largely already happening" than anything, so it really shouldn't be a user facing change at all. When I was investigating the change on mpl, I installed basemap (modified only so that the Looking at https://pypistats.org/packages/basemap: python3 <3.4 are not included in the stats at all, probably because there are no wheels for them python 3.4 is almost literally 0 downloads (a handful of days have a single download, but those are quite few and far between, and represent still ~0% of downloads) python 3.5 participated in a fleury of activity that 2.7 also saw in January/february, but both before and after that was quite similar to 3.4 in that there are effectively zero downloads at all. python 3.6 has a bit of a baseline of downloads at ~10/day (overall is ~1000/day to put it in prespective) so that is still ~1-2 % python 3.7 had a giant spike in early may that is visible in the overall download numbers, where it represented 80% of downloads for a week or so, but outside of that is usually ~10% python 3.8 doesn't have the spike, but is otherwise commensurate to 3.7 (I don't think anybody is suggesting getting rid of 3.9+ quite yet, so not going to analyze those, but suffice to say 3.10 is the most at ~40%, and 3.9 is second at ~30%, 3.11 is still quite low at ~5%) Python 2.7 had a fleury of activity in january to february (aligning perfectly with the 3.5 activity), but outside of that is still ~1-2%, quite similar to 3.6) Ultimately, I will go with whatever cutoff/timeline/release you choose, @molinav, but my recommendation based on these numbers would be to either require 3.7+ or follow SPEC0 and do 3.9 plus (the latter is what most of the core scientific python packages, including matplotlib, do) And of course users on older python are not completely unable to use As for the RHEL/CentOS defaults, I think the overlap of people who:
Is quite a small subset, one that I would assume is zero people until proven otherwise, and thus not weigh it highly in making maintenance decisions. (Of course if people speak up for that, that should be weighed) |
Hi there! I've been trying to package basemap for Gentoo and I've been having problems regarding the namespaces. It would seem like the fix provided by @ksunden would fix the issue, however it is not up to date with the latest commit. Are there any plans to update to the newer PEP standard? Thankd in advance! PS: I am by no means a Python/Gentoo expert. I apologize in advance for any mistakes and/or misconceptions. |
d0f51e9
to
43ed6a5
Compare
I have rebased and added changes to CI to not test on python < 3.5. I have not changed the packaging or adjusted the version number or anything, as those are decisions I leave to you, @molinav. |
So these patches should work for the 1.4.1 release, correct? Thanks in advance |
matplotlib/basemap#576 The package seems to be working :D Signed-off-by: Tomas Fabrizio Orsi <[email protected]>
@ksunden Thank you very much for the patches! The Gentoo ebuild seems to be working correctly! Have a good week |
This is a follow up to matplotlib/matplotlib#25381.
Newer setuptools is going to completely deprecate old-style namespace packages, it seems.
The newer style is to simply not have a
__init__.py
and has a few small changes to the setup.py.This conforms with PEP 420
What I have not done yet, but am willing to do (at least for the packaging/ci side of things) is up the minimum supported python version.
(partly wanted to see which CI would actually fail, if any)
Since PEP 420 is py 3.3+, that is probably the lowest version that should be continued, however all of python <=3.6 is fully end of life (and even 3.7 is end of life at the end of this month)
SPEC 0, which is adopted by much of the scientific python ecosystem, including numpy and matplotlib, would put the python version at 3.9 currently.
With this change, the following files are removed from the wheels:
basemap-1.3.7+dev-cp311-cp311-linux_x86_64.whl
basemap_data-1.3.2-py2.py3-none-any.whl
basemap_data_hires-1.3.2-py2.py3-none-any.whl
Note that setuptools was already removing the ns package
__init__.py
files from the wheels.And the following are removed from the sdist:
basemap-1.3.7+dev.tar.gz
basemap_data-1.3.2.tar.gz
basemap_data_hires-1.3.2.tar.gz
None of these changes are super surprising, and is just a consequence of PEP 420 that these are not needed, and namespace packages are implicit.