Mail archive

[alpine-devel] apk and libraries that optionally replace others

From: Oliver Smith <>
Date: Tue, 15 May 2018 20:57:00 +0000

Hey folks,

in Alpine based postmarketOS we have hit the following use case quite a
few times by now, and we're wondering how to solve it properly:
Packaging "testlib-b" as a _optional_ replacement for "testlib-a".

Both "testlib-a" and "testlib-b" provide the same soname, which means
abuild will automatically make both binary packages provide

Now there is a "testapp" package, which has "testlib-a" in makedepends
and links against "". Therefore abuild puts
"" in the depends of "testapp". What we would like to
achieve is, that whenever installing "testapp", it pulls in "testlib-a".
But when "testlib-b" is already installed, it uses "testlib-b" instead
of "testlib-a".

I have tried various combinations with "provides" and
"provider_priority", and I couldn't get it working. The only way it
would work was if "testapp" explicitly depended on "testlib-a", but that
won't fulfill our use case: if the library in question is "libdrm", then
we would need to change a lot of Alpine's aports to explicitly depend on
libdrm instead of implicitly to make it work.

If someone is interested, I can provide apk's output of what I've tried
so far. The aports I have used for testing are here [1].

To make this less abstract, one example where we would actually use
this, is "libdrm-grate", which adds out of tree tegra drivers to
"libdrm" [2].

Here are my questions:
* Am I missing something, or does this not work with apk?
* Would Alpine be interested in a patch that adds this functionality,
  and if so, how would everyone like to have it integrated?

Thanks for reading,


Received on Tue May 15 2018 - 20:57:00 UTC