2017-07-13 16:11:51 +01:00
This crate provides bindings to `libapt-pkg` .
[![Build status ](https://api.travis-ci.org/FauxFaux/apt-pkg-native-rs.png )](https://travis-ci.org/FauxFaux/apt-pkg-native-rs)
[![ ](http://meritbadge.herokuapp.com/apt-pkg-native )](https://crates.io/crates/apt-pkg-native)
### 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` ](https://tracker.debian.org/pkg/apt ),
which is GPL2+.
### Building
2019-01-21 22:20:47 +00:00
`libapt-pkg-dev` must be installed. The [`cc` ](https://crates.io/crates/cc )
2017-07-13 16:11:51 +01:00
crate is used to try and find a native compiler.
2017-10-15 15:12:24 +01:00
2017-12-12 20:29:27 +00:00
The `ye-olde-apt` feature provides support for `apt <1.2` (Ubuntu 14.04 (Trusty),
Debian 7 (Jessie) (2015)). This works by just deleting methods which are not
available in that version. See
[#2 ](https://github.com/FauxFaux/apt-pkg-native-rs/issues/2#issuecomment-351180818 ).
2017-10-15 15:12:24 +01:00
### 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.
2017-11-18 11:05:57 +00:00
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.
2017-10-15 15:12:24 +01:00
`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.
2017-10-15 21:05:14 +01:00
### 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
```