Skip to content
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

Release plans: 2.22 and 3.0 #2047

Open
henryiii opened this issue Oct 19, 2024 · 12 comments
Open

Release plans: 2.22 and 3.0 #2047

henryiii opened this issue Oct 19, 2024 · 12 comments

Comments

@henryiii
Copy link
Contributor

henryiii commented Oct 19, 2024

Description

I'd like to make a proposal for the versioning strategy and contents of the next few cibuildwheel versions. Here's the suggestion:

The next release (2.22) has the following features:

The following release of cibuildwheel I propose we call "3.0", with the following features (not a complete list):

After this point, we can shift our numbering up one, with major releases for adding/removing Pythons, minor release for features, and patch releases for bug fixes. This would allow the much-requested vX GHA tag to be something we can provide.

Thoughts?

@joerick
Copy link
Contributor

joerick commented Oct 27, 2024

The following release of cibuildwheel I propose we call "3.0", with the following features (not a complete list):

This sounds good. It especially works well with the introduction of the enable option - we can make some braver decisions there, such as dropping pypy from defaults, or changing the policy on building non-eol pythons by default if we like.

Ah yes. I'm happy to take a pass at this if you haven't started already?

After this point, we can shift our numbering up one, with major releases for adding/removing Pythons, minor release for features, and patch releases for bug fixes. This would allow the much-requested vX GHA tag to be something we can provide.

Here, I'm less sure. Personally, I see the compatibility part of our versioning system to be related to the package and configuration, not so much the Python versions that we build. That's my logic behind not being too worried about bumping major when dropping an old version. I see the specific versions of wheels produced more of an side-effect of the time that version of cibuildwheel was released, not part of the API contract.

Having said all that, we don't follow Semantic versioning anyway, so maybe the specific definition of compatibility is moot.

The bigger point is - do users need to care? When I see a package I use bump major, I'll assume there might be some work I need to do to update - read the release notes, maybe update the config files as a result. But I don't think that applies for Python addition/removal updates. The Python additions require no work (assuming you've already made the package compatible during the beta phase), and the removals are probably so old as to not be of interest (we're still building 3.6!).

Put another way - should we be requiring a major version bump to move an old version of PyPy into the pypy-eol enable group? I think it's better to reserve the major bump for circumstances where packagers need to pay attention, outside of the usual churn of interpreter versions.

@joerick
Copy link
Contributor

joerick commented Oct 27, 2024

An aside, but since we're talking about a new major version, a couple things we should consider-

  • Changing the default build-frontend to build - the only reason we're still on pip is inertia, in my opinion. Of course, the build method of doing sdist->wheel builds will break some users, who might have to switch back to pip, but I think build is a better default these days.
  • Adding delvewheel as a default option for repair-wheel-command on Windows. (cc @adang1345)

I think I'd be in favour of both, but curious of opinions.

@henryiii
Copy link
Contributor Author

the build method of doing sdist->wheel builds

That won't affect us at all, since we build with --wheel, which is a direct build, like pip's. If we made SDists, they'd collide.

Yes, more changes is fine, I was just listing what I could quickly think of.

It might be a good time to finally switch the docs to show the TOML option first, with the envvar as second tab.

As for moving to more SemVer-like versioning, it was mostly to get people to stop complaining about a lack of a vX tag. Not required if we'd rather say with the current versioning scheme.

@joerick
Copy link
Contributor

joerick commented Oct 28, 2024

That won't affect us at all, since we build with --wheel, which is a direct build, like pip's. If we made SDists, they'd collide.

Oh, I didn't know that. That's good. So build's wheel builds are 'in-tree', like pip's then?

It might be a good time to finally switch the docs to show the TOML option first, with the envvar as second tab.

Good call.

As for moving to more SemVer-like versioning, it was mostly to get people to stop complaining about a lack of a vX tag. Not required if we'd rather say with the current versioning scheme.

My opinion on this has shifted lately... I think we should just relent and make a vX tag anyway. I think that while it's probably not a good idea for serious, professional packages, there are plenty of hobbyists who just want wheel builds and don't particularly care about the details. That seems valid to me. The number of side-projects I have that get constant dependabot spam for CVEs I don't care about, the dependabot fatigue is real.

@adang1345
Copy link

Regarding adding a delvewheel default repair command, I'm not sure. I have noticed that current cibuildwheel users frequently use the --add-path option to tell delvewheel where to find DLL dependencies during the repair process, and the path used is different for each project. It may be better to require the user to manually set the repair command and just put an example command in the documentation such as delvewheel repair -w {dest_dir} {wheel}.

@henryiii henryiii pinned this issue Nov 1, 2024
@henryiii henryiii changed the title Next release versioning proposal Release plans: 2.22 and 3.0 Nov 1, 2024
@henryiii
Copy link
Contributor Author

henryiii commented Nov 1, 2024

So build's wheel builds are 'in-tree', like pip's then?

pipx build is not in-tree, it builds a wheel from an SDist. But pipx build --wheel is, as there's no SDist built.

@mayeut
Copy link
Member

mayeut commented Nov 2, 2024

I added #2052 to the list for 2.22 per #1912 (comment) comment

@EwoutH
Copy link
Contributor

EwoutH commented Nov 4, 2024

3.0 might also be an oppertunity to bump the default manylinux version:

@joerick
Copy link
Contributor

joerick commented Nov 7, 2024

Would it make sense to create a v3 branch we can start merging these new features into?

@henryiii
Copy link
Contributor Author

henryiii commented Nov 7, 2024

Aren't we just about ready to release 2.22? We just have #2048 and #2052 left. Then we can move forward with main being version 3, and make a v2 branch for back ports.

@henryiii
Copy link
Contributor Author

IMO, 2.22 is ready.

@joerick
Copy link
Contributor

joerick commented Jan 4, 2025

I think it's time to get working on v3.0. Because the utils refactor is gonna be very merge-conflicty, I'll hold off on that until there are fewer PRs waiting to go in. I think a good one to start with is #1912.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants