Creating packages (Español)
Artículos relacionados
- Arch Build System
- Estándares de empaquetado en Arch
- Repositorio de usuarios de Arch
- Creating packages for other distributions
- makepkg
- pacman
- Patching in ABS
- PKGBUILD
- DeveloperWiki:Building in a Clean Chroot Este artículo tiene como objetivo ayudar a los usuarios a crear sus propios paquetes utilizando el sistema de compilación de Arch Linux, asi como subirlos en AUR. Cubre la creación de un PKGBUILD - un archivo de descripción de compilación de paquetes originado por para crear un paquete binario desde los archivos fuentes. Si ya está posee un archivo , vea makepkg. Para obtener instrucciones sobre las normas existentes y las formas de mejorar la calidad del paquete, consulte Arch packaging standards
- Archivos binarios a instalar.
- : contiene todos los metadatos requeridos por pacman para tratar con paquetes, dependencias, etc.
- : contiene hashes y marcas de tiempo de los archivos que se incluyen en la base de datos local para que pacman pueda verificar la integridad del paquete.
- : un archivo opcional utilizado para ejecutar comandos después de la fase de instalación/actualización/eliminación. (Este archivo sólo está presente si se especifica en el ).
- : un archivo opcional guardado por el responsable del paquete documentando los cambios del paquete. (No está presente en todos los paquetes.)
- Comprueba que las dependencias del paquete están instaladas.
- Descarga el(los) archivo(s) fuente desde el(los) servidor(es) especificado(s).
- Desempaque el(los) archivo(s) fuente(s).
- Compila el software y lo instala en un entorno fakeroot.
- Despojar los símbolos innecesarios de los binarios y las bibliotecas.
- Genera el archivo del metapaquete que se incluye con cada paquete.
- Comprime el entorno fakeroot en un archivo de paquete.
- Almacena el archivo de paquete en el directorio de destino configurado, que es el directorio de trabajo actual de forma predeterminada.
- Esto apunta al directorio donde makepkg extrae o crea enlaces simbólicos de todos los archivos de la matriz de origen.
- Esto apunta al directorio en el que makepkg agrupa el paquete instalado, que se convierte en el directorio raíz del paquete construido.
- Comprobar el contenido de PKGBUILD para buscar errores comunes y la jerarquía de archivos de paquetes para archivos innecesarios/extraviados.
- Escanea todos los archivos ELF en el paquete usando ldd, informando automáticamente qué paquetes con las bibliotecas compartidas requeridas faltan de las dependencias y que se pueden omitir como dependencias transitivas.
- Búsqueda heurística de dependencias perdidas y redundantes.
- Descargue el código fuente del software que quiera empaquetar.
- Trate de compilar e instalar el software en un directorio arbitrario
- Copie el prototipo de y renómbrelo como en un directorio de trabajo, preferiblemente ~/abs
- Edite el de acuerdo a las necesidades de su paquete
- Ejecute para verificar si el paquete se construye correctamente
- Si no es así, repita los últimos dos pasos
- Antes de automatizar el proceso de construcción de paquetes, deberá haberlo hecho por lo menos una vez de manera manual para saber de antemano exactamente lo que esta haciendo. Desafortunadamente muchos autores de paquetes se apegan al proceso de 3 pasos de
./configure, make make install
, este no es siempre el caso y puede quedar un paquete en muy malas condiciones si no aplica el cuidado necesario para que todo funcione bien. - En algunos pocos casos, los paquetes no son disponibles en código fuente y habrá que recurrir a scripts como para poder ejecutarlo, habrá de hacer una extensa investigación acerca de otros , leer los , buscar información del creador del programa, o buscar de Gentoo para poder ejecutar la instalación, recuerde que makepkg debe ser completamente automático y sin intervención del usuario.
- Go: go-makepkg
- Haskell: cblrepo
- Python: , pip2arch-gitAUR,
- Ruby: , pacgemAUR
Resumen
Los paquetes en Arch Linux se construyen utilizando la utilidad makepkg y la información almacenada en un archivo PKGBUILD. Cuando se ejecuta, busca un archivo PKGBUILD
en el directorio actual y sigue las instrucciones en él para adquirir los archivos requeridos y/o copilarlos para empaquetarlos en un archivo de paquete(nombredelpaquete.pkg.tar.xz
). El paquete resultante contiene archivos binarios e instrucciones de instalación listas para ser instaladas por pacman.
Un paquete de Arch no es más que un archivo tar o 'tarball', comprimido usando xz, que contiene los siguientes archivos generados por makepkg:
Metapaquetes y grupos
Un grupo de paquetes es un conjunto de paquetes relacionados, definido por el empaquetador, que se pueden instalar o desinstalar simultáneamente utilizando el nombre de grupo como un sustituto para cada nombre de paquete individual. Si bien un grupo no es un paquete, puede instalarse de manera similar a un paquete, véase Pacman (Español)#Instalar grupos de paquetes y PKGBUILD (Español)#groups.
Un metapaquete a menudo (aunque no siempre) titulado con -meta sufijo, proporciona funcionalidad similar a un grupo de paquetes que permite que se instalen o desinstalen simultáneamente varios paquetes relacionados. Los metapaquetes pueden ser instalados como cualquier otro paquete, vea Pacman#Installing specific packages. La única diferencia entre un paquete meta y un paquete regular es que una metapaquete está vacío y existe puramente para vincular paquetes relacionados a través de dependencias.
La ventaja de un metapaquete, en comparación con un grupo, es que cualquier nuevo miembro del paquete se instalará cuando el propio metapaquete sea actualizado con un nuevo conjunto de dependencias. Esto contrasta con un grupo en el que los nuevos miembros del grupo no se instalarán automáticamente. La desventaja de un metapaquete es que no es tan flexible como un grupo - puede elegir los miembros del grupo que desea instalar pero no puede elegir qué dependencias del metapaquete desea instalar. Asimismo, puede desinstalar los miembros del grupo sin tener que quitar el grupo entero, sin embargo no se pueden quitar dependencias del metapaquete sin tener que desinstalar el metapaquete en sí mismo.
Preparación
Programas necesarios
Asegúrese primero de que las herramientas necesarias estén instaladas. Instalando el grupo de paquetes debe ser suficiente; incluye make y herramientas adicionales necesarias para compilar desde el codigo fuente.
Una de las herramientas clave para la construcción de paquetes es makepkg (proporcionado por pacman), que hace lo siguiente:
Descargar y probar la instalación
Descargue el tarball con el codigo fuente del software que desea empaquetar, extráigalo, y siga los pasos del autor para instalar el programa. Anote todos los comandos y/o pasos necesarios para compilarlo e instalarlo. Usted repetirá los mismos comandos en el archivo PKGBUILD. La mayoría de los autores de software se adhieren al ciclo de compilación de 3 pasos:
./configure make make installEste es un buen momento para asegurarse de que el programa funciona correctamente.
Creando el PKGBUILD
Cuando usted ejecuta , buscará un archivo en el directorio de trabajo actual. Si se encuentra un archivo se descargará el código fuente del software y compilará de acuerdo con las instrucciones especificadas en el archivo . Las instrucciones deben ser completamente interpretables por el shell Bash. Después de la finalización satisfactoria, los binarios y metadatos resultantes del paquete, i.e. versión del paquete y dependencias, se empaquetan en un archivo de paquete que se puede instalar con .
Para comenzar con un nuevo paquete, primero debe crear un directorio de trabajo vacío, entre en ese directorio y cree un archivo . Puede copiar el PKGBUILD de ejemplo desde el directorio a su directorio de trabajo o copiar un de un paquete similar. Este último puede ser útil si sólo necesita cambiar algunas opciones.
Definiendo las variables del
Ejemplos de archivos PKGBUILD se encuentran en /usr/share/pacman/
. Se puede encontrar una explicación de las posibles variables en el artículo PKGBUILD.
makepkg define dos variables que se debe utilizar como parte del proceso de creación e instalación:
Todos ellos contienen rutas absolutas, lo que significa que no tiene que preocuparse por su directorio de trabajo si utiliza estas variables correctamente.
Funciones PKGBUILD
Hay cinco funciones, enumeradas aquí en el orden en que se ejecutan si todas existen. Si una no existe, simplemente se omite.
prepare()
Esta función, utiliza comandos para preparar las fuentes para la construcción que se ejecuta, como parches. Esta función se ejecuta justo después de la extracción del paquete, antes de pkgver() y la función de build. Si la extracción se omite (), entonces prepare()
no se ejecuta.
pkgver()
se ejecuta después de la obtención de las fuentes, la extracción y la ejecución de prepare(). Así que uested puede actualizar la variable pkgver durante la etapa makepkg.Esto es particularmente útil si está haciendo making git/svn/hg/etc. paquetes, donde el proceso de construcción puede seguir siendo el mismo, pero el codigo fuente podría ser actualizado todos los días, incluso cada hora. La vieja manera de hacer esto era poner la fecha en el campo del pkgver, donde si el Software no se actualizaba, makepkg aún así lo reconstruiría pensando que la versión había cambiado. Algunos comandos útiles para esto son , hg identify -ni
, etc. Por favor pruebe estos antes de enviar un PKGBUILD, ya que un error en la función puede detener la compilación.
Nota: pkgver no puede contener espacios ni guiones (). El uso de sed para corregir esto es común.
build()
Ahora necesita implementar la función en el archivo . Esta función utiliza comandos de shell comunes en la sintaxis de Bash para compilar automáticamente el software y crear un directorio para instalar el software. Esto permite a makepkg empaquetar archivos sin tener sin tener que filtrar el sistema de archivos.
El primer paso en la función es cambiar al directorio creado descomprimiendo el tarball de origen. makepkg cambiará el directorio actual a antes de ejecutar la función . Por lo tanto, en la mayoría de los casos, como se sugiere en , el primer comando se verá así:
cd "$pkgname-$pkgver"Ahora, necesita listar los mismos comandos que utilizó cuando compiló manualmente el software. La función en esencia automatiza todo lo que hizo a mano y compila el software en el entorno de compilación fakeroot. Si el software que está empaquetando utiliza un script, es una buena práctica usar al crear paquetes para pacman. Una gran cantidad de software instala archivos relativos al directorio /usr/local
, que sólo se debe hacer si se está generando manualmente desde el codigo fuente. Todos los paquetes Arch Linux deben usar el directorio . Como se ve en el archivo , las siguientes dos líneas suelen tener este aspecto:
check()
Momento para llamar a make check
para hacer chequeos y rutinas similares de prueba. Es muy recomendable tener , ya que ayuda a asegurar que el software se ha construido correctamente y funciona bien con sus dependencias.
Usuarios que no lo necesitan (Y ocasionalmente los mantenedores que no pueden arreglar un paquete para que esto pase) puede inhabilitarlo usando en el PKGBUILD/makepkg.conf o llamar con flag .
package()
El paso final es poner los archivos compilados en un directorio donde makepkg puede recuperarlos para crear un paquete. Por defecto es el directorio - un simple entorno fakeroot. El directorio replica la jerarquía del sistema de archivos raíz de las rutas de instalación del software. Si tiene que colocar manualmente los directorios raíz de su sistema de archivos, debe instalarlos en el directorio bajo la misma estructura de directorios. Por ejemplo, si desea instalar un archivo en , debe colocarse en . Muy pocos procedimientos de instalación requieren que el usuario copie docenas de archivos manualmente. En su lugar, la mayoría de software lo hará. La última línea debe ser similar a la siguiente para poder instalar correctamente el software en el directorio :
make DESTDIR="$pkgdir/" installDESTDIR
no se utiliza en el Makefile
; puede que tenga que usar prefix
en su lugar. Si el paquete está construido con autoconf / automake, use DESTDIR
; esto es lo que se documenta en los manuales. Si DESTDIR
no funciona, trate de construir con make prefix="$pkgdir/usr/" install
. Si eso no funciona, tendrá que buscar más en los comandos de instalación que son ejecutados por "make <...> install
".En algunos casos raros, el software espera ejecutarse desde un único directorio. En tales casos, es aconsejable simplemente copiarlos .
A menudo, el proceso de instalación del software creará subdirectorios debajo del directorio . Si no lo hace, makepkg generará muchos errores y necesitará crear manualmente subdirectorios añadiendo los comandos apropiados de en la función antes de ejecutar el procedimiento de instalación.
En los paquetes antiguos, no había ninguna función package()
. Por lo tanto, los archivos se colocaban en el directorio pkg al final de la función . Si package()
no está presente, se ejecuta a través de fakeroot. En paquetes nuevos, package()
es necesario y se ejecuta a través de fakeroot en su lugar, y se ejecuta sin privilegios especiales.
package()
, por lo que crea un archivo archivo sin compilar el paquete. Esto puede ahorrar tiempo, e.g. si acaba de cambiar las variables del paquete.
Prueba del PKGBUILD y del paquete
Al escribir la función , querrá probar sus cambios frecuentemente para asegurarse de que no haya errores. Puedes hacerlo usando el comando en el directorio que contiene el archivo . Con un correctamente formateado, makepkg creará un paquete; con un roto o inacabado, provocará un error.
Si makepkg finaliza correctamente, colocará un archivo denominado en su directorio de trabajo.
Este paquete puede ser instalado con el comando . Sin embargo, sólo porque un archivo de paquete fue construido no implica que es totalmente funcional. Eso 11 Posiblemente sólo contenga el directorio y ningún archivo en si, por ejemplo,
un prefijo se especificó incorrectamente. Puedes usar las funciones de consulta de pacman para mostrar una lista de archivos contenidos en el paquete y las dependencias que requiere con ppacman -Qlp [package file]
y , respectivamente.
¡Si el paquete parece sano, entonces usted a terminado! Sin embargo, si planea liberar el archivo , es imperativo que compruebe y compruebe de nuevo el contenido de la matriz de .
También asegúrese de que los binarios del paquete realmente funcionan perfectamente! Es molesto liberar un paquete que contiene todos los archivos necesarios, pero se bloquea Debido a alguna opción de configuración poco clara que no funciona bien con el resto del sistema. Si solo va a compilar paquetes para su propio sistema, entonces usted no necesita preocuparse demasiado sobre este paso de aseguramiento de calidad, después de todo es la única persona que sufre de errores.
Comprobación de la sanidad del paquete
Después de comprobar la funcionalidad del paquete, compruebe si hay errores con namcap:
$ namcap PKGBUILD $ namcap <package file name>.pkg.tar.xzNamcap deberá:
y mucho más. Adquiera el hábito de revisar sus paquetes con namcap para evitar tener que arreglar los errores más simples después de la subida del paquete.
Subir paquetes a AUR
Por favor lea Arch User Repository#Submitting packages de la guía de AUR. Para una descripción detallada del proceso.
Resumen
Advertencias
Directrices más detalladas
Generadores de PKGBUILD
Los PKGBUILD para algunos paquetes se pueden generar automáticamente.