add package detail accessors
* short description * long description * maintainer * homepage Requires constructing a pkgRecords::Parser to read for some reason. AFAICT this parser is bound to the pkgRecords instance and deleted together with it, so it doesn't require an explicit delete/free.
This commit is contained in:
parent
1018536523
commit
07c92f003b
@ -17,6 +17,9 @@ struct PCache {
|
|||||||
|
|
||||||
// Borrowed from cache_file.
|
// Borrowed from cache_file.
|
||||||
pkgCache *cache;
|
pkgCache *cache;
|
||||||
|
|
||||||
|
// Owned by us.
|
||||||
|
pkgRecords *records;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct PPkgIterator {
|
struct PPkgIterator {
|
||||||
@ -41,6 +44,9 @@ struct PVerIterator {
|
|||||||
struct PVerFileIterator {
|
struct PVerFileIterator {
|
||||||
// Owned by us.
|
// Owned by us.
|
||||||
pkgCache::VerFileIterator iterator;
|
pkgCache::VerFileIterator iterator;
|
||||||
|
|
||||||
|
// Borrow of "static" PCache.
|
||||||
|
PCache *cache;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct PPkgFileIterator {
|
struct PPkgFileIterator {
|
||||||
@ -48,6 +54,10 @@ struct PPkgFileIterator {
|
|||||||
pkgCache::PkgFileIterator iterator;
|
pkgCache::PkgFileIterator iterator;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct PVerFileParser {
|
||||||
|
pkgRecords::Parser *parser;
|
||||||
|
};
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
void init_config_system();
|
void init_config_system();
|
||||||
|
|
||||||
@ -101,6 +111,15 @@ extern "C" {
|
|||||||
void ver_file_iter_next(PVerFileIterator *iterator);
|
void ver_file_iter_next(PVerFileIterator *iterator);
|
||||||
bool ver_file_iter_end(PVerFileIterator *iterator);
|
bool ver_file_iter_end(PVerFileIterator *iterator);
|
||||||
|
|
||||||
|
// ver_file_parser creation
|
||||||
|
PVerFileParser *ver_file_iter_get_parser(PVerFileIterator *iterator);
|
||||||
|
|
||||||
|
// ver_file_parser access
|
||||||
|
const char *ver_file_parser_short_desc(PVerFileParser *parser);
|
||||||
|
const char *ver_file_parser_long_desc(PVerFileParser *parser);
|
||||||
|
const char *ver_file_parser_maintainer(PVerFileParser *parser);
|
||||||
|
const char *ver_file_parser_homepage(PVerFileParser *parser);
|
||||||
|
|
||||||
// ver_file_iter has no accessors, only the creation of pkg_file_iter
|
// ver_file_iter has no accessors, only the creation of pkg_file_iter
|
||||||
|
|
||||||
|
|
||||||
@ -133,16 +152,19 @@ void init_config_system() {
|
|||||||
PCache *pkg_cache_create() {
|
PCache *pkg_cache_create() {
|
||||||
pkgCacheFile *cache_file = new pkgCacheFile();
|
pkgCacheFile *cache_file = new pkgCacheFile();
|
||||||
pkgCache *cache = cache_file->GetPkgCache();
|
pkgCache *cache = cache_file->GetPkgCache();
|
||||||
|
pkgRecords *records = new pkgRecords(*cache);
|
||||||
|
|
||||||
PCache *ret = new PCache();
|
PCache *ret = new PCache();
|
||||||
ret->cache_file = cache_file;
|
ret->cache_file = cache_file;
|
||||||
ret->cache = cache;
|
ret->cache = cache;
|
||||||
|
ret->records = records;
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
void pkg_cache_release(PCache *cache) {
|
void pkg_cache_release(PCache *cache) {
|
||||||
// TODO: is cache->cache cleaned up with cache->cache_file?
|
// TODO: is cache->cache cleaned up with cache->cache_file?
|
||||||
|
delete cache->records;
|
||||||
delete cache->cache_file;
|
delete cache->cache_file;
|
||||||
delete cache;
|
delete cache;
|
||||||
}
|
}
|
||||||
@ -264,6 +286,7 @@ const char *ver_iter_arch(PVerIterator *wrapper) {
|
|||||||
PVerFileIterator *ver_iter_ver_file_iter(PVerIterator *wrapper) {
|
PVerFileIterator *ver_iter_ver_file_iter(PVerIterator *wrapper) {
|
||||||
PVerFileIterator *new_wrapper = new PVerFileIterator();
|
PVerFileIterator *new_wrapper = new PVerFileIterator();
|
||||||
new_wrapper->iterator = wrapper->iterator.FileList();
|
new_wrapper->iterator = wrapper->iterator.FileList();
|
||||||
|
new_wrapper->cache = wrapper->cache;
|
||||||
return new_wrapper;
|
return new_wrapper;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -275,6 +298,38 @@ void ver_file_iter_next(PVerFileIterator *wrapper) {
|
|||||||
++wrapper->iterator;
|
++wrapper->iterator;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PVerFileParser *ver_file_iter_get_parser(PVerFileIterator *wrapper) {
|
||||||
|
PVerFileParser *parser = new PVerFileParser();
|
||||||
|
parser->parser = &wrapper->cache->records->Lookup(wrapper->iterator);
|
||||||
|
return parser;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *to_c_string(std::string s) {
|
||||||
|
char *cstr = new char[s.length()+1];
|
||||||
|
std::strcpy(cstr, s.c_str());
|
||||||
|
return cstr;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *ver_file_parser_short_desc(PVerFileParser *parser) {
|
||||||
|
std::string desc = parser->parser->ShortDesc();
|
||||||
|
return to_c_string(desc);
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *ver_file_parser_long_desc(PVerFileParser *parser) {
|
||||||
|
std::string desc = parser->parser->LongDesc();
|
||||||
|
return to_c_string(desc);
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *ver_file_parser_maintainer(PVerFileParser *parser) {
|
||||||
|
std::string maint = parser->parser->Maintainer();
|
||||||
|
return to_c_string(maint);
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *ver_file_parser_homepage(PVerFileParser *parser) {
|
||||||
|
std::string hp = parser->parser->Homepage();
|
||||||
|
return to_c_string(hp);
|
||||||
|
}
|
||||||
|
|
||||||
bool ver_file_iter_end(PVerFileIterator *wrapper) {
|
bool ver_file_iter_end(PVerFileIterator *wrapper) {
|
||||||
return wrapper->iterator.end();
|
return wrapper->iterator.end();
|
||||||
}
|
}
|
||||||
|
@ -13,6 +13,7 @@ pub type PPkgIterator = *mut c_void;
|
|||||||
pub type PVerIterator = *mut c_void;
|
pub type PVerIterator = *mut c_void;
|
||||||
pub type PVerFileIterator = *mut c_void;
|
pub type PVerFileIterator = *mut c_void;
|
||||||
pub type PPkgFileIterator = *mut c_void;
|
pub type PPkgFileIterator = *mut c_void;
|
||||||
|
pub type PVerFileParser = *mut c_void;
|
||||||
|
|
||||||
#[link(name = "apt-pkg-c", kind = "static")]
|
#[link(name = "apt-pkg-c", kind = "static")]
|
||||||
#[link(name = "apt-pkg")]
|
#[link(name = "apt-pkg")]
|
||||||
@ -83,6 +84,12 @@ extern "C" {
|
|||||||
pub fn ver_file_iter_next(iterator: PVerFileIterator);
|
pub fn ver_file_iter_next(iterator: PVerFileIterator);
|
||||||
pub fn ver_file_iter_end(iterator: PVerFileIterator) -> bool;
|
pub fn ver_file_iter_end(iterator: PVerFileIterator) -> bool;
|
||||||
|
|
||||||
|
pub fn ver_file_iter_get_parser(iterator: PVerFileIterator) -> PVerFileParser;
|
||||||
|
pub fn ver_file_parser_short_desc(parser: PVerFileParser) -> *const c_char;
|
||||||
|
pub fn ver_file_parser_long_desc(parser: PVerFileParser) -> *const c_char;
|
||||||
|
pub fn ver_file_parser_maintainer(parser: PVerFileParser) -> *const c_char;
|
||||||
|
pub fn ver_file_parser_homepage(parser: PVerFileParser) -> *const c_char;
|
||||||
|
|
||||||
pub fn ver_file_iter_pkg_file_iter(iterator: PVerFileIterator) -> PPkgFileIterator;
|
pub fn ver_file_iter_pkg_file_iter(iterator: PVerFileIterator) -> PPkgFileIterator;
|
||||||
pub fn pkg_file_iter_release(iterator: PPkgFileIterator);
|
pub fn pkg_file_iter_release(iterator: PPkgFileIterator);
|
||||||
|
|
||||||
|
20
src/sane.rs
20
src/sane.rs
@ -284,6 +284,7 @@ pub struct VerFileIterator<'c> {
|
|||||||
pub struct VerFileView<'c> {
|
pub struct VerFileView<'c> {
|
||||||
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
||||||
ptr: raw::PVerFileIterator,
|
ptr: raw::PVerFileIterator,
|
||||||
|
parser: raw::PVerFileParser,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'c> RawIterator for VerFileIterator<'c> {
|
impl<'c> RawIterator for VerFileIterator<'c> {
|
||||||
@ -300,9 +301,12 @@ impl<'c> RawIterator for VerFileIterator<'c> {
|
|||||||
fn as_view(&self) -> Self::View {
|
fn as_view(&self) -> Self::View {
|
||||||
assert!(!self.is_end());
|
assert!(!self.is_end());
|
||||||
|
|
||||||
|
let parser = unsafe { raw::ver_file_iter_get_parser(self.ptr) };
|
||||||
|
|
||||||
VerFileView {
|
VerFileView {
|
||||||
ptr: self.ptr,
|
ptr: self.ptr,
|
||||||
cache: self.cache,
|
cache: self.cache,
|
||||||
|
parser
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -321,6 +325,22 @@ impl<'c> VerFileView<'c> {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn short_desc(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::ver_file_parser_short_desc(self.parser)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn long_desc(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::ver_file_parser_long_desc(self.parser)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn maintainer(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::ver_file_parser_maintainer(self.parser)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn homepage(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::ver_file_parser_homepage(self.parser)) }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// An "iterator"/pointer to a point in a file list.
|
/// An "iterator"/pointer to a point in a file list.
|
||||||
|
Loading…
Reference in New Issue
Block a user