impl Display; remove prettyprint for compat; fix section
This commit is contained in:
parent
d1948421ce
commit
457c31b4a4
@ -4,7 +4,6 @@
|
||||
#include <assert.h>
|
||||
|
||||
#include <apt-pkg/pkgcache.h>
|
||||
#include <apt-pkg/prettyprinters.h>
|
||||
#include <apt-pkg/cachefile.h>
|
||||
|
||||
struct PCache {
|
||||
@ -52,9 +51,6 @@ extern "C" {
|
||||
const char *pkg_iter_current_version(PPkgIterator *iterator);
|
||||
const char *pkg_iter_candidate_version(PPkgIterator *iterator);
|
||||
|
||||
// freed by caller
|
||||
char *pkg_iter_pretty(PCache *cache, PPkgIterator *iterator);
|
||||
|
||||
PVerIterator *pkg_iter_ver_iter(PPkgIterator *iterator);
|
||||
void ver_iter_release(PVerIterator *iterator);
|
||||
|
||||
@ -138,15 +134,11 @@ const char *pkg_iter_current_version(PPkgIterator *wrapper) {
|
||||
}
|
||||
|
||||
const char *pkg_iter_candidate_version(PPkgIterator *wrapper) {
|
||||
return wrapper->cache->cache_file->GetPolicy()->GetCandidateVer(wrapper->iterator).VerStr();
|
||||
pkgCache::VerIterator it = wrapper->cache->cache_file->GetPolicy()->GetCandidateVer(wrapper->iterator);
|
||||
if (it.end()) {
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
char *pkg_iter_pretty(PCache *cache, PPkgIterator *wrapper) {
|
||||
assert(cache);
|
||||
assert(wrapper);
|
||||
std::stringstream ss;
|
||||
ss << APT::PrettyPkg(cache->cache_file->GetDepCache(), wrapper->iterator);
|
||||
return strdup(ss.str().c_str());
|
||||
return it.VerStr();
|
||||
}
|
||||
|
||||
PVerIterator *pkg_iter_ver_iter(PPkgIterator *wrapper) {
|
||||
|
6
build.rs
6
build.rs
@ -1,8 +1,12 @@
|
||||
extern crate gcc;
|
||||
|
||||
const SRC: &str = "apt-pkg-c/lib.cpp";
|
||||
|
||||
fn main() {
|
||||
println!("cargo:rerun-if-changed={}", SRC);
|
||||
|
||||
gcc::Config::new()
|
||||
.file("apt-pkg-c/lib.cpp")
|
||||
.file(SRC)
|
||||
.cpp(true)
|
||||
.flag("-std=gnu++11")
|
||||
.compile("libapt-pkg-c.a");
|
||||
|
@ -1,10 +1,11 @@
|
||||
extern crate apt_pkg_native;
|
||||
|
||||
use apt_pkg_native::Cache;
|
||||
use apt_pkg_native::simple;
|
||||
|
||||
fn main() {
|
||||
let mut cache = Cache::get_singleton();
|
||||
for item in cache.iter().map(|item| item.pretty_print()) {
|
||||
println!("{}", item);
|
||||
for item in cache.iter().map(simple::BinaryPackageVersions::new) {
|
||||
println!("{}: {:?}", item.pkg, item.versions);
|
||||
}
|
||||
}
|
||||
|
@ -49,7 +49,9 @@ mod tests {
|
||||
#[test]
|
||||
fn pretty_print_all() {
|
||||
let mut cache = Cache::get_singleton();
|
||||
assert!(cache.iter().map(|item| item.pretty_print()).count() > 0);
|
||||
let read_all_and_count = cache.iter().map(simple::BinaryPackageVersions::new).count();
|
||||
assert!(read_all_and_count > 2);
|
||||
assert_eq!(read_all_and_count, cache.iter().count());
|
||||
}
|
||||
|
||||
#[test]
|
||||
|
@ -41,7 +41,6 @@ extern "C" {
|
||||
pub fn pkg_iter_arch(iterator: PPkgIterator) -> *const c_char;
|
||||
pub fn pkg_iter_current_version(iterator: PPkgIterator) -> *const c_char;
|
||||
pub fn pkg_iter_candidate_version(iterator: PPkgIterator) -> *const c_char;
|
||||
pub fn pkg_iter_pretty(cache: PCache, iterator: PPkgIterator) -> *mut c_char;
|
||||
|
||||
|
||||
// Version iterators
|
||||
|
15
src/sane.rs
15
src/sane.rs
@ -127,18 +127,6 @@ impl<'c> PkgView<'c> {
|
||||
unsafe { make_owned_ascii_string(raw::pkg_iter_candidate_version(self.ptr)) }
|
||||
}
|
||||
|
||||
pub fn pretty_print(&self) -> String {
|
||||
unsafe {
|
||||
let ptr = raw::pkg_iter_pretty(self.cache.ptr, self.ptr);
|
||||
let result = ffi::CStr::from_ptr(ptr)
|
||||
.to_str()
|
||||
.expect("package names are always low-ascii")
|
||||
.to_string();
|
||||
libc::free(ptr as *mut libc::c_void);
|
||||
result
|
||||
}
|
||||
}
|
||||
|
||||
pub fn versions(&self) -> CIterator<VerIterator> {
|
||||
CIterator {
|
||||
first: true,
|
||||
@ -204,10 +192,9 @@ impl<'c> VerView<'c> {
|
||||
}
|
||||
}
|
||||
|
||||
pub fn section(&self) -> String {
|
||||
pub fn section(&self) -> Option<String> {
|
||||
unsafe {
|
||||
make_owned_ascii_string(raw::ver_iter_section(self.ptr))
|
||||
.expect("versions always have a section")
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1,27 +1,46 @@
|
||||
//! Some structs representing basic concepts, and utilities to copy out of "iterators".
|
||||
|
||||
use std::fmt;
|
||||
|
||||
use sane;
|
||||
|
||||
#[derive(Clone, Debug)]
|
||||
pub struct BinaryPackage {
|
||||
pub name: String,
|
||||
pub arch: String,
|
||||
pub current_version: Option<String>,
|
||||
pub candidate_version: Option<String>,
|
||||
}
|
||||
|
||||
impl BinaryPackage {
|
||||
pub fn new(iter: &sane::PkgView) -> Self {
|
||||
pub fn new(view: &sane::PkgView) -> Self {
|
||||
BinaryPackage {
|
||||
name: iter.name(),
|
||||
arch: iter.arch(),
|
||||
name: view.name(),
|
||||
arch: view.arch(),
|
||||
current_version: view.current_version(),
|
||||
candidate_version: view.candidate_version(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl fmt::Display for BinaryPackage {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "{}:{}", self.name, self.arch)?;
|
||||
if let Some(ref version) = self.current_version {
|
||||
write!(f, " @ {}", version)?;
|
||||
}
|
||||
if let Some(ref version) = self.candidate_version {
|
||||
write!(f, " -> {}", version)?;
|
||||
}
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug)]
|
||||
pub struct Version {
|
||||
pub version: String,
|
||||
pub arch: String,
|
||||
pub section: String,
|
||||
pub section: Option<String>,
|
||||
pub source_package: String,
|
||||
pub source_version: String,
|
||||
pub priority: i32,
|
||||
@ -29,14 +48,49 @@ pub struct Version {
|
||||
|
||||
|
||||
impl Version {
|
||||
pub fn new(iter: &sane::VerView) -> Self {
|
||||
pub fn new(view: &sane::VerView) -> Self {
|
||||
Version {
|
||||
version: iter.version(),
|
||||
arch: iter.arch(),
|
||||
section: iter.section(),
|
||||
source_package: iter.source_package(),
|
||||
source_version: iter.source_version(),
|
||||
priority: iter.priority(),
|
||||
version: view.version(),
|
||||
arch: view.arch(),
|
||||
section: view.section(),
|
||||
source_package: view.source_package(),
|
||||
source_version: view.source_version(),
|
||||
priority: view.priority(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl fmt::Display for Version {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "{}:{} in {:?} from {}:{} at {}",
|
||||
self.version,
|
||||
self.arch,
|
||||
self.section,
|
||||
self.source_package,
|
||||
self.source_version,
|
||||
self.priority,
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
#[derive(Clone, Debug)]
|
||||
pub struct BinaryPackageVersions {
|
||||
pub pkg: BinaryPackage,
|
||||
pub versions: Vec<Version>,
|
||||
}
|
||||
|
||||
impl BinaryPackageVersions {
|
||||
pub fn new(view: &sane::PkgView) -> Self {
|
||||
BinaryPackageVersions {
|
||||
pkg: BinaryPackage::new(view),
|
||||
versions: view.versions().map(Version::new).collect(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl fmt::Display for BinaryPackageVersions {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "{} + {} versions", self.pkg, self.versions.len())
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user