added first part of database

i18n
axtlos 3 years ago
parent 1d4b996ae4
commit bdbb06d6cf

@ -15,3 +15,5 @@ ansi_term = "*"
uwuizer = "*"
moins = "*"
regex = "*"
toml_edit = "*"
toml = "*"

@ -0,0 +1,80 @@
mod mods;
use mods::{clearcache::clearcache, clone::clone, help::help, install::install, inssort::inssort, search::{a_search, r_search}, uninstall::uninstall, upgrade::upgrade, update::update, ver::ver, strs::inf, strs::err_unrec, strs::err_rec, xargs::*, database::addPkg};
use std::{env, process::exit, process::Command};
fn main() {
// let statements
let args: Vec<String> = env::args().collect();
let mut pkgs: Vec<String> = env::args().skip(2).collect();
// args catch
if args.len() <= 1 {
help();
exit(1);
}
let oper = &args[1];
let noconfirm: bool = noconf(&args);
argssort(&mut pkgs);
// install
if oper == "-S" || oper == "-Sn" || oper == "ins" {
inssort(noconfirm, pkgs);
// remove
} else if oper == "-R" || oper == "-Rn " || oper == "-Rsn" || oper == "-Rs" || oper == "rm" {
uninstall(noconfirm, pkgs);
// upgrade
} else if oper == "-Syu" || oper == "-Syun" || oper == "upg" {
upgrade(noconfirm);
// update
} else if oper == "-Sy" || oper == "upd" {
update();
} else if oper == "-db" {
addPkg(pkgs);
// general search
} else if oper == "-Ss" || oper == "sea" {
r_search(&args[2]);
a_search(&args[2]);
// aur search
} else if oper == "-Sa" || oper == "aursea" {
a_search(&args[2]);
// repo search
} else if oper == "-Sr" || oper == "repsea" {
r_search(&args[2]);
// clear cache !! DEBUG ONLY !! DO NOT DO THIS IF YOU DONT KNOW WHAT YOURE DOING !!
} else if oper == "-Cc" || oper == "clr" {
clearcache();
// version / contrib
} else if oper == "-v" || oper == "-V" || oper == "ver" {
ver();
// help
} else if oper == "-h" || oper == "help" {
help();
// pacman passthrough
} else {
let pass = Command::new("pacman")
.args(env::args().skip(1))
.status()
.expect("Something has gone wrong.");
match pass.code() {
Some(1) => {
err_rec(format!("No such operation \"{}\"", args.join(" ")));
inf(format!("Try running \"ame help\" for an overview of how to use ame"))
}
Some(_) => {}
None => {
err_unrec(format!("Something has gone terribly wrong."))
}}
}
}

@ -14,6 +14,7 @@ use mods::{
upgrade::upgrade,
ver::ver,
xargs::*,
database::addPkg
};
use std::{env, process::exit, process::Command};
@ -41,6 +42,8 @@ fn main() {
upgrade(noconfirm);
} else if oper == "-Sy" || oper == "upd" {
update();
} else if oper == "-db" {
addPkg(pkgs);
} else if oper == "-Ss" || oper == "sea" {
r_search(&args[2]);
a_search(&args[2]);

@ -10,3 +10,4 @@ pub mod update;
pub mod upgrade;
pub mod ver;
pub mod xargs;
pub mod database;

@ -0,0 +1,20 @@
use toml_edit::{Document, value};
use std::io::{Read, Write};
pub fn addPkg(pkgs: Vec<String>) {
let file = format!("{}/.local/ame/aurPkgs.db", std::env::var("HOME").unwrap());
let database = std::fs::read_to_string(&file).expect("cant open new configuration");
let mut dbParsed = database.parse::<Document>().expect("invalid Database");
for i in pkgs {
let results = raur::search(&i);
for res in &results {
for r in res {
dbParsed[&i]["name"] = value(&r.name);
dbParsed[&i]["version"] = value(&r.version);
}
}
}
print!("{}",dbParsed);
}
Loading…
Cancel
Save