diff --git a/Cargo.toml b/Cargo.toml index ce3e8c2c4e88b81e3cabdf6fd10b2c6ba241f801..9691f1a70f989805ad692b63a9f2327cdc701469 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -16,7 +16,6 @@ pkgutils = { git = "https://github.com/redox-os/pkgutils.git" } rand = "0.3" serde = "0.8" serde_derive = "0.8" -tar = { git = "https://github.com/redox-os/tar-rs.git" } termion = "1.1" toml = { version = "0.2", default-features = false, features = ["serde"] } userutils = { git = "https://github.com/redox-os/userutils.git" } diff --git a/src/install.rs b/src/install.rs index 08ed601e7afd76561eda34b745f9d16fb80fc52a..615c63aaad6133186c31825da46237fe18d8deea 100644 --- a/src/install.rs +++ b/src/install.rs @@ -1,22 +1,22 @@ extern crate liner; extern crate pkgutils; extern crate rand; -extern crate tar; extern crate termion; extern crate userutils; use self::rand::Rng; -use self::tar::{Archive, EntryType}; use self::termion::input::TermRead; +use self::pkgutils::Repo; use std::{env, fs}; -use std::io::{self, Read, Write}; -use std::os::unix::fs::OpenOptionsExt; -use std::path::Path; +use std::io::{self, Write}; use std::str::FromStr; use config::Config; +const REMOTE: &'static str = "https://static.redox-os.org/pkg"; +const TARGET: &'static str = "x86_64-unknown-redox"; + fn unwrap_or_prompt<T: FromStr>(option: Option<T>, context: &mut liner::Context, prompt: &str) -> Result<T, String> { match option { None => { @@ -63,46 +63,6 @@ fn prompt_password(prompt: &str, confirm_prompt: &str) -> Result<String, String> } } -fn extract_inner<T: Read>(ar: &mut Archive<T>, root: &Path) -> io::Result<()> { - for entry_result in try!(ar.entries()) { - let mut entry = try!(entry_result); - match entry.header().entry_type() { - EntryType::Regular => { - let mut file = { - let mut path = root.to_path_buf(); - path.push(try!(entry.path())); - if let Some(parent) = path.parent() { - println!("Extract file parent {}", parent.display()); - try!(fs::create_dir_all(parent)); - } - println!("Extract file {}", path.display()); - try!( - fs::OpenOptions::new() - .read(true) - .write(true) - .truncate(true) - .create(true) - .mode(entry.header().mode().unwrap_or(644)) - .open(path) - ) - }; - try!(io::copy(&mut entry, &mut file)); - }, - EntryType::Directory => { - let mut path = root.to_path_buf(); - path.push(try!(entry.path())); - println!("Extract directory {}", path.display()); - try!(fs::create_dir_all(path)); - }, - other => { - panic!("Unsupported entry type {:?}", other); - } - } - } - - Ok(()) -} - pub fn install(config: Config) -> Result<(), String> { println!("Install {:#?}", config); @@ -155,20 +115,13 @@ pub fn install(config: Config) -> Result<(), String> { dir!(""); - for (packagename, _package) in config.packages { - let remote_path = format!("{}/{}/{}.tar", "https://static.redox-os.org/pkg", "x86_64-unknown-redox", packagename); - let local_path = format!("pkg/{}.tar", packagename); - if let Some(parent) = Path::new(&local_path).parent() { - println!("Create package repository {}", parent.display()); - fs::create_dir_all(parent).map_err(|err| format!("failed to create package repository {}: {}", parent.display(), err))?; - } - println!("Download package {} to {}", remote_path, local_path); - pkgutils::download(&remote_path, &local_path).map_err(|err| format!("failed to download {} to {}: {}", remote_path, local_path, err))?; + let mut repo = Repo::new(TARGET); + repo.add_remote(REMOTE); + repo.set_dest(sysroot.to_str().unwrap()); - let path = Path::new(&local_path); - println!("Extract package {}", path.display()); - let file = fs::File::open(&path).map_err(|err| format!("failed to open {}: {}", path.display(), err))?; - extract_inner(&mut Archive::new(file), &sysroot).map_err(|err| format!("failed to extract {}: {}", path.display(), err))?; + for (packagename, _package) in config.packages { + println!("Installing package {}", packagename); + repo.install(&packagename).unwrap(); } for file in config.files {