Professional Documents
Culture Documents
Ondřej Surý • ondrej@isc.org • ondrej@debian.org • 25. 10. 2017
Contents
● .deb binary package structure
● Source package structure
● Basic toolchain
● Recommended toolchain
● Keeping the sources in git
● Clean build environment
● Misc...
● So how do I become Debian Developer?
My Debian portfolio (since 2000)
● Mostly team maintained ● BIRD
● PHP + PECL (pkg-php) ● Cyrus SASL
○ Co-installable packages since 7.x ● Cyrus IMAPD
○ Longest serving PHP maintainer in Debian ● Apache2 + mod_md (fresh)
(and still not crazy)
● ...other little stuff
● libjpeg-turbo
○ Transitioned Debian from IIJ JPEG (that
Older work
crazy guy) to libjpeg-turbo
● DNS Packaging Group
● GTK/GNOME/Freedesktop
○ CZ.NIC’s Knot DNS and Knot Resolver
● Redmine/Ruby
○ NLnet Lab’s NSD, Unbound, getdns, ldns
○ Never again, it’s a straight road to madness
○ PowerDNS
○ BIND 9
● Berkeley DB and LMDB (pkg-db)
○ One Berkeley DB per release (yay!)
Binary package structure
$ ar xv knot_2.0.1-4_amd64.deb
● ar archive consisting of: x – debian-binary
○ debian-binary x – control.tar.gz
x – data.tar.xz
■ .deb format version (2.0)
○ control.tar.gz $ dpkg-deb -X knot_2.0.1-4_amd64.deb output/
./
■ Package informatio (control) ./etc/
■ Maintainer scripts […]
./usr/sbin/knotd
● {pre,post}{inst,rm} […]
■ Misc (md5sum, conffiles) $ dpkg-deb -e knot_2.0.1-4_amd64.deb DEBIAN/
○ data.tar.xz $ ls DEBIAN/
conffiles control md5sums postinst postrm preinst
■ Actual content of the package prerm
■ This is what gets installed
$ dpkg -I knot_2.0.1-4_amd64.deb
● Nástroje pro práci s .deb soubory new debian package, version 2.0.
size 218134 bytes: control archive=2737 bytes.
○ dpkg-deb Package: knot
○ dpkg (wrapper around dpkg-deb) Version: 2.0.1-4
Architecture: amd64
○ ar, tar
Source package structure
Format: 3.0 (quilt)
● Source package metadata Source: knot
<pkg>_<dver>.dsc Binary: knot, [...], knot-doc
Architecture: any all
○ Maintainer + Uploaders Version: 2.0.1-4
Maintainer: Debian DNS Packaging
○ Build Dependencies and Conflicts <pkg-dns-devel@l.a.d.o>
○ List of binary packages Uploaders: Ondřej Surý <ondrej@d.o>
Homepage: http://www.knot-dns.cz/
○ Checksums (sha256) Standards-Version: 3.9.6
○ And more… Vcs-Browser: https://anonscm.d.o/git/pkg-dns/knot.git
Vcs-Git: git://anonscm.d.o/pkg-dns/knot.git
● Upstream tarball Build-Depends: debhelper (>= 9), [...], pkg-config
Build-Depends-Indep: ghostscript, [...], python-sphinx
<pkg>_<uver>.orig.?z Package-List:
knot deb net optional arch=any
○ Original upstream unmodified tarball [...]
○ Or repacked due licensing reasons (dfsg) Checksums-Sha1: [...]
Checksums-Sha256:
● Changes against the upstream tarball 183b[...]6ce6 958560 knot_2.0.1.orig.tar.xz
29b7[...]681c 17688 knot_2.0.1-4.debian.tar.xz
<pkg>_<dver>.debian.tar.xz Files:
○ Debian directory (debian/) 96c1[...]22e5 958560 knot_2.0.1.orig.tar.xz
643a[...]4d6d 17688 knot_2.0.1-4.debian.tar.xz
○ Or other changes in older package formats
Debian package versioning
[epoch:]upstream_version[-debian_revision] # fixup the versioning (start over)
# e.g. new package with same name or mistake
# example: git (formelly GNU Interactive Tools)
● epoch – [0-9] dpkg --compare-versions ‘1:2.1.4-2.1’ gt ‘4.3.20-7’
● d/patches/
○ Patches for upstream sources
○ Managed by quilt or gbp pq
● And more...
Basic (barebone) toolchain
#!/usr/bin/make -f
● d/rules is Makefile # -*- makefile -*-
● d/rules <target>, where <target> is:
build:
○ clean gcc -o helloworld helloworld.c
■ Return the pristine state clean:
○ build (build-arch, build-indep) rm -f helloworld
■ Compile the sources install: build
○ install (install-indep, install-arch) mkdir debian/tmp/usr/bin
cp -a helloworld debian/tmp/usr/bin/
■ Install into the temporary path
○ binary (binary-arch, binary-indep) binary-indep: build
$ cat debian/libknot-dev.install
dh_install usr/include/
● Helper script to copy d/tmp/ contents into usr/lib/*/*.a
usr/lib/*/*.so
d/<package>/ directories usr/lib/*/pkgconfig/*
d/<package>/usr/share/doc/<package>
● Option --link-doc can symlink
documentation between packages
○ It can save space (in theory)
○ !!!WARNING!!! You must not mix
binary:arch and binary:all packages, it break
binNMU
○ My recommendation: DON’T USE IT
Tweak the standard dh behaviour
$ dh build --no-act
● dh <target> --no-act dh_testdir
○ Prints the chain of commands dh_auto_configure
dh_auto_build
● Every command can be overriden in d/rules debian/rules override_dh_auto_test
○ override_<target> $ cat debian/rules
● Some commands read env variables #!/usr/bin/make -f
[...]
● Some needs to be given option %:
dh $@
○ Via override
○ Or give it to dh # run tests, but don’t fail the build on failure
override_dh_auto_test:
● Common use: -make check
○ https://www.debian.org/devel/join/newmaint
○ http://mentors.debian.net/
● Adopt an existing package or create a new
○ And become Debian Maintainer
■ https://wiki.debian.org/DebianMaintainer
● After you prove yourself and if you still like it
○ Became Debian Developer (with voting rights)
Library
● Debian Policy Manual
○ https://www.debian.org/doc/debian-policy/
● Debian Developer’s Reference
○ https://www.debian.org/doc/manuals/deve
lopers-reference/
● Debian New Maintainers' Guide
○ https://www.debian.org/doc/manuals/main
t-guide/
● Preferred debian packaging setup for dkg
○ https://wiki.debian.org/DanielKahnGillmor
/preferred_packaging
Questions?