[Date Prev][Date Next] [Thread Prev][Thread Next] [Date Index] [Thread Index]

Re: debian 11 - créer une "desktop icon"... simplement




On 07/03/2023 01:44, roger.tarani@free.fr wrote:

----- Mail original -----
De: "hamster" <hamster@suna.fdn.fr>
À: "Liste Debian" <debian-user-french@lists.debian.org>
Envoyé: Lundi 6 Mars 2023 21:31:25
Objet: Re: debian 11 - créer une "desktop icon"... simplement

Le 06/03/2023 à 17:34, roger.tarani@free.fr a écrit :
Je n'ai pas vraiment mélangé.
J'ai reporté mon expérience selon 2 voies communément relayées sur internet.

*Procédé 1/CLI : *
Je crée un fichier (que je dois saisir avec mes doigts et un clavier) 
que j'enregistre dans ~/Desktop :

$ cat ~/Desktop/test.desktop
[Desktop Entry]
Version=1.0
Type=Application
Terminal=false
Exec=/usr/bin/gedit
Name=gedit
Comment=gedit
Icon=/home/test/Desktop/logo.png

SUR LE BUREAU, ou dans une fenête de navigateur (nautilus),
Je clique droit dessus et je choisis ouvrir avec "Create launcher on the 
panel".
Non non non. Ce fichier EST le launcher, il ne faut donc pas essayer de 
créer un launcher avec. Tu a juste a faire ce fichier et lui donner les 
droits d'execution, pas a faire de clic droit dessus ou autres opérations.

En fait, c'est bien plus simple que ce que tu essaye de faire.

OUI, OUI, OUI ! En effet.


J'ai alors une erreur :
"Failed to add a plugin to the panel
GDBus.Error:org.freedesktop.DBus.Error.Service.UNknown: The name 
org.xfce.Panel was not provided by any .service files"
Voir image ci-dessous.

C'est cette commande qui ne s'exécute pas :
$ ps aux | grep xfce
... *xfce4-panel --add=launcher /home/test/Desktop/test.desktop*
Logique : tu essaye de créer un launcher qui lance… un autre launcher.

Maintenant, c'est clair. Je m'attendais à ce qu'un launcher soit créé
avec l'amorce de définition du fichier .desktop .


 
Il apparaît donc cette commande que j'ignorais et qui me permet à 
présent d'être à 100% en CLI :
'xfce4-panel --add=launcher /home/test/Desktop/test.desktop'
Je suppose que cette commande marcherait si tu lui passait comme 
paramètre le chemin d'un binaire executable ou d'un script. 


Une possibilité complémentaire (pour faire un "lanceur") qui a besoin des privilèges de root, serait de coder un petit programme (soigné, il doit vérifier chaque appel système listé dans https://man7.org/linux/man-pages/man2/syscalls.2.html ) en C (ou C++) dont le binaire serait mis dans /usr/local/bin/ par exemple


coder avec soin un programme (plutôt minimal) toto.c qui fait les appels systèmes détaillés ci-dessous.

le compiler avec gcc -Wall -Wextra -g -O toto.c -o /tmp/toto.bin et d'autres options choisies avec soin, peut-être -I reph et -L repl et -lbiblio reph est un repertoire d'entêtes (peut-être /usr/local/include/ ...) et repl un répertoire de bibliothèques (peut-être /usr/local/lib/ ...) qu'on nomme biblio

le déboguer convenablement (en ligne de commande, et avec strace(1) et gdb(1) ....) et peut-être même avec l'aide de Frama-C et d'annotations ACSL

une fois qu'on est sûr de soi on installe le binaire exécutable avec le privilège setuid.

cp -v /tmp/toto.bin /usr/local/bin/

chmod u+s /usr/local/bin/toto.bin


Les appels systèmes et fonctions significatifs à utiliser avec soin et rigueur dans toto.c sont parmi les suivants


et des dizaines d'autres!


Si on est parano, on ferait peut-être même des exécutables intermédiaires.


Cordialement

-- 
Basile Starynkevitch                  <basile@starynkevitch.net>
(only mine opinions / les opinions sont miennes uniquement)
92340 Bourg-la-Reine, France
web page: starynkevitch.net/Basile/ & refpersys.org


Reply to: