From 82d78097c8e291f45b923790d63fa1324d447658 Mon Sep 17 00:00:00 2001 From: Ed Page Date: Wed, 23 Aug 2023 09:05:15 -0500 Subject: [PATCH] fix(update): Clarify meaning of --aggressive as --recursive When working on cargo-upgrade, I found the meaning of `--aggressive` confusing and named it `--recursive` there. Renaming this in `cargo update` (with a backwards compatible alias) was referenced in #12425. --- src/bin/cargo/commands/update.rs | 5 ++- src/cargo/ops/cargo_generate_lockfile.rs | 8 ++-- src/doc/man/cargo-update.md | 2 +- src/doc/man/generated_txt/cargo-update.txt | 2 +- src/doc/src/commands/cargo-update.md | 2 +- src/doc/src/reference/resolver.md | 2 +- src/etc/_cargo | 1 + src/etc/cargo.bashcomp.sh | 2 +- src/etc/man/cargo-update.1 | 2 +- tests/testsuite/cargo_update/help/stdout.log | 2 +- tests/testsuite/git.rs | 6 +-- tests/testsuite/update.rs | 45 ++++++++++++++++++-- 12 files changed, 59 insertions(+), 20 deletions(-) diff --git a/src/bin/cargo/commands/update.rs b/src/bin/cargo/commands/update.rs index d72c19cd266..1749de763a7 100644 --- a/src/bin/cargo/commands/update.rs +++ b/src/bin/cargo/commands/update.rs @@ -24,9 +24,10 @@ pub fn cli() -> Command { .arg_dry_run("Don't actually write the lockfile") .arg( flag( - "aggressive", + "recursive", "Force updating all dependencies of [SPEC]... as well", ) + .alias("aggressive") .conflicts_with("precise"), ) .arg( @@ -68,7 +69,7 @@ pub fn exec(config: &mut Config, args: &ArgMatches) -> CliResult { } let update_opts = UpdateOptions { - aggressive: args.flag("aggressive"), + recursive: args.flag("recursive"), precise: args.get_one::("precise").map(String::as_str), to_update, dry_run: args.dry_run(), diff --git a/src/cargo/ops/cargo_generate_lockfile.rs b/src/cargo/ops/cargo_generate_lockfile.rs index 2bcdcbefd98..265d2a883d4 100644 --- a/src/cargo/ops/cargo_generate_lockfile.rs +++ b/src/cargo/ops/cargo_generate_lockfile.rs @@ -14,7 +14,7 @@ pub struct UpdateOptions<'a> { pub config: &'a Config, pub to_update: Vec, pub precise: Option<&'a str>, - pub aggressive: bool, + pub recursive: bool, pub dry_run: bool, pub workspace: bool, } @@ -38,8 +38,8 @@ pub fn generate_lockfile(ws: &Workspace<'_>) -> CargoResult<()> { } pub fn update_lockfile(ws: &Workspace<'_>, opts: &UpdateOptions<'_>) -> CargoResult<()> { - if opts.aggressive && opts.precise.is_some() { - anyhow::bail!("cannot specify both aggressive and precise simultaneously") + if opts.recursive && opts.precise.is_some() { + anyhow::bail!("cannot specify both recursive and precise simultaneously") } if ws.members().count() == 0 { @@ -89,7 +89,7 @@ pub fn update_lockfile(ws: &Workspace<'_>, opts: &UpdateOptions<'_>) -> CargoRes let mut sources = Vec::new(); for name in opts.to_update.iter() { let dep = previous_resolve.query(name)?; - if opts.aggressive { + if opts.recursive { fill_with_deps(&previous_resolve, dep, &mut to_avoid, &mut HashSet::new()); } else { to_avoid.insert(dep); diff --git a/src/doc/man/cargo-update.md b/src/doc/man/cargo-update.md index a24330fad4f..b392b83145f 100644 --- a/src/doc/man/cargo-update.md +++ b/src/doc/man/cargo-update.md @@ -33,7 +33,7 @@ will remain locked at their currently recorded versions. If _spec_ is not specified, all dependencies are updated. {{/option}} -{{#option "`--aggressive`" }} +{{#option "`--recursive`" }} When used with _spec_, dependencies of _spec_ are forced to update as well. Cannot be used with `--precise`. {{/option}} diff --git a/src/doc/man/generated_txt/cargo-update.txt b/src/doc/man/generated_txt/cargo-update.txt index c7554c197f1..a96a34c962e 100644 --- a/src/doc/man/generated_txt/cargo-update.txt +++ b/src/doc/man/generated_txt/cargo-update.txt @@ -26,7 +26,7 @@ OPTIONS If spec is not specified, all dependencies are updated. - --aggressive + --recursive When used with spec, dependencies of spec are forced to update as well. Cannot be used with --precise. diff --git a/src/doc/src/commands/cargo-update.md b/src/doc/src/commands/cargo-update.md index e08f6f91fed..234998faa5e 100644 --- a/src/doc/src/commands/cargo-update.md +++ b/src/doc/src/commands/cargo-update.md @@ -31,7 +31,7 @@ will remain locked at their currently recorded versions.

If spec is not specified, all dependencies are updated. -

--aggressive
+
--recursive
When used with spec, dependencies of spec are forced to update as well. Cannot be used with --precise.
diff --git a/src/doc/src/reference/resolver.md b/src/doc/src/reference/resolver.md index 49beb5d60af..7d01fb167ad 100644 --- a/src/doc/src/reference/resolver.md +++ b/src/doc/src/reference/resolver.md @@ -342,7 +342,7 @@ instead. [`cargo update`] can be used to update the entries in `Cargo.lock` when new versions are published. Without any options, it will attempt to update all packages in the lock file. The `-p` flag can be used to target the update for -a specific package, and other flags such as `--aggressive` or `--precise` can +a specific package, and other flags such as `--recursive` or `--precise` can be used to control how versions are selected. [`cargo build`]: ../commands/cargo-build.md diff --git a/src/etc/_cargo b/src/etc/_cargo index a017b51c552..8df59b5f380 100644 --- a/src/etc/_cargo +++ b/src/etc/_cargo @@ -342,6 +342,7 @@ _cargo() { update) _arguments -s -S $common $manifest \ '--aggressive=[force dependency update]' \ + '--recursive=[force dependency update]' \ "--dry-run[don't actually write the lockfile]" \ '(-p --package)'{-p+,--package=}'[specify package to update]:package:_cargo_package_names' \ '--precise=[update single dependency to precise release]:release' \ diff --git a/src/etc/cargo.bashcomp.sh b/src/etc/cargo.bashcomp.sh index 33f225ebf39..23f22595b17 100644 --- a/src/etc/cargo.bashcomp.sh +++ b/src/etc/cargo.bashcomp.sh @@ -87,7 +87,7 @@ _cargo() local opt__t="$opt__test" local opt__tree="$opt_common $opt_pkg_spec $opt_feat $opt_mani $opt_lock --target -i --invert --prefix --no-dedupe --duplicates -d --charset -f --format -e --edges" local opt__uninstall="$opt_common $opt_lock $opt_pkg --bin --root" - local opt__update="$opt_common $opt_mani $opt_lock $opt_pkg --aggressive --precise --dry-run" + local opt__update="$opt_common $opt_mani $opt_lock $opt_pkg --aggressive --recursive --precise --dry-run" local opt__vendor="$opt_common $opt_mani $opt_lock $opt_sync --no-delete --respect-source-config --versioned-dirs" local opt__verify_project="$opt_common $opt_mani $opt_lock" local opt__version="$opt_common $opt_lock" diff --git a/src/etc/man/cargo-update.1 b/src/etc/man/cargo-update.1 index 0ea8db3a881..c9fe881c8fc 100644 --- a/src/etc/man/cargo-update.1 +++ b/src/etc/man/cargo-update.1 @@ -28,7 +28,7 @@ will remain locked at their currently recorded versions. If \fIspec\fR is not specified, all dependencies are updated. .RE .sp -\fB\-\-aggressive\fR +\fB\-\-recursive\fR .RS 4 When used with \fIspec\fR, dependencies of \fIspec\fR are forced to update as well. Cannot be used with \fB\-\-precise\fR\&. diff --git a/tests/testsuite/cargo_update/help/stdout.log b/tests/testsuite/cargo_update/help/stdout.log index dec044f4b7b..111ee72d4fc 100644 --- a/tests/testsuite/cargo_update/help/stdout.log +++ b/tests/testsuite/cargo_update/help/stdout.log @@ -4,7 +4,7 @@ Usage: cargo[EXE] update [OPTIONS] [SPEC]... Options: --dry-run Don't actually write the lockfile - --aggressive Force updating all dependencies of [SPEC]... as well + --recursive Force updating all dependencies of [SPEC]... as well --precise Update [SPEC] to exactly PRECISE -q, --quiet Do not print cargo log messages -v, --verbose... Use verbose output (-vv very verbose/build.rs output) diff --git a/tests/testsuite/git.rs b/tests/testsuite/git.rs index b47b3986722..7ed9b546cde 100644 --- a/tests/testsuite/git.rs +++ b/tests/testsuite/git.rs @@ -769,9 +769,9 @@ Caused by: .with_stdout("") .run(); - // Updating aggressively should, however, update the repo. - println!("dep1 aggressive update"); - p.cargo("update dep1 --aggressive") + // Updating recursively should, however, update the repo. + println!("dep1 recursive update"); + p.cargo("update dep1 --recursive") .with_stderr(&format!( "[UPDATING] git repository `{}`\n\ [UPDATING] bar v0.5.0 ([..]) -> #[..]\n\ diff --git a/tests/testsuite/update.rs b/tests/testsuite/update.rs index d7d008b2393..807072eaf6d 100644 --- a/tests/testsuite/update.rs +++ b/tests/testsuite/update.rs @@ -428,7 +428,44 @@ fn update_precise_do_not_force_update_deps() { } #[cargo_test] -fn update_aggressive() { +fn update_recursive() { + Package::new("log", "0.1.0").publish(); + Package::new("serde", "0.2.1").dep("log", "0.1").publish(); + + let p = project() + .file( + "Cargo.toml", + r#" + [package] + name = "bar" + version = "0.0.1" + authors = [] + + [dependencies] + serde = "0.2" + "#, + ) + .file("src/lib.rs", "") + .build(); + + p.cargo("check").run(); + + Package::new("log", "0.1.1").publish(); + Package::new("serde", "0.2.2").dep("log", "0.1").publish(); + + p.cargo("update serde:0.2.1 --recursive") + .with_stderr( + "\ +[UPDATING] `[..]` index +[UPDATING] log v0.1.0 -> v0.1.1 +[UPDATING] serde v0.2.1 -> v0.2.2 +", + ) + .run(); +} + +#[cargo_test] +fn update_aggressive_alias_for_recursive() { Package::new("log", "0.1.0").publish(); Package::new("serde", "0.2.1").dep("log", "0.1").publish(); @@ -465,7 +502,7 @@ fn update_aggressive() { } #[cargo_test] -fn update_aggressive_conflicts_with_precise() { +fn update_recursive_conflicts_with_precise() { Package::new("log", "0.1.0").publish(); Package::new("serde", "0.2.1").dep("log", "0.1").publish(); @@ -490,11 +527,11 @@ fn update_aggressive_conflicts_with_precise() { Package::new("log", "0.1.1").publish(); Package::new("serde", "0.2.2").dep("log", "0.1").publish(); - p.cargo("update serde:0.2.1 --precise 0.2.2 --aggressive") + p.cargo("update serde:0.2.1 --precise 0.2.2 --recursive") .with_status(1) .with_stderr( "\ -error: the argument '--precise ' cannot be used with '--aggressive' +error: the argument '--precise ' cannot be used with '--recursive' Usage: cargo[EXE] update --precise ]>