Tenemos varios archivos .deb hechos a mano (con fpm y jenkins) en un repositorio local de Apt (reprepro). Estos .debs contienen un archivo .desktop que será recogido por xdg-desktop en un script posterior al inst.
Si instalamos el archivo deb a mano, en un nuevo sistema, todo está bien.
Si instalamos una nueva versión con apt-get install, obtenemos este error
xdg-desktop-menu: file '/usr/local/share/applications/customthingy.desktop' does not exist
Si descargo el archivo deb con apt-get install -d customthingy y ejecuto
dpkg -i /var/cache/apt/archives/customthingy_2-r3_all.deb
Me sale el mismo xdg-desktop
error que antes. Entonces eso descarta un problema con apt.
Si enumero el contenido de la descarga descargada,
tom.oconnor@charcoal-black:~$ dpkg --contents /var/cache/apt/archives/customthingy_2-r3_all.deb |grep ".desktop"
-rw-r--r-- root/root 201 2011-07-28 20:02 ./usr/local/share/applications/customthingy.desktop
Puedes ver que el archivo existe.
Sin embargo .. Si purgamos antes de reinstalar,
tom.oconnor@charcoal-black:~$ sudo apt-get purge customthingy
Reading package lists... Done
Building dependency tree
Reading state information... Done
The following packages will be REMOVED
customthingy*
0 upgraded, 0 newly installed, 1 to remove and 84 not upgraded.
After this operation, 0B of additional disk space will be used.
Do you want to continue [Y/n]? y
(Reading database ... 219342 files and directories currently installed.)
Removing customthingy ...
Purging configuration files for customthingy ...
Y entonces
tom.oconnor@charcoal-black:~$ sudo apt-get install customthingy
Reading package lists... Done
Building dependency tree
Reading state information... Done
The following NEW packages will be installed
customthingy
0 upgraded, 1 newly installed, 0 to remove and 84 not upgraded.
Need to get 0B/4,030B of archives.
After this operation, 0B of additional disk space will be used.
Selecting previously deselected package customthingy.
(Reading database ... 219319 files and directories currently installed.)
Unpacking customthingy (from .../customthingy_2-r3_all.deb) ...
Setting up customthingy (2-r3) ...
EDITAR: Contenido del script Postinst
#!/bin/sh
# Add an entry to the system menu
XDG_DESKTOP_MENU="`which xdg-desktop-menu 2> /dev/null`"
if [ ! -x "$XDG_DESKTOP_MENU" ]; then
echo "WARNING: Could not find xdg-desktop-menu" >&2
else
"$XDG_DESKTOP_MENU" install --mode system /usr/local/share/applications/customthingy.desktop
"$XDG_DESKTOP_MENU" forceupdate --mode system
fi
No hay error Entonces ... Las preguntas son estas:
- ¿Es este comportamiento esperado o un error en apt / dpkg?
- ¿Tenemos un paquete con formato incorrecto con customthingy.deb que impide que una futura ejecución de reinstalación funcione?
- ¿Es seguro asumir que el post-inst siempre sucederá al final de la instalación, y podemos suponer con seguridad que todos los archivos se habrán extraído antes de este momento?
- ¿Estamos haciendo algo enormemente extraño?
apt
package-management
dpkg
Tom O'Connor
fuente
fuente
dpkg -D101 -i <package>
(o inclusodpkg -D1101
) resultados diferentes en cada escenario? Podría arrojar un orden diferente de ejecución.postinst
?Respuestas:
Supongo que
postinst
está llamandoxdg-desktop-menu
para mover el archivo de escritorio/usr/share/applications
y actualizar la base de datos de escritorio XDG. Esto se hace, por ejemplogoogle-chrome-stable
, pero no puedo entender por qué ( sigue leyendo)Si instala el archivo de escritorio directamente en su
/usr/share/applications
lugar (a través de dpkg, es decir, coloque el archivo allí a través de,dh_install
por ejemplo, tal que la ruta en el.deb
es justo/usr/share/applications
), una serie de paquetes automáticamente 'activarán' las actualizaciones: notablementegnome-menus
ydesktop-file-utils
, pero tal vez otros (dependiendo de la versión precisa del sistema operativo de destino, etc.)Al menos en mi caso, estos son suficientes para lograr lo que
xdg-desktop-menu
haría correr a mano (el programa aparece en mis menús de usuario de inmediato)Todavía estoy en la oscuridad sobre por qué
google-chrome-stable
y otros (predominantemente de terceros).deb
envían el archivo de escritorio a otro lugar que no sea/usr/share/applications
(/opt
en el caso de Chrome) y luego lo mueven a mano.fuente
postinst
. Eso parece sugerir que he adivinado correctamente. Todavía nopostinst
tengo idea de por qué es así, pero intente ver si puede reorganizar las cosas como he descrito, para ver si resuelve sus problemas.Error on file "/usr/local/share/applications/silhouettefx-silhouette.desktop": No such file or directory
lo que indica que aún podría ser un problema prerm/usr/share/applications
, no necesitapostinst
nada (o elprerm
fragmento equivalente ), intente eso.Son los scripts postrm / prerm que llaman "xdg-desktop-menu --uninstall 'los culpables, es decir
Eso eliminará el archivo .desktop justo antes de que la invocación posterior a xdg-desktop-menu intente usarlo. Muy agradable.
Hablando de las debs de google-chrome, también incluyen esta estrofa en la parte superior de su script prerm:
Este es un enfoque duro para solucionar el problema, pero parece estar haciendo el truco aquí (y también para el poderoso Goog).
Pablo
fuente