Apéndice A. Técnicas avanzadas

Tabla de contenidos

A.1. Bibliotecas compartidas
A.2. Gestionando debian/package.symbols
A.3. Varias arquitecturas
A.4. Construcción de un paquete de biblioteca compartida
A.5. Paquete nativo Debian

The rewrite of this tutorial document with updated contents and more practical examples is available as Guide for Debian Maintainers. Please use this new tutorial as the primary tutorial document.

Here are some hints and pointers for advanced packaging topics that you are most likely to deal with. You are strongly advised to read all the references suggested here.

Puede ser necesario editar manualmente los ficheros de las plantillas generadas con la orden dh_make para abordar los temas tratados en este capítulo. La nueva orden debmake maneja mejor estos aspectos de la construcción de paquetes.

Antes de empaquetar bibliotecas compartidas, debes leer atentamente la siguientes referencias básicas:

Éstos son algunos consejos básicos para empezar:

  • Las bibliotecas compartidas son archivos objeto en formato ELF que contienen código compilado.

  • Las bibliotecas compartidas se distribuyen como ficheros *.so (no como ficheros *.a o *.la).

  • Las bibliotecas compartidas se utilizan principalmente para compartir código común entre varios ejecutables con la orden ld.

  • Las bibliotecas compartidas se utilizan, a veces, para proveer varios complementos («plugins») a un ejecutable mediante el procedimiento dlopen.

  • Shared libraries export symbols, which represent compiled objects such as variables, functions, and classes; and enable access to them from the linked executables.

  • El SONAME (el nombre lógico) de la biblioteca compartida libnombre_biblioteca.so.1: objdump -p libnombre_biblioteca.so.1 | grep SONAME [87]

  • El «SONAME» (el nombre lógico) de una biblioteca compartida generalmente coincide con el nombre del archivo de biblioteca (pero no siempre).

  • El «SONAME» (el nombre lógico) de las bibliotecas compartidas enlazadas a /usr/bin/foo: objdump -p /usr/bin/foo | grep NEEDED [88]

  • libfoo1: el paquete de biblioteca de la biblioteca compartida libfoo.so.1 con la versión ABI del nombre lógico («SONAME») 1.[89]

  • Los guiones de desarrollador de un paquete de biblioteca deben ejecutar ldconfig cuando sea necesario para generar los enlaces simbólicos para el «SONAME» (el nombre lógico).[90]

  • libfoo1-dbg: the debugging symbols package that contains the debugging symbols for the shared library package libfoo1.

  • libfoo-dev: the development package that contains the header files etc. for the shared library libfoo.so.1.[91]

  • Debian packages should not contain *.la Libtool archive files in general.[92]

  • Debian packages should not use RPATH in general.[93]

  • Aunque está un poco anticuado y es sólo una referencia secundaria, Debian Library Packaging Guide aún puede ser útil.

When you package a shared library, you should create a debian/package.symbols file to manage the minimal version associated with each symbol for backward-compatible ABI changes under the same SONAME of the library for the same shared library package name.[94] You should read the following primary references in detail:

Here is a rough example of how to create the libfoo1 package from the upstream version 1.3 with the proper debian/libfoo1.symbols file:

  • Preparar el esqueleto de directorios fuente Debian utilizando el fichero con las fuentes libfoo-1.3.tar.gz.

    • Si es la primera versión del paquete libfoo1, genera un fichero debian/libfoo1.symbols en blanco.

    • Si la versión anterior del autor (la 1.2) fue empaquetada en el paquete libfoo1 con el fichero debian/libfoo1.symbols adecuado en el paquete fuente, utilízalo otra vez.

    • If the previous upstream version 1.2 was not packaged with debian/libfoo1.symbols, create it as the symbols file from all available binary packages of the same shared library package name containing the same SONAME of the library, for example, versions 1.1-1 and 1.2-1. [96]

      $ dpkg-deb -x libfoo1_1.1-1.deb libfoo1_1.1-1
      $ dpkg-deb -x libfoo1_1.2-1.deb libfoo1_1.2-1
      $ : > symbols
      $ dpkg-gensymbols -v1.1 -plibfoo1 -Plibfoo1_1.1-1 -Osymbols
      $ dpkg-gensymbols -v1.2 -plibfoo1 -Plibfoo1_1.2-1 -Osymbols
      
  • Make trial builds of the source tree with tools such as debuild and pdebuild. (If this fails due to missing symbols etc., there were some backward-incompatible ABI changes that require you to bump the shared library package name to something like libfoo1a and you should start over again.)

    $ cd libfoo-1.3
    $ debuild
    ...
    dpkg-gensymbols: advertencia: hay símbolos nuevos en el fichero de símbolos: ...
     mire las diferencias a continuación
    --- debian/libfoo1.symbols (libfoo1_1.3-1_amd64)
    +++ dpkg-gensymbolsFE5gzx        2012-11-11 02:24:53.609667389 +0900
    @@ -127,6 +127,7 @@
      foo_get_name@Base 1.1
      foo_get_longname@Base 1.2
      foo_get_type@Base 1.1
    + foo_get_longtype@Base 1.3-1
      foo_get_symbol@Base 1.1
      foo_get_rank@Base 1.1
      foo_new@Base 1.1
    ...
    
  • If you see the diff printed by the dpkg-gensymbols as above, extract the proper updated symbols file from the generated binary package of the shared library. [97]

    $ cd ..
    $ dpkg-deb -R  libfoo1_1.3_amd64.deb libfoo1-tmp
    $ sed -e 's/1\.3-1/1\.3/' libfoo1-tmp/DEBIAN/symbols \
            >libfoo-1.3/debian/libfoo1.symbols
    
  • Compilar paquetes para publicarlos con herramientas como debuild y pdebuild.

    $ cd libfoo-1.3
    $ debuild -- clean
    $ debuild
    ...
    

Además de los ejemplos anteriores, también debes comprobar la compatibilidad ABI con más atención y actualizar manualmente las versiones de los símbolos (si es necesario). [98]

Aunque es sólo una referencia secundaria, Debian wiki UsingSymbolsFiles y sus enlaces a otras páginas web puede ser útil.

La función de varias arquitecturas introducida en Debian «wheezy» integra la instalación en más de una arquitectura de los paquetes binarios (en particular i386<->amd64, pero también con otras combinaciones) en dpkg y apt. Se recomienda leer atentamente las siguientes referencias:

Se utilizan tripletes del tipo i386-linux-gnu y x86_64-linux-gnu para el directorio de instalación de bibliotecas compartidas. El triplete de trabajo se establece dinámicamente al valor $(DEB_HOST_MULTIARCH) por dpkg-architecture(1) para cada compilación. Por ejemplo, el directorio de instalación de bibliotecas para varias arquitecturas se cambia como sigue:[99]

Here are some typical multiarch package split scenario examples for the following:

  • el código fuente de la biblioteca libfoo-1.tar.gz

  • el código fuente de una orden bar-1.tar.gz escrito en un lenguaje compilado

  • el código fuente de una orden baz-1.tar.gz escrito en un lenguaje interpretado

Hay que tener en cuenta que el paquete de desarrollo debe contener un enlace simbólico a la biblioteca compartida asociada sin el número de versión. P. ej.: /usr/lib/x86_64-linux-gnu/libfoo.so -> libfoo.so.1

You can build a Debian library package enabling multiarch support using dh(1) as follows:

Debes comprobar que el paquete de biblioteca compartida solo contiene los ficheros esperados y que el paquete «-dev» sigue funcionando correctamente.

All files installed simultaneously as the multiarch package to the same file path should have exactly the same file content. You must be careful of differences generated by the data byte order and by the compression algorithm.

Si un paquete se mantiene exclusivamente para Debian o para uso local, su paquete fuente puede contener todos los ficheros debian/*. Hay dos maneras para empaquetarlos.

You can make the upstream tarball by excluding the debian/* files and package it as a non-native Debian package as in Sección 2.1, “Plan de trabajo para la construcción de paquetes Debian”. This is the normal way, which some people encourage using.

La alternativa es el esquema de trabajo para paquetes nativos Debian.

  • Generaremos un paquete fuente Debian en el formato 3.0 (native), utilizando un archivo comprimido en formato «tar» que incluirá todos los archivos.

    • nombre_del_paquete_versión.tar.gz
    • nombre_del_paquete_versión.dsc
  • Construiremos un paquete binario Debian del paquete de fuentes nativo Debian.

    • nombre_del_paquete_versión_arquitectura.deb

For example, if you have source files in ~/mypackage-1.0 without the debian/* files, you can create a native Debian package by issuing the dh_make command as follows:

$ cd ~/mi_paquete-1.0
$ dh_make --native

Then the debian directory and its contents are created just like in Sección 2.8, “Paquete no nativo Debian inicial”. This does not create a tarball, since this is a native Debian package. But that is the only difference. The rest of the packaging activities are practically the same.

Después de la ejecución de la orden dpkg-buildpackage, encontrarás los siguientes ficheros en el directorio superior:

  • mi_paquete_1.0.tar.gz

    Este es el archivo del código fuente generado a partir del directorio mi_paquete-1.0 por la orden dpkg-source (su sufijo no es orig.tar.gz.).

  • mi_paquete_1.0.dsc

    This is a summary of the contents of the source code, as in the non-native Debian package. (There is no Debian revision.)

  • mi_paquete_1.0_i386.deb

    This is your completed binary package, as in the non-native Debian package. (There is no Debian revision.)

  • mi_paquete_1.0_i386.changes

    Este archivo describe todos los cambios realizados en el versión actual del paquete en el caso de los paquetes Debian no nativos (no tiene código de revisión Debian).



[87] Como alternativa: readelf -d libnombre_biblioteca.so.1 | grep SONAME

[88] Como alternativa: readelf -d libfoo.so.1 | grep NEEDED

[94] Los cambios ABI incompatibles con versiones anteriores, normalmente requieren actualizar el «SONAME» (el nombre lógico) de la biblioteca y el de la biblioteca compartida a otros nuevos.

[95] Para bibliotecas C++ y otros casos en los que el seguimiento individual de símbolos es difícil, es mejor consultar Debian Policy Manual, 8.6.4 "The shlibs system".

[96] Las versiones previas de los paquetes Debian están disponibles en http://snapshot.debian.org/. La revisión Debian del paquete sigue a la versión para facilitar mantenimiento de versiones anteriores («backport») del paquete: 1.1 << 1.1-1~bpo70+1 << 1.1-1 y 1.2 << 1.2-1~bpo70+1 << 1.2-1

[97] La revisión de Debian se deriva de la versión para hacer más fácil el mantenimiento de versiones anteriores («backport») del paquete: 1.3 << 1.3-1~bpo70+1 << 1.3-1

[99] Old special purpose library paths such as /lib32/ and /lib64/ are not used anymore.

[100] Como alternativa, puedes añadir los argumentos --libdir=\$${prefix}/lib/$(DEB_HOST_MULTIARCH) y --libexecdir=\$${prefix}/lib/$(DEB_HOST_MULTIARCH) en ./configure. Fíjate que --libexecdir especifica el directorio predeterminado para la instalación de programas ejecutables que son ejecutados por otros programas en lugar de por los usuarios. El valor predeterminado por «Autotools» es /usr/libexec/ pero en Debian es /usr/lib/.