mirror of
https://github.com/TECHNOFAB11/pay-respects.git
synced 2025-12-11 22:10:09 +01:00
feat: check for command-not-found
This commit is contained in:
parent
4f75e43b7a
commit
21ded71ab6
2 changed files with 66 additions and 32 deletions
26
src/modes.rs
26
src/modes.rs
|
|
@ -5,6 +5,8 @@ use crate::{shell, suggestions};
|
|||
use colored::Colorize;
|
||||
use inquire::*;
|
||||
|
||||
use std::path::Path;
|
||||
|
||||
pub fn suggestion(data: &mut Data) {
|
||||
let shell = data.shell.clone();
|
||||
let mut last_command;
|
||||
|
|
@ -87,12 +89,31 @@ pub fn cnf(data: &mut Data) {
|
|||
}
|
||||
} else {
|
||||
let package_manager = match system::get_package_manager(data) {
|
||||
Some(package_manager) => package_manager,
|
||||
Some(package_manager) => match package_manager.as_str() {
|
||||
"apt" => {
|
||||
let cnf_dirs = [
|
||||
"/usr/lib/",
|
||||
"/data/data/com.termux/files/usr/libexec/termux/",
|
||||
];
|
||||
let mut package_manager = package_manager;
|
||||
for bin_dir in &cnf_dirs {
|
||||
let bin = format!("{}{}", bin_dir, "command-not-found");
|
||||
if Path::new(&bin).exists() {
|
||||
package_manager = bin;
|
||||
}
|
||||
}
|
||||
package_manager
|
||||
}
|
||||
_ => package_manager,
|
||||
},
|
||||
None => {
|
||||
return;
|
||||
}
|
||||
};
|
||||
|
||||
#[cfg(debug_assertions)]
|
||||
eprintln!("package_manager: {}", package_manager);
|
||||
|
||||
let packages = match system::get_packages(data, &package_manager, executable) {
|
||||
Some(packages) => packages,
|
||||
None => {
|
||||
|
|
@ -101,6 +122,9 @@ pub fn cnf(data: &mut Data) {
|
|||
}
|
||||
};
|
||||
|
||||
#[cfg(debug_assertions)]
|
||||
eprintln!("packages: {:?}", packages);
|
||||
|
||||
let style = ui::Styled::default();
|
||||
let render_config = ui::RenderConfig::default().with_prompt_prefix(style);
|
||||
let msg = format!("{}", t!("install-package")).bold().blue();
|
||||
|
|
|
|||
|
|
@ -6,7 +6,6 @@ use colored::Colorize;
|
|||
|
||||
pub fn get_package_manager(data: &mut Data) -> Option<String> {
|
||||
let package_managers = vec![
|
||||
"command-not-found", // not actually a package manager
|
||||
"apt", "dnf", "emerge", "nix", "pacman",
|
||||
// "pkg",
|
||||
// "yum",
|
||||
|
|
@ -28,21 +27,6 @@ pub fn get_packages(
|
|||
) -> Option<Vec<String>> {
|
||||
let shell = &data.shell.clone();
|
||||
match package_manager {
|
||||
"command-not-found" => {
|
||||
let result = command_output(shell, &format!("command-not-found {}", executable));
|
||||
if result.is_empty() {
|
||||
return None;
|
||||
}
|
||||
if result.contains("did you mean") || result.contains("is not installed") {
|
||||
let packages = result
|
||||
.lines()
|
||||
.skip(1)
|
||||
.map(|line| line.to_string())
|
||||
.collect();
|
||||
return Some(packages);
|
||||
}
|
||||
return None;
|
||||
}
|
||||
"apt" => {
|
||||
if !data.has_executable("apt-file") {
|
||||
eprintln!("{}: apt-file is required to find packages", "pay-respects".yellow());
|
||||
|
|
@ -148,26 +132,32 @@ pub fn get_packages(
|
|||
Some(packages)
|
||||
}
|
||||
}
|
||||
_ => unreachable!("Unsupported package manager"),
|
||||
_ => {
|
||||
match package_manager.ends_with("command-not-found") {
|
||||
true => {
|
||||
let result = command_output(shell, &format!("command-not-found {}", executable));
|
||||
if result.is_empty() {
|
||||
return None;
|
||||
}
|
||||
if result.contains("did you mean") || result.contains("is not installed") {
|
||||
let packages = result
|
||||
.lines()
|
||||
.skip(1)
|
||||
.map(|line| line.to_string())
|
||||
.collect();
|
||||
return Some(packages);
|
||||
}
|
||||
return None;
|
||||
},
|
||||
false => unreachable!("Unsupported package manager"),
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn install_package(data: &mut Data, package_manager: &str, package: &str) -> bool {
|
||||
let shell = &data.shell.clone();
|
||||
let mut install = match package_manager {
|
||||
"command-not-found" => {
|
||||
match package.starts_with("Command") {
|
||||
false => package.to_string(),
|
||||
true => {
|
||||
let split = package.split_whitespace().collect::<Vec<&str>>();
|
||||
let command = split[1];
|
||||
let package = split[split.len() - 1];
|
||||
let new_command = data.command.clone().replacen(command, package, 1);
|
||||
data.update_command(&new_command);
|
||||
format!("apt install {}", package)
|
||||
}
|
||||
}
|
||||
}
|
||||
"apt" => format!("apt install {}", package),
|
||||
"dnf" => format!("dnf install {}", package),
|
||||
"emerge" => format!("emerge {}", package),
|
||||
|
|
@ -176,10 +166,30 @@ pub fn install_package(data: &mut Data, package_manager: &str, package: &str) ->
|
|||
"pkg" => format!("pkg install {}", package),
|
||||
"yum" => format!("yum install {}", package),
|
||||
"zypper" => format!("zypper install {}", package),
|
||||
_ => unreachable!("Unsupported package manager"),
|
||||
_ => {
|
||||
match package_manager.ends_with("command-not-found") {
|
||||
true => {
|
||||
match package.starts_with("Command") {
|
||||
false => package.to_string(),
|
||||
true => {
|
||||
let split = package.split_whitespace().collect::<Vec<&str>>();
|
||||
let command = split[1];
|
||||
let package = split[split.len() - 1];
|
||||
let new_command = data.command.clone().replacen(command, package, 1);
|
||||
data.update_command(&new_command);
|
||||
format!("apt install {}", package)
|
||||
}
|
||||
}
|
||||
},
|
||||
false => unreachable!("Unsupported package manager"),
|
||||
}
|
||||
},
|
||||
};
|
||||
elevate(data, &mut install);
|
||||
|
||||
#[cfg(debug_assertions)]
|
||||
eprintln!("install: {}", install);
|
||||
|
||||
let result = Command::new(shell)
|
||||
.arg("-c")
|
||||
.arg(install)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue