Comment construire un .deb pour Ubuntu
Date: 28/05/2009 | Catégories: Developpement,Open-source,Planet-libre | Tags: deb,debian,launchpad,linux,package,ubuntu
Voici une procédure (assez longue) permettant de générer un .deb (format de package compatible avec l'OS Ubuntu) pouvant être mis sur un depot officiel. Ce billet s'inspire très fortement de ce forum.
Avant de commencer...
Il faut installer les pré-requis suivants:
sudo aptitude install build-essential autoconf automake autotools-dev dh-make debhelper devscripts fakeroot xutils lintian pbuilder
Ensuite on créé l'arborescence suivante dans votre répertoire racine:
cd ~
mkdir packages
cd packages
Création de notre premier package .deb
On doit dans un premier temps récupérer les sources du logiciel à packager (sjitter dans mon exemple):
wget http://fastbull.dl.sourceforge.net/sourceforge/sjitter/sjitter-0.18.1b.tgz
tar zxvf sjitter-0.18.1b.tgz
Le nom du répertoire contenant les sources doit être de la forme nom-version:
mv sjitter sjitter-0.18.1b
On créé un sous répertoire sjitter dans lequel on met l'archive et les sources:
mkdir sjitter
mv sjitter-0.18.1b sjitter-0.18.1b.tgz sjitter
Pour vérifier, le contenu du répertoire de travail doit être le suivant:
# ls -l ~/packages/sjitter
sjitter-0.18.1b
sjitter-0.18.1b.tgz
On va dans le répertoire source:
cd sjitter/sjitter-0.18.1b
Puis on lance la commande:
dh_make -e nicolas@nospam.com -c GPL -f ../sjitter-0.18.1b.tgz
> s
Maintainer name : unknown
Email-Address : nicolas@nospam.com
Date : Wed, 27 May 2009 11:52:00 +0000
Package Name : sjitter
Version : 0.18.1b
License : blank
Type of Package : Single
> ENTER
A la première question, il faut répondre:
s = [single binary] - si c'est package normal
l = [library] - si c'est une librairie de dev
m = [multiple] - si c'est un package comprenant plusieurs binaires
k = [kernel module] - si c'est module noyau
On va alors dans le sous répertoire debian créé par le programme dh_make:
cd debian
Puis on édite le fichier control:
# vi control
Source: sjitter
Section: net
Priority: extra
Maintainer: Nicolas Hennion <nicolas@nospam.com>
Build-Depends: debhelper (>= 5), autotools-dev
Standards-Version: 3.7.2Package: sjitter
Architecture: any
Depends: ${shlibs:Depends}, ${misc:Depends}
Description: Sjitter is a client/server performing tool.
Sjitter is a command line client/server to measure jitter (based on RFC 1889), one way UDP delay and bandwidth. The client and the server's date should be synchronise to compute the jitter. You can use the NTP protocol to do this.
Avec:
Ligne 1: Nom du projet
Ligne 2: Section à laquelle appartient le projet (voir la des sections disponible ici)
Ligne 3: Laisse la valeur par défaut
Ligne 4: Nom et adresse mail du mainteneur du package
Ligne 5: Il faut y mettre les dépendances finissants par -dev
Ligne 6: Laisse la valeur par défaut
Ligne 7: Vide
Ligne 8: Mettre la même chose qu'en ligne 1
Ligne 9: Architecture cible (any pour toutes)
Ligne 10: Il faut y mettre les dépendances ne finissants pas par -dev
Ligne 11: Description courte du projet (< à 60 caractères)
Ligne 12->n: Description longue (attention à laisser un espace avant votre description)
Puis le fichier changelog:
# vi changelog
sjitter (0.18.1b) maverick; urgency=low* Version 0.18 (23/03/2009), thanks to Thierry Legras
-- Nicolas Hennion <nicolas@nospam.com> Wed, 27 May 2009 11:52:00 +0000
Avec:
Ligne 1: Nom du package et version d'Ubuntu (maverick dans mon exemple)
Ligne 2: Vide
Ligne 3->n: Liste des changements de cette version
Ligne n+1: Vide
Ligne n+2: Nom, adresse mail et date (attention, il faut mettre votre nom / adresse comme configuré dans Launchpad)
Le fichier copyright:
# vi copyright
This package was debianized by Nicolas Hennion <nicolas@nicolargo.com> on
Wed, 27 May 2009 11:52:00 +0000.It was downloaded from http://fastbull.dl.sourceforge.net/sourceforge/sjitter/sjitter-0.18.1b.tgz
Upstream Author(s): Nicolas Hennion <nicolas@nicolargo.com>
License: This script is written under the GNU General Public License.
Avec:
Ligne 1: Nom et adresse de l'auteur du package
Ligne 2: Date
Ligne 3: Vide
Ligne 4: A partir de quel source le package a été généré
Ligne 5: Vide
Ligne 6->n: Les auteurs du logiciel (copie du fichier ../AUTHORS)
Ligne n+1: Vide
Ligne n+2->m: Licence sous laquelle le logiciel est distribué (conformément à la volonté de l'auteur)
Ligne m+1: Vide (optionnel)
Ligne m+2: Licence complète (optionnel)
Il y a ensuite certains fichiers optionnels à configurer. Si ils ne sont pas utiles pour votre logiciel, il faut les supprimer.
README.debian: Informations complémentaires sur le logiciel (non présentes dans les autres fichiers)
emacsen-*.ex: Fichier Emacs pouvant être compilé à l'installation
init.d.ex: Si votre logiciel doit se lancer en mode daemon, c'est dans ce fichier qu'il faut écrire le script init.d
manpage.1.ex, manpage.sgml.ex: Fichiers de man (aide)
preinst.ex: Script à lancer avant l'installation
postinst.ex: Script à lancer après l'installation
prerm.ex: Script à lancer avant la désinstallation
postrm.ex: Script à lancer après la désinstallation
On peut ensuite lancer la génération du fichier .deb
cd ..
debuild -S -k_CLES_
Il faut remplacer _CLES_ par votre clés Launchpad (liste des clés: gpg --list-keys).
Si tout se passe sans problème, vous devriez vous retrouver avec les fichiers suivant dans le répertoire ~/packages/sjitter/:
sjitter_0.18.1b-1.diff.gz: Changement entre .deb et les sources originales
sjitter_0.18.1b-1.dsc: Fichier permettant aux mainteneurs des repos de suivre ce package
sjitter_0.18.1b-1_source.changes: Le changelog (liste des changements)
sjitter_0.18.1b-1_source.deb: Le package au format .deb
sjitter_0.18.1b.orig.tar.gz: Les sources originales
Et voilà, vous venez de faire votre premier package Ubuntu, il ne reste plus qu'a le soumettre à la communauté.
Par exemple pour soumettre votre package sur Launchpad:
dput ppa:nicolashennion/ppa sjitter_0.18.1b-1_source.changes
Et hop...