| use cargo::core::Workspace; |
| use cargo::ops; |
| use cargo::util::{CliResult, Config}; |
| use cargo::util::important_paths::find_root_manifest_for_wd; |
| |
| #[derive(Deserialize)] |
| pub struct Options { |
| flag_manifest_path: Option<String>, |
| flag_verbose: u32, |
| flag_quiet: Option<bool>, |
| flag_color: Option<String>, |
| flag_frozen: bool, |
| flag_locked: bool, |
| #[serde(rename = "flag_Z")] |
| flag_z: Vec<String>, |
| } |
| |
| pub const USAGE: &'static str = " |
| Fetch dependencies of a package from the network. |
| |
| Usage: |
| cargo fetch [options] |
| |
| Options: |
| -h, --help Print this message |
| --manifest-path PATH Path to the manifest to fetch dependencies for |
| -v, --verbose ... Use verbose output (-vv very verbose/build.rs output) |
| -q, --quiet No output printed to stdout |
| --color WHEN Coloring: auto, always, never |
| --frozen Require Cargo.lock and cache are up to date |
| --locked Require Cargo.lock is up to date |
| -Z FLAG ... Unstable (nightly-only) flags to Cargo |
| |
| If a lockfile is available, this command will ensure that all of the git |
| dependencies and/or registries dependencies are downloaded and locally |
| available. The network is never touched after a `cargo fetch` unless |
| the lockfile changes. |
| |
| If the lockfile is not available, then this is the equivalent of |
| `cargo generate-lockfile`. A lockfile is generated and dependencies are also |
| all updated. |
| "; |
| |
| pub fn execute(options: Options, config: &mut Config) -> CliResult { |
| config.configure(options.flag_verbose, |
| options.flag_quiet, |
| &options.flag_color, |
| options.flag_frozen, |
| options.flag_locked, |
| &options.flag_z)?; |
| let root = find_root_manifest_for_wd(options.flag_manifest_path, config.cwd())?; |
| let ws = Workspace::new(&root, config)?; |
| ops::fetch(&ws)?; |
| Ok(()) |
| } |
| |