From 09f6efadcac7a3c6c78701518eb478c6e2bb4eab Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Wed, 24 Apr 2019 09:45:25 +0200 Subject: Implement ListFrontend::compare_packages() --- src/frontend/list.rs | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/src/frontend/list.rs b/src/frontend/list.rs index 8cff146..b229ecd 100644 --- a/src/frontend/list.rs +++ b/src/frontend/list.rs @@ -4,10 +4,13 @@ use std::ops::Deref; use librepology::v1::types::Package; use librepology::v1::types::Problem; +use librepology::v1::types::Repo; use failure::Fallible as Result; use failure::Error; use crate::frontend::Frontend; +use crate::backend::Backend; +use librepology::v1::api::Api; pub struct ListFrontend(Stdout); @@ -67,5 +70,28 @@ impl Frontend for ListFrontend { }) }) } + + fn compare_packages(&self, packages: Vec, backend: &Backend, filter_repos: Vec) -> Result<()> { + let mut output = self.0.lock(); + + for package in packages { + backend + .project(package.name().deref())? + .into_iter() + .filter(|p| filter_repos.contains(p.repo())) + .map(|upstream_package| { + writeln!(output, + "{our_package_name} - {our_package_version} - {up_repo_name} - {up_package_version}", + our_package_name = package.name().deref(), + our_package_version = package.version().deref(), + up_repo_name = upstream_package.repo().deref(), + up_package_version = upstream_package.version().deref() + ).map_err(Error::from) + }) + .collect::>>()?; + } + + Ok(()) + } } -- cgit v1.2.3