use std::collections::HashMap;
use async_trait::async_trait;
use clap::Command;
pub mod get;
use get::WorkspaceDFGetCmd;
pub mod index;
use index::WorkspaceDFIndexCmd;
use crate::{
cli_error::UnknownSubcommand,
cmd::{RunCmd, Runners},
};
pub const NAME: &str = "df";
pub struct WorkspaceDfCmd;
#[async_trait]
impl RunCmd for WorkspaceDfCmd {
fn name(&self) -> &str {
NAME
}
fn args(&self) -> Command {
let mut command = Command::new(NAME).about(
"Interact with remote data frames. Supported types: csv, tsv, ndjson, jsonl, parquet.",
);
let sub_commands = self.get_subcommands();
for cmd in sub_commands.values() {
command = command.subcommand(cmd.args());
}
command
}
async fn run(&self, args: &clap::ArgMatches) -> Result<(), anyhow::Error> {
let sub_commands = self.get_subcommands();
if let Some((name, sub_matches)) = args.subcommand() {
let Some(cmd) = sub_commands.get(name) else {
return Err(UnknownSubcommand {
parent: "df",
name: name.to_string(),
})?;
};
tokio::task::block_in_place(|| {
tokio::runtime::Handle::current().block_on(cmd.run(sub_matches))
})?;
}
Ok(())
}
}
impl WorkspaceDfCmd {
fn get_subcommands(&self) -> Runners {
let commands: [Box<dyn RunCmd>; 2] =
[Box::new(WorkspaceDFIndexCmd), Box::new(WorkspaceDFGetCmd)];
let mut runners = HashMap::new();
for cmd in commands {
runners.insert(cmd.name().to_string(), cmd);
}
runners
}
}