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

deprecate Package.python_marker #446

Merged
merged 2 commits into from
Oct 6, 2024

Conversation

dimbleby
Copy link
Contributor

remove with_python_versions() on the grounds that

  • it has had no callers since more than two years now python-poetry/poetry@2433e0e
  • the naming convention with_ (or without_) on the package is nowadays being used to mean "a clone of the package with (or without) this thing", this collides with and confuses that
  • it's bizarre anyway

Copy link
Member

@radoering radoering left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm a little torn whether we should deprecate it before removing because there might be some plugin out there using it.

@dimbleby
Copy link
Contributor Author

dimbleby commented Sep 3, 2022

There's lots of crud in poetry-core that it's desirable to remove (I have similar queued up that I'll submit when things quieten down / I have a large enough collection). Going through deprecation periods for everything is going to get tedious.

IMO: clean up at will, note it in the changelog, do major version bumps if we think we've made possibly-breaking changes. I see nothing to be afraid of in this package going 2.0 or 10.0 or even 50.0.

@dimbleby dimbleby force-pushed the remove-python-with-versions branch from 5e7464b to 48ba7ca Compare September 7, 2022 18:07
@dimbleby
Copy link
Contributor Author

dimbleby commented Sep 7, 2022

Added a couple more removals to this MR, probably might as well discuss / make a decision for them all in the same place

  • EmptyConstraint.matches() should be uncontroversial, who knows what this was intended for but anyone who was relying on it can replace with True
  • python_marker on packages may be more interesting.
    • If any plugin was relying on this they can always reconstruct it using the removed code parse_marker(create_nested_marker(...))
    • from the point of view of poetry / poetry-core this is a great candidate for removal: that's quite a lot of work to do for every package, in code that's had more than its share of bugs, so if it's not needed then that's super news

@dimbleby
Copy link
Contributor Author

dimbleby commented Sep 7, 2022

Actually the export plugin is an example of a project that relies on the python_marker, but only for the root package.

I'm pretty neutral about whether to leave it on the root package (reasoning about cost can't matter for a single package), or have the export plugin work it out itself from the root python_constraint. Or we could just keep python_marker everywhere. Views welcome.

@dimbleby dimbleby force-pushed the remove-python-with-versions branch from 48ba7ca to 7ae4575 Compare September 24, 2022 20:22
@sonarqubecloud
Copy link

Kudos, SonarCloud Quality Gate passed!    Quality Gate passed

Bug A 0 Bugs
Vulnerability A 0 Vulnerabilities
Security Hotspot A 0 Security Hotspots
Code Smell A 0 Code Smells

No Coverage information No Coverage information
0.0% 0.0% Duplication

@dimbleby dimbleby force-pushed the remove-python-with-versions branch from 7ae4575 to 41323b5 Compare October 31, 2022 18:16
@sonarqubecloud
Copy link

Kudos, SonarCloud Quality Gate passed!    Quality Gate passed

Bug A 0 Bugs
Vulnerability A 0 Vulnerabilities
Security Hotspot A 0 Security Hotspots
Code Smell A 0 Code Smells

No Coverage information No Coverage information
0.0% 0.0% Duplication

@dimbleby dimbleby force-pushed the remove-python-with-versions branch from 41323b5 to 32f9e80 Compare January 21, 2023 12:04
@radoering
Copy link
Member

I'm pretty neutral about whether to leave it on the root package (reasoning about cost can't matter for a single package), or have the export plugin work it out itself from the root python_constraint. Or we could just keep python_marker everywhere. Views welcome.

We could make it a cached_property. Unfortunately, cached_property is not available for Python 3.7. We added a backport package in poetry. We probably had to vendor it here (or just copy https://github.com/penguinolog/backports.cached_property/blob/1.0.2/backports/cached_property/__init__.py into utils/_compat.py)?

@dimbleby
Copy link
Contributor Author

Unless profiling shows otherwise, I doubt that there's enough of a performance issue to justify adding complication.

My goal in deleting code is quite the opposite of that: I want to remove complication.

  • This is an area that has historically been buggy. No code = no bugs!
  • But mostly: it's a burden for the human reader. Whenever I get into one of those bugs that requires me to figure out what the solver is doing, I could do without having to worry about whether the python_marker is a thing that even matters

@dimbleby dimbleby force-pushed the remove-python-with-versions branch from 32f9e80 to 5f4b866 Compare January 22, 2023 14:54
@sonarqubecloud
Copy link

Kudos, SonarCloud Quality Gate passed!    Quality Gate passed

Bug A 0 Bugs
Vulnerability A 0 Vulnerabilities
Security Hotspot A 0 Security Hotspots
Code Smell A 0 Code Smells

No Coverage information No Coverage information
0.0% 0.0% Duplication

@Secrus
Copy link
Member

Secrus commented May 31, 2023

Now that we dropped Python 3.7 and cached_property availability is not an issue, are there any more blockers here?

@dimbleby
Copy link
Contributor Author

python 3.7 and cached_property are irrelevant here: per my last I have no intention of making code more complicated, the goal is to delete it.

this is blocked only by a maintainer agreeing that that is a good idea

@dimbleby dimbleby force-pushed the remove-python-with-versions branch from 5f4b866 to 2996d24 Compare May 31, 2023 08:03
@sonarqubecloud
Copy link

Kudos, SonarCloud Quality Gate passed!    Quality Gate passed

Bug A 0 Bugs
Vulnerability A 0 Vulnerabilities
Security Hotspot A 0 Security Hotspots
Code Smell A 0 Code Smells

No Coverage information No Coverage information
No Duplication information No Duplication information

@dimbleby dimbleby force-pushed the remove-python-with-versions branch from 2996d24 to 08ee00a Compare October 28, 2023 15:51
@sonarqubecloud
Copy link

Kudos, SonarCloud Quality Gate passed!    Quality Gate passed

Bug A 0 Bugs
Vulnerability A 0 Vulnerabilities
Security Hotspot A 0 Security Hotspots
Code Smell A 0 Code Smells

No Coverage information No Coverage information
No Duplication information No Duplication information

@Secrus
Copy link
Member

Secrus commented Oct 3, 2024

@dimbleby would you rebase? With 2.0 coming we are introducing breaking changes anyway, so we might as well break this too

Copy link
Member

@radoering radoering left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

With 2.0 coming we are introducing breaking changes anyway, so we might as well break this too

In general, I agree...

Actually the export plugin is an example of a project that relies on the python_marker, but only for the root package.

...but we should at least check our plugins and prepare them for the removal if we remove something they are still using.

@radoering radoering changed the title remove Package.with_python_versions() remove Package.python_marker() Oct 4, 2024
@radoering radoering changed the title remove Package.python_marker() remove Package.python_marker Oct 4, 2024
@radoering
Copy link
Member

By the way, I renamed the PR because Package.with_python_versions() has already been removed in 01b58ea so only Package.python_marker is left.

@radoering radoering force-pushed the remove-python-with-versions branch from 5aebdd1 to e1b8759 Compare October 5, 2024 11:55
@radoering radoering changed the title remove Package.python_marker deprecate Package.python_marker Oct 5, 2024
@radoering radoering merged commit a8f7ed9 into python-poetry:main Oct 6, 2024
21 checks passed
@dimbleby dimbleby deleted the remove-python-with-versions branch October 6, 2024 10:02
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

Successfully merging this pull request may close these issues.

3 participants