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-desktoperror 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
postinstestá llamandoxdg-desktop-menupara mover el archivo de escritorio/usr/share/applicationsy 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/applicationslugar (a través de dpkg, es decir, coloque el archivo allí a través de,dh_installpor ejemplo, tal que la ruta en el.debes justo/usr/share/applications), una serie de paquetes automáticamente 'activarán' las actualizaciones: notablementegnome-menusydesktop-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-menuharí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-stabley otros (predominantemente de terceros).debenvían el archivo de escritorio a otro lugar que no sea/usr/share/applications(/opten el caso de Chrome) y luego lo mueven a mano.fuente
postinst. Eso parece sugerir que he adivinado correctamente. Todavía nopostinsttengo 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 directorylo que indica que aún podría ser un problema prerm/usr/share/applications, no necesitapostinstnada (o elprermfragmento 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