Some background: I'm using Debian 7 as my main environment, and I want to tell my system that I have glibc = 2.15
in addition to the environment's required glibc = 2.13
for the purposes of using some more recent applications.
I got the glibc from the various tutorials on the web for installing eg.: Steam. It is unpacked in /usr/local/lib/libc6-2.15
and I've tested it with some applications such as Pidgin 2.10, Boinc 7 and Stellarium, it's working well (so far, I do expect it to eventually fail gracefully). Since it'd be much better if I could install those applications from packaged sources as well (both clang and Boinc are in testing for example), I'd like to tell my system via a virtual package that I do, in fact, have a glibc 2.15 available.
Of course I know about equivs
as a tool to create virtual packages for stuff that one does not have installed from repositories, but I have found no good documentation so far on how to use equivs
to create a virtual package that can update an already installed package, ideally without breaking.
I first tried the obvious:
Package: libc6
Version: 2.15-1
And dpkg-installed the generated package, with the expected result that it uninstalled the already present libc
to update and left the system in an unusable state. (Of course, I tried this in a VM). I've also tried
Version: >= 2.13
Without any good results.
I tried to look for a way of using Provides or Enhances by creating a package of a different name
Package: local-libc6
Version: 2.15
# Either this:
Provides: libc6
# Or this:
Enhances: libc6 (< 2.15)
But so far I have had no success in getting equivs
to create an installable package (aptitude complains about an invalid Provides or Enhances), or even to create a package at all.
Of course, the idea is to create a virtual package for libc
that won't uninstall the already installed one, and merely "provides" the new version. But I've found the documentation horribly lacking in that respect so far (and I really don't want to have to delve deep and become lost into the DPKG Encyclopedia; usually I have the disposition and time to do such tasks, but these days my focus is needed elsewhere).
So, I guess the base question is: can I use equivs to create an update for a package without uninstalling the original, or achieve something to that effect? What general cares do I need to exercise when specifying versions to equivs
?
Best Answer
The answer is that a package created with
equivs-build
from a control file which contains a variation on the name (libc6-local for ex.) of an existing package and a higher version, will trigger the removal of the older package, not because of the execution toprerm
orpostrm
scripts from neither the new or old package, but by design.Now, it is possible to create a package with an entirely different name, and set in the control file that it provides a package like libc6. More specifically, consider the following control file (only relevant portion shown) for a proposed virtual package:
Compare this with the control file in libc6 2.17-0ubuntu5 (my machine):
Then consider an empty package based on this control file:
Then build the packages. Our virtual package which provides glib-2.9 installs and doesn't remove any installed libc6. When you try installing our package which depends on glibc-2.9 we get an error in
apt
(set up as 2.2 here):or
dpkg
:Go back to our initial virtual package and replace what it provides with:
Then try to reinstall our package which depends on glibc-2.9.
dpkg
gives the same error message but notapt
!!!! Apt actually changed its mind the minute I built the packages after changing the provide value then pushed changes to the Packages.gz and updated apt withdpkg-scanpackages dirwithpackages | gzip > dirwithpackages/Packages.gz
thensudo apt-get update
:This is actually a bit different from the explanation I had missed in the Debian Handbook:
5.2.1.4.3. Current Limitations
Virtual packages suffer from some troubling limitations, the most significant of which being the absence of a version number. To return to the previous example, a dependency such as Depends: libdigest-md5-perl (>= 1.6), despite the presence of Perl 5.10, will never be considered as satisfied by the packaging system — while in fact it most likely is satisfied. Unaware of this, the package system chooses the least risky option, assuming that the versions do not match.
The experience above shows that
apt
anddpkg
behaved somewhat differently (insofar as error messages change) with my setup (Xubuntu 13.04, dpkg=1.16.10 (amd64) and apt=0.9.7.7ubuntu4 (amd64)).Apt
acknowledges that it sees that this package we installed provides libc6, but it doesn't see that it provides exactly version 2.9. Ultimately apt calls dpkg so dpkg should be the bottleneck.Finally, as you know, ld.config.so is the facility to take care of all the linking as demonstrated in this example of the chain of ld.so.conf files and directories. The linking infrastructure and the $LD_LIBRARY_PATH variable to shared objects take priority over default library locations such as /lib and /usr/lib in this context.