Computing Build-Depends at build time (and other updates to debian/control)?

Josh Triplett josh at joshtriplett.org
Sun Aug 21 09:03:00 UTC 2016


[CCed to other potentially interested parties. Please CC me on replies.]

Mechanisms like shlibdeps, dh_perl, and other substvars allow packages
to compute their Depends at build time.  This avoids hard-coding
dependencies, simplifies upgrading the package to new versions, and
makes transitions much easier.

Some packages could potentially compute most of their Build-Depends the
same way.  For example, I'm working on a tool ("debcargo") to package
Rust libraries and applications, which include detailed metadata (via
Cargo) for dependencies on other Rust libraries.  Given a minimal set of
tools installed (cargo and that packaging tool), I could compute all the
necessary Depends and Build-Depends on Rust packages, including
versions.

Right now, that packaging tool has to compute the Build-Depends at
packaging time and embed them in debian/control.  (Most likely, I'll
include comments delimiting the Cargo dependencies, to make it easier to
update them.)

What would it take to compute Build-Depends at build time instead, with
a minimal set of Build-Depends installed to support doing so?

(This relates somewhat to build profiles, though not quite, as with
build profiles the Build-Depends field must still contain a list of
everything needed to build the package with no profile.)

This would clearly require a new version of dpkg-dev, to invoke a new
debian/rules target, and to enforce the computed Build-Depends.  Any
package using this feature would need to Build-Depends on a sufficient
version of dpkg-dev.  Package builders and other tools that install
Build-Depends (such as sbuild and pbuilder) would also need an update;
perhaps dpkg-dev could have versioned Breaks for tools that don't
understand this mechanism.  However, this shouldn't require waiting for
a new stable version of Debian before any package can use it; it would
only require waiting for a new dpkg-dev and updated autobuilder
infrastructure.

As one possible implementation, after dpkg-buildpackage checks that the
system satisfies the Build-Depends specified in debian/control, it could
check if the package specifies a specific flag header in the source
stanza of debian/control (for instance, "Build-Control: yes").  If
present, dpkg-buildpackage would back up debian/control and invoke
"debian/rules control", which should generate a new control file.
dpkg-buildpackage would then use that control file for the remainder of
the build process, starting by checking that the system satisfies the
new Build-Depends.  (The generation of the source package will include
the backed up debian/control file, not the generated one.)  (It might
also help to provide a helper program that merges two debian/control
files, so that "debian/rules control" can just produce the fields it
wants to update.)

This strawman proposal allows updating all of debian/control, not just
Build-Depends.  I've seen various requests over the years for the
ability to update debian/control at build time; it seems just as easy to
support that.  However, if that seems problematic for any reason, this
mechanism could instead just allow updating a subset of fields.

Any thoughts on this proposal?

- Josh Triplett



More information about the Pbuilder-maint mailing list