Go to file
2017-12-10 15:20:21 +00:00
apt-pkg-c add a reload() (#1) 2017-11-17 09:54:14 +00:00
examples new rustfmt 2017-11-17 09:03:38 +00:00
src remove empty test 2017-11-17 09:54:20 +00:00
.gitignore list packages (after manual make) 2017-07-12 21:18:34 +01:00
.travis.yml try and convince travis to run in fast mode 2017-09-13 08:33:02 +01:00
build.rs cargo upgrade + fix deprecation warning 2017-09-13 08:28:30 +01:00
Cargo.toml update lazy-static to 1 2017-12-10 15:20:21 +00:00
LICENSE.MIT docs / crates.io stuff 2017-07-13 16:12:58 +01:00
README.md add a note about singleton breakage 2017-11-18 11:05:57 +00:00

This crate provides bindings to libapt-pkg.

Build status

Documentation and Examples

See the examples/ folder for some partial implementations of some commands.

https://docs.rs/apt-pkg-native

License Note

While the code in this crate is available under a permissive MIT license, it is useless without libapt-pkg, which is GPL2+.

Building

libapt-pkg-dev must be installed. The gcc crate is used to try and find a native compiler.

Thread safety

It is intended that the crate should be usable from multiple threads. However, this is generally implemented using singletons, which may be really annoying for your use-case.

The current way the singleton is managed is awful, and it's not been fixed while I've been learning about the problems. A major version bump, and a proper singleton, may resolve some of the issues. This needs to be done eventually.

apt does not have a concurrency model: you may not use threads.

Since apt 1.4 or 1.5 (in Debian Stretch (2017), but not in Xenial 16.04), some operations are thread safe: it should be possible to initialise the cache twice in parallel. As these versions of apt are not widespread, the API of this crate does not attempt to expose this.

Switching distro with docker

examples/on-sid has a docker file which builds a minimum Debian image with typical package lists downloaded. You can run a tool in it, from this directory, by:

(cd examples/on-sid && make)
docker run -v $(pwd):/mnt sid-sources-list /mnt/target/release/examples/sources