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

Update to semver 1.0.0 #9508

Merged
merged 3 commits into from
May 27, 2021
Merged

Update to semver 1.0.0 #9508

merged 3 commits into from
May 27, 2021

Conversation

dtolnay
Copy link
Member

@dtolnay dtolnay commented May 26, 2021

I am working on a 1.0.0 of the semver crate some time this week. It would be good to confirm Cargo will be able to use it, beforehand!

It's a from-scratch rewrite, but dtolnay/semver#237 has code to compare against 0.10.0 (currently used by Cargo) how every possible version requirement currently published to crates.io matches against every possible crate version. The differences are all broken syntax like ^0-.11.0 previously parsing with ".11.0" as a pre-release string (which is invalid, because pre-release are not allowed to contain empty dot-separated identifiers) and ~2.0-2.2 previously parsing with "2.2" as a pre-release string, when the user almost certainly meant >=2.0, <=2.2. I'm not sure how much of those you want to add code into Cargo to preserve behavior, but I would be happy to do it.

@rust-highfive
Copy link

r? @ehuss

(rust-highfive has picked a reviewer for you, use r? to override)

@rust-highfive rust-highfive added the S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. label May 26, 2021
Comment on lines 116 to 120
".*" => "*",
"0.1.0." => "0.1.0",
"0.3.1.3" => "0.3.13",
"0.2*" => "0.2.*",
"*.0" => "*",
Copy link
Member Author

Choose a reason for hiding this comment

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

These are copied from dtolnay/semver#93.

Copy link
Member

Choose a reason for hiding this comment

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

Thanks for keeping the compat here! That being said the warning below says that it will soon become a hard error, and that was added 5 years ago in #3154. I think it's probably fine to just delete all this at this point (and I'm glad you moved this logic to Cargo from the semver crate itself!)

Copy link
Member Author

Choose a reason for hiding this comment

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

Good call 😛 I've deleted the compatibility code in 396bdd3.

Comment on lines 174 to 179
Some(v) => (true, parse_req_with_deprecated(name, v, arg)?),
None => (false, VersionReq::any()),
Some(v) => (true, parse_req_with_deprecated(name, v, arg)?.into()),
None => (false, OptVersionReq::Any),
Copy link
Member Author

@dtolnay dtolnay May 26, 2021

Choose a reason for hiding this comment

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

"Any" is not considered a VersionReq, because there is no semver syntax that literally matches any version. * is not that, because of how https://github.com/semver/semver/blob/efcff2c838c9945f79bfd21c1df0073271bcc29c/ranges.md suggests handling pre-release versions:

  • SemVer Versions containing PRERELEASE identifiers MUST NOT be included by a SemVer Comparator Set unless they are included by all of the Comparators in the Comparator Set, and one or more of the following conditions are met:

    • The implementation has provided the user with an option to explicitly include PRERELEASE versions, and the user has set this option. This SHOULD NOT be the default behavior when resolving software dependencies.

    • One or more of the Comparators in the Comparator Set have the same MAJOR, MINOR, and PATCH version as the SemVer Version string being considered, and has a PRERELEASE version, and would normally include the SemVer Version string by virtue of precedence comparison.

      For example, the Range >=1.0.0-alpha would include the Version 1.0.0-beta but not the Version 1.0.1-beta.

In previous versions of the semver crate, VersionReq::any() would literally mean any, which is different from *, and it would match any version. But upon roundtrip through a string, it would decay to *, because again there is no semver syntax that means "any".

Instead I'm suggesting that Cargo use something effectively like Option<VersionReq> with an absent VersionReq meaning "any", and the equivalent of .map_or(true, |req| req.matches(version)) for matching.

@Eh2406
Copy link
Contributor

Eh2406 commented May 26, 2021

Thank you for working on semver!
The brakeage documented in dtolnay/semver#237 is ok by me, but I think will need the consent of the full team.

Copy link
Member

@alexcrichton alexcrichton left a comment

Choose a reason for hiding this comment

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

Thanks for doing this @dtolnay! This all looks good to me and I would personally be ok merging. We may end up discovering one or two things that are problematic, but that's just a fear of "well things are always weird in the wild". If that comes up we can always figure out how to deal with it. It sounds like you've otherwise handled other known issues, hence me being comfortable landing this.

Comment on lines 116 to 120
".*" => "*",
"0.1.0." => "0.1.0",
"0.3.1.3" => "0.3.13",
"0.2*" => "0.2.*",
"*.0" => "*",
Copy link
Member

Choose a reason for hiding this comment

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

Thanks for keeping the compat here! That being said the warning below says that it will soon become a hard error, and that was added 5 years ago in #3154. I think it's probably fine to just delete all this at this point (and I'm glad you moved this logic to Cargo from the semver crate itself!)

@dtolnay dtolnay changed the title Update to semver 1.0.0-rc Update to semver 1.0.0 May 26, 2021
@alexcrichton alexcrichton added the T-cargo Team: Cargo label May 26, 2021
@alexcrichton
Copy link
Member

@rfcbot fcp merge

👍 thanks again for this @dtolnay!

@rfcbot
Copy link
Collaborator

rfcbot commented May 26, 2021

Team member @alexcrichton has proposed to merge this. The next step is review by the rest of the tagged team members:

No concerns currently listed.

Once a majority of reviewers approve (and at most 2 approvals are outstanding), this will enter its final comment period. If you spot a major issue that hasn't been raised at any point in this process, please speak up!

See this document for info about what commands tagged team members can give me.

@rfcbot rfcbot added proposed-final-comment-period An FCP proposal has started, but not yet signed off. disposition-merge FCP with intent to merge labels May 26, 2021
@Eh2406
Copy link
Contributor

Eh2406 commented May 27, 2021

From the description of the situation around Any it sounds like a mess. If we need the concept of Any then if feels dangerous to have it change meaning when it is serialized. If we can use * instead then we should.

Also now that a lot more internals of a semver are available we should look at how meny of our hacks can be simplified.

But all of that can be looked at in flow up PR. So I am +1.

@rfcbot
Copy link
Collaborator

rfcbot commented May 27, 2021

🔔 This is now entering its final comment period, as per the review above. 🔔

@rfcbot rfcbot added final-comment-period FCP — a period for last comments before action is taken and removed proposed-final-comment-period An FCP proposal has started, but not yet signed off. labels May 27, 2021
@ehuss
Copy link
Contributor

ehuss commented May 27, 2021

Thanks for being so thorough!

Just to be clear, the current crates in the index that will now fail are:

Bad versions:

  • volatile 0.4.0-alpha.00
  • volatile 0.4.0-alpha.01
  • bluetooth_client 0.0.1-001
  • hxgm30-client 0.3.0-alpha.01

Bad requirements:

  • lmdb-rkv-sys 0.9.4 -> bindgen ^0.51-oldsyn
  • raft 0.5.0 -> protobuf ~2.0-2.2
  • solstice-2d 0.1.2 -> solstice ^0.1-alpha.0
  • solstice-2d 0.2.0 -> solstice ^0.1-alpha.0
  • solstice-2d 0.2.1 -> solstice ^0.1-alpha.0
  • solstice-2d 0.2.2 -> solstice ^0.1-alpha.0
  • solstice-2d 0.2.3 -> solstice ^0.1-alpha.0
  • solstice-2d 0.2.5 -> solstice ^0.1-alpha.0
  • solstice-2d 0.2.6 -> solstice ^0.1-alpha.0
  • solstice-2d 0.2.7 -> solstice ^0.1-alpha.0
  • solstice-2d 0.2.8 -> solstice ^0.1-alpha.0
  • tma 0.1.0 -> error-chain ^0-.11.0
  • tma 0.1.1 -> error-chain ^0-.11.0

To the best of my knowledge, these entries in the local cache will just cause the cache to be rebuilt. Otherwise, Cargo will behave as-if these releases don't exist.

@ehuss
Copy link
Contributor

ehuss commented May 27, 2021

@bors r+

@bors
Copy link
Contributor

bors commented May 27, 2021

📌 Commit 7ace447 has been approved by ehuss

@bors bors added S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels May 27, 2021
@bors
Copy link
Contributor

bors commented May 27, 2021

⌛ Testing commit 7ace447 with merge 7c479d26ca12eccafeb15aa5ae3c5507373236e2...

@bors
Copy link
Contributor

bors commented May 27, 2021

💔 Test failed - checks-actions

@bors bors added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. and removed S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. labels May 27, 2021
@alexcrichton
Copy link
Member

That'll get fixed by #9517, will retry once that merges first.

@alexcrichton
Copy link
Member

@bors: retry

@bors bors added S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels May 27, 2021
@bors
Copy link
Contributor

bors commented May 27, 2021

⌛ Testing commit 7ace447 with merge 2f3df16...

@bors
Copy link
Contributor

bors commented May 27, 2021

☀️ Test successful - checks-actions
Approved by: ehuss
Pushing 2f3df16 to master...

@bors bors merged commit 2f3df16 into rust-lang:master May 27, 2021
@dtolnay dtolnay deleted the semver branch May 27, 2021 23:19
JohnTitor added a commit to JohnTitor/rust that referenced this pull request Jun 3, 2021
Update cargo

10 commits in e931e4796b61de593aa1097649445e535c9c7ee0..0cecbd67323ca14a7eb6505900d0d7307b00355b
2021-05-24 16:17:27 +0000 to 2021-06-01 20:09:13 +0000
- Configure hosts separately from targets when --target is specified. (rust-lang/cargo#9322)
- Add some validation to rustc-link-arg (rust-lang/cargo#9523)
- Implement suggestions for unknown features in workspace (rust-lang/cargo#9420)
- Extract common `make_dep_path` to cargo_util (rust-lang/cargo#9529)
- Add a note about rustflags compatibility. (rust-lang/cargo#9524)
- Consolidate doc collision detection. (rust-lang/cargo#9526)
- Add `--depth` option for `cargo-tree` (rust-lang/cargo#9499)
- `cargo tree -e no-proc-macro` to hide procedural macro dependencies (rust-lang/cargo#9488)
- Update to semver 1.0.0 (rust-lang/cargo#9508)
- Update tar dependency to 0.4.35 (rust-lang/cargo#9517)
@SergioBenitez
Copy link
Contributor

This seems to contain a breaking change where previously version strings like 0.11.x were accepted to mean 0.11.* but now error. See, for instance, https://github.com/Arnavion/derive-error-chain/blob/ed2fafa0354b10df889cf46042651a91a02d58bf/derive-error-chain/Cargo.toml, which is causing a failure in diesel on nightly: diesel-rs/diesel#2797.

JohnTitor added a commit to JohnTitor/rust that referenced this pull request Jun 4, 2021
@rfcbot rfcbot added finished-final-comment-period FCP complete to-announce and removed final-comment-period FCP — a period for last comments before action is taken labels Jun 6, 2021
rhdxmr added a commit to foniod/redbpf that referenced this pull request Jul 17, 2021
rhdxmr added a commit to foniod/redbpf that referenced this pull request Jul 19, 2021
ramnivas added a commit to exograph/exograph that referenced this pull request Jul 29, 2021
Cargo in the latest version upgraded the server dependency
(rust-lang/cargo#9508). As a result, it no
longer accepts "" as a version. So we now use a specific version of
all such usage.
ramnivas added a commit to exograph/exograph that referenced this pull request Jul 30, 2021
* Fix cargo failures on rust version 1.54

Cargo in the latest version upgraded the server dependency (rust-lang/cargo#9508). As a result, it no longer accepts "" as a version. So we now use a specific version of all such usage.

* Fix new clippy warnings new to Rust 1.54
jeanphilippeD pushed a commit to jeanphilippeD/raft-rs that referenced this pull request Aug 2, 2021
With this, rust-lang/cargo#9508, the dependency can no longer be used.
What was picked with 1.53 cargo was ~2.0, so use that instead.

Test:
verify dependency can now be used
jeanphilippeD pushed a commit to jeanphilippeD/raft-rs that referenced this pull request Aug 2, 2021
With this, rust-lang/cargo#9508, the dependency can no longer be used.
What was picked with 1.53 cargo was ~2.0, so use that instead.

Test:
verify dependency can now be used

Signed-off-by: Jean-Philippe DUFRAIGNE <[email protected]>
@ehuss ehuss added this to the 1.54.0 milestone Feb 6, 2022
shadaj pushed a commit to exograph/exograph that referenced this pull request Apr 20, 2023
* Fix cargo failures on rust version 1.54

Cargo in the latest version upgraded the server dependency (rust-lang/cargo#9508). As a result, it no longer accepts "" as a version. So we now use a specific version of all such usage.

* Fix new clippy warnings new to Rust 1.54
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
disposition-merge FCP with intent to merge finished-final-comment-period FCP complete S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. T-cargo Team: Cargo
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants