-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
feat(yank): Support foo@version like cargo-add #10597
Conversation
In rust-lang#10472, cargo-add was merged with support for an inline version syntax of `foo@version`. That also served as the change proposal for extending that syntax to `cargo yank` for convinience and consistency. The major difference is that `cargo-add` is specifying a version-req while `cargo-yank` is specifying a version. This doesn't use the full `pkgid` syntax because that allows syntax that is unsupported here. This doesn't use `cargo-add`s parser because that is for version reqs.
r? @ehuss (rust-highfive has picked a reviewer for you, use r? to override) |
ops::yank( | ||
config, | ||
args.value_of("crate").map(|s| s.to_string()), | ||
args.value_of("version").map(|s| s.to_string()), | ||
krate.map(|s| s.to_string()), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could we remove the .map(|s| s.to_string())
for all these arguments and make ops::yank
take Option<&str>
instead?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
imo
- this is out of scope for this PR
- the use of
String
is wider than justyank
, its most Op options (though sometimes we do see a&str
or a mix ofString
and&str
) - I personally find this a point I don't have a strong preference on besides consistency.
String
is slightly more ergonomic though that is diminished by having a&Config
in theOptions
and no one will ever notice the performance difference in these (thinking back to the RustConf talk about "just clone and stop worrying about it).
8901a94
to
6f78fdc
Compare
📌 Commit 6f78fdce959def9d40deee2b454a2d9b00735ef5 has been approved by |
⌛ Testing commit 6f78fdce959def9d40deee2b454a2d9b00735ef5 with merge d2abb00f93eea9ad91cf87a6ef817353d3742600... |
💔 Test failed - checks-actions |
Looks like #10582 conflicted with this. Tests are now updated. |
@bors r+ |
📌 Commit 790e4ce has been approved by |
⌛ Testing commit 790e4ce with merge 59ccffc08fbb9a0dfac6a613d64b8ce2492a1419... |
💔 Test failed - checks-actions |
@ehuss I'm not recognizing this failure, doesn't look related, and can't reproduce it locally.
|
I'm not sure what went wrong, I haven't seen that test fail before. It looks like there was a fingerprint issue. It's definitely not related to this PR. I'm having a hard time trying to come up with any theories as to why it failed. I ran some stress tests, and couldn't get it to fail. 🤷 @bors retry |
☀️ Test successful - checks-actions |
feat(install): Support `foo@version` like cargo-add ### What does this PR try to resolve? This aims to make `cargo install` consistent with - `cargo add foo@version` from #10472 - pkgid changes in #10582 - `cargo yank foo@version` from #10597 It also offers a shorthand for people installing a specific version. ### How should we test and review this PR? #10582 acted as the FCP for this, see #10597 Documentation updates are split into their own commit to not clog up browsing the code. Examine the tests to see if they make sense ### Additional information While the `foo@vewrsion` syntax is the same, each's semantics are different. We had decided it was better to have the same syntax with different semantics than having the user worry about what syntax they use where. In `cargo install`s case, it has an implicit-but-required `=` operand while `cargo-add` allows any operand. This doesn't use the full `pkgid` syntax because that allows syntax that is unsupported here. This doesn't use `cargo-add`s parser because that is for version reqs. I held off on reusing the parser from `cargo-yank` because they had different type system needs and the level of duplication didn't seem worth it (see Rule of Three).
Update cargo 20 commits in a44758ac805600edbb6ba51e7e6fb81a6077c0cd..3f052d8eed98c6a24f8b332fb2e6e6249d12d8c1 2022-05-04 02:29:34 +0000 to 2022-05-12 15:19:04 +0000 - pre-stabilization documentation for workspace inheritance (rust-lang/cargo#10659) - test: Make curr_dir work in/out of workspace (rust-lang/cargo#10658) - Fix no_cross_doctests race condition. (rust-lang/cargo#10660) - Fix typo (rust-lang/cargo#10657) - feat(install): Support `foo@version` like cargo-add (rust-lang/cargo#10650) - fix typos found by the `typos-cli` crate (rust-lang/cargo#10649) - feat(yank): Support foo@version like cargo-add (rust-lang/cargo#10597) - add `cargo-features` to unstable docs for workspace inheritance (rust-lang/cargo#10648) - Use the traits added to the Rust 2021 Edition prelude (rust-lang/cargo#10646) - Pass `--target` to `rustdoc` for `cargo test` if specified with host target. (rust-lang/cargo#10594) - Fix use of .. in dep-info-basedir (rust-lang/cargo#10281) - fix some typos (rust-lang/cargo#10639) - Move snapshot tests into testsuite (rust-lang/cargo#10638) - Improve support of condition compilation checking (rust-lang/cargo#10566) - When documenting private items in a binary, ignore warnings about links to private items (rust-lang/cargo#10142) - Extend pkgid syntax with ``@`` support (rust-lang/cargo#10582) - move one `snapshot/add` test into `testsuite/cargo_add/` (rust-lang/cargo#10631) - Add caveat for covering features (rust-lang/cargo#10605) - Improve CARGO_ENCODED_RUSTFLAGS and CARGO_ENCODED_RUSTDOCFLAGS variables docs (rust-lang/cargo#10633) - reorganize `snapshot` tests to better work in contexts that sort by extension (rust-lang/cargo#10629)
What does this PR try to resolve?
In #10472, cargo-add was merged with support for an inline version
syntax of
cargo add foo@version
. That also served as the change proposal forextending that syntax to
cargo yank
for convenience and consistency.How should we test and review this PR?
Documentation updates are split into their own commit to not clog up browsing the code.
The ops API is generic enough that this is implemented purely in the command.
For now, the
foo@version
syntax parser is being left in the command, rather than being shared, as we see how the behavior of these different parsers diverge for their target needs to see what makes sense for refactoring. See also The Rule of Threepkgid
syntax (modified in Extend pkgid syntax with@
support #10582) because that allows syntax that is unsupported here.cargo-add
s parser because that is for version reqs.Tests were added for various combinations of flags and behavior.
Additional information
The major difference is that
cargo-add
is specifying a version-reqwhile
cargo-yank
is specifying a version. This was originally discussed on zulip and there seemed to be a desire to have one syntax rather than the user thinking about a syntax per type of version (which users won't always think about). See also #10582 which extended the pkgid spec syntax and has some more discussion on this general trend.cargo-install
will be updated in a subsequent PR.