use eyre::Result;
use crate::backend::unalias_backend;
use crate::toolset::install_state;
use crate::ui::multi_progress_report::MultiProgressReport;
use crate::ui::style;
use crate::{backend, plugins};
#[derive(Debug, clap::Args)]
#[clap(verbatim_doc_comment, visible_aliases = ["remove", "rm"], after_long_help = AFTER_LONG_HELP)]
pub struct PluginsUninstall {
#[clap(verbatim_doc_comment)]
plugin: Vec<String>,
#[clap(long, short, verbatim_doc_comment, conflicts_with = "plugin")]
all: bool,
#[clap(long, short, verbatim_doc_comment)]
purge: bool,
}
impl PluginsUninstall {
pub async fn run(self) -> Result<()> {
let mpr = MultiProgressReport::get();
let plugins = match self.all {
true => install_state::list_plugins().keys().cloned().collect(),
false => self.plugin.clone(),
};
for plugin_name in plugins {
let plugin_name = unalias_backend(&plugin_name);
self.uninstall_one(plugin_name, &mpr).await?;
}
Ok(())
}
async fn uninstall_one(&self, plugin_name: &str, mpr: &MultiProgressReport) -> Result<()> {
if let Ok(plugin) = plugins::get(plugin_name) {
if plugin.is_installed() {
let prefix = format!("plugin:{}", style::eblue(&plugin.name()));
let pr = mpr.add(&prefix);
plugin.uninstall(pr.as_ref()).await?;
if self.purge {
let backend = backend::get(&plugin_name.into()).unwrap();
backend.purge(pr.as_ref())?;
}
pr.finish_with_message("uninstalled".into());
} else {
warn!("{} is not installed", style::eblue(plugin_name));
}
} else {
warn!("{} is not installed", style::eblue(plugin_name));
}
Ok(())
}
}
static AFTER_LONG_HELP: &str = color_print::cstr!(
r#"<bold><underline>Examples:</underline></bold>
$ <bold>mise plugins uninstall cmake</bold>
"#
);