Création/Mise à jour de paquets DEB

Création/Mise à jour de paquets DEB

Après la publication d’un paquet, il sera rapidement nécessaire de le mettre à jour.

[](){#newrevision}8.1. Nouvelle révision Debian {#nouvelle-révision-debian .title} -----------------------------------------------

[](){#newrevision}

[](){#newrevision}

[](){#newrevision}

Soit un rapport de bogue numéroté #654321{.literal}, concernantvotre paquet et décrivant un problème que vous pouvez résoudre. Voici ce quevous devez faire pour créer une nouvelle révision du paquet :

[](){#newrevision} [](){#newrevision} - pour un nouveau correctif :
- configurer le nom du correctif : `dquilt newnomdubogue.patch`{.literal} ; - déclarer le fichier à modifier : `dquilt addfichier-bogué`{.literal} ; - corriger le problème dans le paquet source pour le bogue amont ; - l'enregistrer en`nomdubogue.patch`{.filename} :`dquilt refresh`{.literal} ; - ajouter sa description : `dquilt header -e`{.literal} ;
  • pour la mise à jour d’un correctif :

    • rappeler le correctiftoto.patch{.filename} existant :dquilt pop toto.patch{.literal} ;
    • corriger le problème dans l’ancientoto.patch{.filename} ;
    • mettre à jour toto.patch{.filename} :dquilt refresh{.literal} ;
    • mettre à jour sa description : dquilt header -e{.literal} ;
    • appliquer tous les correctifs en enlevant les approximations(fuzz) : while dquilt push; do dquilt refresh;done{.literal} ;

  • [](){#newrevision}[](){#newrevision}ajouter une nouvelle révision au début du fichierchangelog{.filename} Debian, par exemple avec dch-i{.literal}, ou explicitement avec dch -vversion{.literal}-révision,et ajoutez ensuite les commentaires en utilisant votre éditeurfavori ;0{#idp39901104 .footnote}
  • ajouter une courte description du bogue et de la solution dans l’entrée duchangelog, suivie par Closes: #654321{.literal}. De cette manière,le rapport de bogue sera automagiquement fermé par lelogiciel de maintenance des archives une fois le paquet accepté dansl’archive Debian ;
  • répéter les opérations précédentes pour corriger plus de bogues tout enmettant à jour le fichier changelog{.filename} avecdch{.literal} selon votre besoin ;
  • recommencer ce qui a été fait en Section 6.1, « Reconstruction complète »{.xref} et Chapitre 7, Contrôle des erreurs du paquet{.xref} ;
  • une fois satisfait, modifier la valeur de distribution danschangelog{.filename} d’UNRELEASED{.literal} à la valeurde distribution cible unstable{.literal} (ou mêmeexperimental{.literal}). 0{#idp39910880 .footnote}
  • envoyer le paquet comme en Chapitre 9, Envoi de paquet{.xref}. La différence est quecette fois, l’archive source originale ne sera pas incluse, car elle n’a pasété modifiée et est déjà dans l’archive Debian.

Un cas délicat peut se produire quand vous faites un paquet local pourexpérimenter l’empaquetage avant d’envoyer la version normale vers l’archiveofficielle, par exemple1.0.1{.literal}-1.Pour des mises à niveau plus en douceur, il vaut mieux créer une entrée dechangelog{.filename} avec une chaîne de version comme1.0.1{.literal}-1~rc1.Vous pouvez nettoyer le changelog{.filename} en fusionnant cesentrées de modification en une unique entrée pour le paquetofficiel. Consultez Section 2.6, « Nom et version de paquet »{.xref} pour l’ordre des chaînes deversion.

[](){#inspectnewupstream}8.2. Examen d'une nouvelle version amont {#examen-dune-nouvelle-version-amont .title} -----------------------------------------------------------------

[](){#inspectnewupstream}

[](){#inspectnewupstream}

[](){#inspectnewupstream}

Lors de la préparation de paquets d’une nouvelle version amont pourl’archive Debian, vous devez commencer par vérifier la nouvelle versionamont. Commencez par lire les changelog{.filename} etNEWS{.filename} amonts, ainsi que toute autre documentationdistribuée avec la nouvelle version. Examinez ensuite les modifications entre les anciennes et nouvelles sourcesamont, pour guetter tout changement suspect :

$ diff -urN toto-ancienneversion toto-nouvelleversion

Les modifications de certains fichiers automatiquement créés par Autotoolscomme missing{.filename}, aclocal.m4{.filename},config.guess{.filename}, config.h.in{.filename},config.sub{.filename}, configure{.filename},depcomp{.filename}, install-sh{.filename},ltmain.sh{.filename} et Makefile.in{.filename} peuventêtre ignorées. Vous pouvez les effacer avant d’exécuterdiff pour examiner les sources.

[](){#inspectnewupstream}

[](){#inspectnewupstream}
[](){#inspectnewupstream}
[](){#inspectnewupstream}
[](){#inspectnewupstream} [](){#inspectnewupstream}[](){#newupstream}8.3. Nouvelle version amont {#nouvelle-version-amont .title} ----------------------------------------------------------------------

[](){#newupstream}

[](){#newupstream}

[](){#newupstream}

[](){#newupstream}[](){#newupstream}Si un paquet toto{.systemitem} est correctementempaqueté au nouveau format 3.0 (native){.literal} ou3.0 (quilt){.literal}, empaqueter une nouvelle version amontconsiste essentiellement à déplacer l’ancien répertoiredebian{.filename} dans les nouvelles sources. Ce peut être réaliséen exécutant tar xvzf/chemin{.literal}/vers/toto_ancienneversion.debian.tar.gzdepuis la nouvelle arborescence source décompressée. 0{#idp39936912 .footnote} Bien sûr, vous devez vous occuper de quelquesroutines évidentes :

- création d'une copie des sources amont dans un fichier`toto_nouvelleversion`{.filename}.orig.tar.gz ; - mise à jour du ficher `changelog`{.filename} Debian avec`dch -vnouvelleversion`{.literal}-*`1`* :
- ajout d'une entrée avec `New upstream release.`{.literal} (nouvelleversion amont) ; - description succincte des modifications *dans la nouvelle versionamont* qui corrigent des bogues et ferment les rapports associésen ajoutant `Closes:#numéro_de_bogue`{.literal} ; - description succincte des modifications *à la nouvelle versionamont* par le responsable qui corrigent des bogues et ferment lesrapports associés en ajoutant `Closes:#numéro_de_bogue`{.literal} ;
  • application de tous les correctifs en enlevant les approximations(« fuzz ») : while dquilt push; do dquiltrefresh; done{.literal}.

Si la fusion des correctifs ne s’applique pas proprement, examinez lasituation (des indices sont laissés dans les fichiers.rej{.filename}) :

- si un correctif appliqué aux sources a été intégré aux sources amont :
- `dquilt delete`{.literal} pour l'enlever ;
  • si un correctif appliqué aux sources entre en confit avec les nouvellesmodifications des sources amont :

    • dquilt push -f{.literal} pour appliquer les anciens correctifs touten forçant les rejets commetruc{.filename}.rej ;
    • édition manuelle du fichiertruc{.filename} pour obtenir lerésultat attendu detruc{.filename}.rej ;
    • dquilt refresh{.literal} pour mettre à jour le correctif ;

  • continuer comme d’habitude avec while dquilt push; do dquiltrefresh; done{.literal}.

Cette méthode peut être automatisé avec uupdate(1) :

$ apt-get source toto...dpkg-source: info: extraction de toto dans toto-ancienneversiondpkg-source: info: extraction de toto_ancienneversion.orig.tar.gzdpkg-source: info: extraction de toto_ancienneversion-1.debian.tar.gz$ ls -Ftoto-ancienneversion/toto_ancienneversion-1.debian.tar.gztoto_ancienneversion-1.dsctoto_ancienneversion.orig.tar.gz$ wget http://example.org/toto/toto-nouvelleversion.tar.gz$ cd toto-ancienneversion$ uupdate -v nouvelleversion ../toto-nouvelleversion.tar.gz$ cd ../toto-nouvelleversion$ while dquilt push; do dquilt refresh; done$ dch... documentation des modifications réalisées

Si le fichier debian/watch{.filename} est configuré comme décriten Section 5.22, « watch{.filename} »{.xref}, la commande wget estinutile. Exécutez simplement uscan(1) dans le répertoiretoto{.filename}-ancienneversionà la place de la commande uupdate suffit. Les sourcesmises à jour seront automagiquement recherchées,téléchargées, et la commande uupdate seraexécutée. 0{#idp39985632 .footnote} Vous pouvez publier ces sources mises à jour en recommençant ce qui a étéfait en Section 6.1, « Reconstruction complète »{.xref}, Chapitre 7, Contrôle des erreurs du paquet{.xref} et Chapitre 9, Envoi de paquet{.xref}.

[](){#packagestyle}8.4. Mise à jour du style d'empaquetage {#mise-à-jour-du-style-dempaquetage .title} ----------------------------------------------------------

[](){#packagestyle}

[](){#packagestyle}

[](){#packagestyle}

[](){#packagestyle}[](){#packagestyle}La mise à jour du style d’empaquetage n’est pas nécessaire lors de la mise àjour d’un paquet. Néanmoins, le faire permet de profiter de tout lepotentiel du système debhelper{.systemitem}moderne et du format source 3.0{.literal} : 0{#idp39993344 .footnote}

- si vous devez, pour quelque raison que ce soit, recréer des fichiers modèlesqui avaient été effacés, vous pouvez exécuter **dh\_make** ànouveau depuis le répertoire des sources Debian, avec l'option`--addmissing`{.literal}. Puis modifiez-les de façon adéquate ; - si le paquet n'a pas été mis à jour pour utiliser la syntaxe**dh** de `debhelper`{.systemitem} v7+ dans le fichier`debian/rules`{.filename}, mettez-le à jour pour utiliser**dh**. Mettez à jour le fichier`debian/control`{.filename} en conséquence ; - si vous voulez mettre à jour le fichier `rules`{.filename} créé avecle mécanisme d'héritage `Makefile`{.filename} du système decompilation usuel Debian (`cdbs`{.systemitem}) versla syntaxe **dh**, consultez les documents suivants pourcomprendre ses variables de configuration `DEB_*`{.literal} :
- copie locale de `/usr/share/doc/cdbs/cdbs-doc.pdf.gz`{.filename} ; - [Le système de compilation usuel Debian (CDBS),FOSDEM 2009](http://meetings-archive.debian.net/pub/debian-meetings/2009/fosdem/slides/The_Common_Debian_Build_System_CDBS/){.ulink} ;
  • si vous avez un paquet source 1.0{.literal} sans fichiertoto{.filename}.diff.gz, vous pouvez lemettre à jour au récent format source 3.0 (native){.literal} encréant debian/source/format{.filename} contenant3.0 (native){.literal}. Le reste des fichiersdebian/*{.filename} peut être simplement copié ;
  • si vous avez un paquet source 1.0{.literal} avec fichiertoto{.filename}.diff.gz, vous pouvez lemettre à jour au récent format source 3.0 (quilt){.literal} encréant debian/source/format{.filename} contenant3.0 (quilt){.literal}. Le reste des fichiersdebian/*{.filename} peut être simplement copié. Importez lefichier gros.diff{.filename} créé par la commandefilterdiff -z -x '*/debian/*'toto{.literal}.diff.gz > gros.diff dans votresystème quilt, au besoin ; 0{#idp40017184 .footnote}
  • si l’empaquetage a été créé en utilisant un autre système de correctif commedpatch{.systemitem}, dbs{.systemitem} ou cdbs{.systemitem} avec -p0{.literal},-p1{.literal} ou -p2{.literal}, convertissez-le àquilt{.systemitem} avec deb3{.filename}disponible en http://bugs.debian.org/581186 ;
  • si l’empaquetage a été créé avec la commande dh et leparamètre --with quilt{.literal} ou les commandesdh_quilt_patch et dh_quilt_unpatch,enlevez-les et utilisez le nouveau format source3.0 (native){.literal}.

Vous devriez consulter les propositions d’améliorationsDebian (DEP - Debian Enhancement Proposals){.ulink} et adopter lespropositions marquées « ACCEPTED ». Les autres tâches décrites en Section 8.3, « Nouvelle version amont »{.xref} sont aussi àeffectuer.

[](){#utf8}8.5. Conversion en UTF-8 {#conversion-en-utf-8 .title} -----------------------------------

[](){#utf8}

[](){#utf8}

[](){#utf8}

[](){#utf8}[](){#utf8}Si les documents amonts sont encodés avec d’anciens jeux de caractères, lesconvertir en UTF-8{.ulink} peut être utile :

- avec iconv(1) pour convertir l'encodage defichiers texte : ``` {.screen} iconv -f latin1 -t utf8 truc_entrée.txt > truc_sortie.txt ``` - avec w3m(1) pour convertir les fichiers HTML enfichier texte UTF-8. Assurez-vous d'exécuter cette commande avec desparamètres régionaux en UTF-8 : ``` {.screen} LC_ALL=en_US.UTF-8 w3m -o display_charset=UTF-8 -cols 70 -dump -no-graph -T text/html < foo_in.html > truc_sortie.txt ```

[](){#reminders}8.6. Rappels pour la mise à jour de paquets {#rappels-pour-la-mise-à-jour-de-paquets .title} -----------------------------------------------------------

[](){#reminders}

[](){#reminders}

[](){#reminders}

Voici quelques rappels pour la mise à jour de paquets :

[](){#reminders} [](){#reminders} - préservez les anciennes entrées `changelog`{.filename} (cela va desoit, mais des personnes ont parfois utilisé `dch`{.literal} au lieude `dch -i`{.literal}) ; - les modifications Debian existantes doivent être réévaluées ; jetez tout cequi a été incorporé en amont (sous une forme ou une autre), et souvenez-vousde garder ce qui ne l'a pas été, à moins qu'il n'y ait une bonne raison dene pas le faire ; - si le système de construction a été modifié (avec un peu de chance, vousêtes au courant depuis l'inspection des modifications amont), mettez à jourles dépendances de construction `debian/rules`{.filename} et`debian/control`{.filename}, si besoin est ; - [](){#reminders}[](){#reminders}vérifiez dans le [système de gestion de bogues(BTS)](http://www.debian.org/Bugs/){.ulink} que personne n'a fourni de correctifs aux bogues ouverts ; - vérifiez le contenu du fichier `.changes`{.filename} pour vousassurer que vous envoyez vers la bonne distribution, que les rapports debogue refermés sont correctement listés dans les champs`Closes`{.literal}, que les champs `Maintainer`{.literal} et`Changed-By`{.literal} correspondent, que le fichier est signé avecGPG, etc.

------------------------------------------------------------------------
[^\[78\]^](https://www.debian.org/doc/manuals/maint-guide/update.fr.html#idp39901104){.para}Pour obtenir la date au format voulu, utilisez `LANG=C date-R`{.literal}.
[^\[79\]^](https://www.debian.org/doc/manuals/maint-guide/update.fr.html#idp39910880){.para}Si vous utilisez la commande `dch -r`{.literal} pour faire cettedernière modification, n'oublier pas de sauver le fichier`changelog`{.filename} explicitement dans l'éditeur.
[^\[80\]^](https://www.debian.org/doc/manuals/maint-guide/update.fr.html#idp39936912){.para} Si un paquet `toto`{.systemitem} est empaquetéavec l'ancien format `1.0`{.literal}, ce peut plutôt être réalisé enexécutant `zcat/chemin`{.literal}/*`vers`*/*`toto`*\_*`ancienneversion`*.diff.gz|patch-p1 depuis la nouvelle arborescence source décompressée.
[^\[81\]^](https://www.debian.org/doc/manuals/maint-guide/update.fr.html#idp39985632){.para} Si la commande **uscan** télécharge les sources mises à jourmais n'exécute pas la commande **uupdate**, vous devriezcorriger le fichier `debian/watch`{.filename} pour avoir`debian uupdate`{.literal} après l'URL.
[^\[82\]^](https://www.debian.org/doc/manuals/maint-guide/update.fr.html#idp39993344){.para} Si votre parrain ou d'autres responsables s'opposent à la mise à jour dustyle d'empaquetage existant, ne vous embêtez pas à argumenter. Il y a deschoses plus importantes à faire.
[^\[83\]^](https://www.debian.org/doc/manuals/maint-guide/update.fr.html#idp40017184){.para}vous pouvez découper `gros.diff`{.filename} en plusieurs petitscorrectifs incrémentaux avec la commande **splitdiff**. Voir en ligne : [debian.org](https://www.debian.org/doc/manuals/maint-guide/update.fr.html){.spip_out}