Radish alpha
h
Radicle Heartwood Protocol & Stack
Radicle
Git (anonymous pull)
Log in to clone via SSH
cli/checkout: use Clap
✗ CI failure Richard Levitte committed 6 months ago
commit 06e22434e13a79c27ca7eeabf9d2b6a05b3d2ef4
parent 28824a312764bdc83c6afaee232583e07a8101b1
3 failed (3 total) View logs
4 files changed +43 -74
modified crates/radicle-cli/src/commands/checkout.rs
@@ -1,5 +1,6 @@
#![allow(clippy::box_default)]
-
use std::ffi::OsString;
+
mod args;
+

use std::path::PathBuf;

use anyhow::anyhow;
@@ -12,80 +13,22 @@ use radicle::storage::git::transport;

use crate::project;
use crate::terminal as term;
-
use crate::terminal::args::{Args, Error, Help};
-

-
pub const HELP: Help = Help {
-
    name: "checkout",
-
    description: "Checkout a repository into the local directory",
-
    version: env!("RADICLE_VERSION"),
-
    usage: r#"
-
Usage
-

-
    rad checkout <rid> [--remote <did>] [<option>...]
-

-
    Creates a working copy from a repository in local storage.
-

-
Options
-

-
    --remote <did>  Remote peer to checkout
-
    --no-confirm    Don't ask for confirmation during checkout
-
    --help          Print help
-
"#,
-
};

-
pub struct Options {
-
    pub id: RepoId,
-
    pub remote: Option<Did>,
-
}
-

-
impl Args for Options {
-
    fn from_args(args: Vec<OsString>) -> anyhow::Result<(Self, Vec<OsString>)> {
-
        use lexopt::prelude::*;
-

-
        let mut parser = lexopt::Parser::from_args(args);
-
        let mut id = None;
-
        let mut remote = None;
-

-
        while let Some(arg) = parser.next()? {
-
            match arg {
-
                Long("no-confirm") => {
-
                    // Ignored for now.
-
                }
-
                Long("help") | Short('h') => return Err(Error::Help.into()),
-
                Long("remote") => {
-
                    let val = parser.value().unwrap();
-
                    remote = Some(term::args::did(&val)?);
-
                }
-
                Value(val) if id.is_none() => {
-
                    id = Some(term::args::rid(&val)?);
-
                }
-
                _ => anyhow::bail!(arg.unexpected()),
-
            }
-
        }
-

-
        Ok((
-
            Options {
-
                id: id.ok_or_else(|| anyhow!("a repository to checkout must be provided"))?,
-
                remote,
-
            },
-
            vec![],
-
        ))
-
    }
-
}
+
pub use args::Args;
+
pub(crate) use args::ABOUT;

-
pub fn run(options: Options, ctx: impl term::Context) -> anyhow::Result<()> {
+
pub fn run(args: Args, ctx: impl term::Context) -> anyhow::Result<()> {
    let profile = ctx.profile()?;
-
    execute(options, &profile)?;
+
    execute(args, &profile)?;

    Ok(())
}

-
fn execute(options: Options, profile: &Profile) -> anyhow::Result<PathBuf> {
-
    let id = options.id;
+
fn execute(args: Args, profile: &Profile) -> anyhow::Result<PathBuf> {
    let storage = &profile.storage;
-
    let remote = options.remote.unwrap_or(profile.did());
+
    let remote = args.remote.unwrap_or(profile.did());
    let doc = storage
-
        .repository(id)?
+
        .repository(args.repo)?
        .identity_doc()
        .context("repository could not be found in local storage")?;
    let payload = doc.project()?;
@@ -98,7 +41,7 @@ fn execute(options: Options, profile: &Profile) -> anyhow::Result<PathBuf> {
    }

    let mut spinner = term::spinner("Performing checkout...");
-
    let repo = match radicle::rad::checkout(options.id, &remote, path.clone(), &storage, false) {
+
    let repo = match radicle::rad::checkout(args.repo, &remote, path.clone(), &storage, false) {
        Ok(repo) => repo,
        Err(err) => {
            spinner.failed();
@@ -124,7 +67,7 @@ fn execute(options: Options, profile: &Profile) -> anyhow::Result<PathBuf> {
    // Setup remote tracking branches for project delegates.
    setup_remotes(
        project::SetupRemote {
-
            rid: id,
+
            rid: args.repo,
            tracking: Some(payload.default_branch().clone()),
            repo: &repo,
            fetch: true,
added crates/radicle-cli/src/commands/checkout/args.rs
@@ -0,0 +1,24 @@
+
use clap::Parser;
+
use radicle::prelude::{Did, RepoId};
+

+
pub(crate) const ABOUT: &str = "Checkout a repository into the local directory";
+
const LONG_ABOUT: &str = r#"
+
Creates a working copy from a repository in local storage.
+
"#;
+

+
#[derive(Debug, Parser)]
+
#[command(about = ABOUT, long_about = LONG_ABOUT, disable_version_flag = true)]
+
pub struct Args {
+
    /// Repository ID of the repository to checkout
+
    #[arg(value_name = "RID")]
+
    pub(super) repo: RepoId,
+

+
    /// The DID of the remote peer to checkout
+
    #[arg(long, value_name = "DID")]
+
    pub(super) remote: Option<Did>,
+

+
    /// Don't ask for confirmation during checkout
+
    // TODO(erikli): This is obsolete and should be removed
+
    #[arg(long)]
+
    no_confirm: bool,
+
}
modified crates/radicle-cli/src/commands/help.rs
@@ -45,7 +45,10 @@ const COMMANDS: &[CommandItem] = &[
        name: "block",
        about: crate::commands::block::ABOUT,
    },
-
    CommandItem::Lexopt(crate::commands::checkout::HELP),
+
    CommandItem::Clap {
+
        name: "checkout",
+
        about: crate::commands::checkout::ABOUT,
+
    },
    CommandItem::Clap {
        name: "clone",
        about: crate::commands::clone::ABOUT,
modified crates/radicle-cli/src/main.rs
@@ -47,6 +47,7 @@ struct CliArgs {
enum Commands {
    Auth(auth::Args),
    Block(block::Args),
+
    Checkout(checkout::Args),
    Clean(clean::Args),
    Clone(clone::Args),
    Debug(debug::Args),
@@ -209,11 +210,9 @@ pub(crate) fn run_other(exe: &str, args: &[OsString]) -> Result<(), Option<anyho
            }
        }
        "checkout" => {
-
            term::run_command_args::<checkout::Options, _>(
-
                checkout::HELP,
-
                checkout::run,
-
                args.to_vec(),
-
            );
+
            if let Some(Commands::Checkout(args)) = CliArgs::parse().command {
+
                term::run_command_fn(checkout::run, args);
+
            }
        }
        "clone" => {
            if let Some(Commands::Clone(args)) = CliArgs::parse().command {