Temos vários arquivos .deb criados à mão (com fpm e jenkins) em um repositório local do Apt (reprepro). Esses .debs contêm um arquivo .desktop que será capturado pelo xdg-desktop em um script pós-inst.
Se instalarmos o arquivo deb manualmente, em um novo sistema, tudo estará bem.
Se instalarmos uma nova versão com o apt-get install, obteremos este erro
xdg-desktop-menu: file '/usr/local/share/applications/customthingy.desktop' does not exist
Se eu baixar o arquivo deb com o apt-get install -d customthingy, e execute
dpkg -i /var/cache/apt/archives/customthingy_2-r3_all.deb
Eu recebo o mesmo xdg-desktop
erro , como antes. Portanto, isso exclui um problema com o apt.
Se eu listar o conteúdo da deb baixada,
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
Você pode ver o arquivo existe.
No entanto .. Se limparmos 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 ...
E depois
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) ...
EDIT: Conteúdo do 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
Não há erro. Então .. As perguntas são estas:
- Esse comportamento é esperado ou é um bug no apt / dpkg?
- Temos um pacote malformado com customthingy.deb que impede que uma futura reinstalação funcione?
- É seguro supor que o pós-inst sempre ocorra no final da instalação e podemos assumir com segurança que todos os arquivos foram extraídos antes desse momento?
- Estamos fazendo algo massivamente estranho?
apt
package-management
dpkg
Tom O'Connor
fonte
fonte
dpkg -D101 -i <package>
(ou mesmodpkg -D1101
) produzir quaisquer resultados diferentes em cada cenário? Pode gerar uma ordem de execução diferente.postinst
?Respostas:
Suponho que você
postinst
esteja ligandoxdg-desktop-menu
para mover o arquivo da área de trabalho/usr/share/applications
e atualizar o banco de dados da área de trabalho XDG. Isso é feito por exemplogoogle-chrome-stable
, mas não consigo entender o porquê (continue lendo)Se você instalar o arquivo da área de trabalho diretamente no
/usr/share/applications
lugar (via dpkg - ou seja, coloque o arquivo lá pordh_install
exemplo, de modo que o caminho.deb
seja apenas/usr/share/applications
), vários pacotes automaticamente "dispararão" as atualizações: notavelmentegnome-menus
edesktop-file-utils
, mas talvez outros (dependendo da versão precisa do SO de destino etc.)Pelo menos no meu caso, são suficientes para alcançar o que a execução
xdg-desktop-menu
manual faria (o programa aparece nos meus menus de usuário imediatamente)Ainda estou no escuro sobre o porquê
google-chrome-stable
e outros (principalmente de terceiros).deb
enviam o arquivo da área de trabalho para outro lugar que não seja/usr/share/applications
(/opt
no caso do chrome) e depois o movemos manualmente.fonte
postinst
. Isso parece sugerir que adivinhei corretamente. Ainda não faço ideia porpostinst
que isso acontece, mas tente e veja se você pode reorganizar as coisas como descrevi para ver se isso resolve seus problemas.Error on file "/usr/local/share/applications/silhouettefx-silhouette.desktop": No such file or directory
que indica que ele ainda pode ser um problema prerm/usr/share/applications
, não precisará dopostinst
todo (ou doprerm
snippet equivalente ) - tente isso.São os scripts postrm / prerm que chamam "xdg-desktop-menu --uninstall 'que são os culpados, ou seja,
Isso excluirá o arquivo .desktop antes que a chamada postinst do xdg-desktop-menu tente usá-lo. Muito agradável.
Falando das debs do google-chrome, elas também incluem essa estrofe na parte superior de seu script pré-termo:
Essa é uma abordagem pesada para resolver o problema, mas parece estar fazendo o truque por aqui (e para o poderoso Goog também).
Paulo
fonte