Je vous présente une bibliothèque écrite en Shell : bash-argsparse
Bash-argsparse permet une gestion des options de la ligne de commande en plus haut niveau qu'un simple getopt, un peu comme le module argparse de python.
Parmi la liste des fonctionnalités, on trouve :
- la génération automatique du --help ;
- la vérification des entrées utilisateurs, soit suivant des énumérations, soit suivant des formats pré-établis (nombres entiers, adresses IP, etc.), soit via des résultats de fonctions définies par le développeur du script ;
- l'exclusion mutuelle de plusieurs options ;
- le cumul de valeur par répétition d'une option ;
- et plein d'aut'trucs.
Bash-Argsparse est écrit pour GNU Bash version 4 et fait un usage intensif des tableaux, tableaux associatifs et autres built-ins de Bash.
Il manque encore certaines fonctionnalités, notamment la gestion des paramètres positionnels (les trucs après le '--') qui fera partie d'une prochaine version, mais le code existant est plutôt stable. Libre aussi à vous de soumettre des requêtes pour de nouvelles fonctionnalités.
Aller plus loin
- Bash Argsparse sur github (815 clics)
- Page de téléchargement (342 clics)
# passé sous zsh...
Posté par isildur37 . Évalué à 5.
Tu as l'air d'avoir fait un sacré taff. Malheureusement pour moi je suis passe a zsh en shell principal. Mais je note pour mes scripts ;)
[^] # Re: passé sous zsh...
Posté par Bapt (site web personnel) . Évalué à 5.
sous zsh tu as zparseopts qui est assez magique aussi :), man zshmodules pour plus d'infos
[^] # Re: passé sous zsh...
Posté par ariasuni . Évalué à 3.
Et je crois que zsh peut interpréter le bash. De toute façon tu peux créer un script bash et l'exécuter depuis zsh.
Écrit en Bépo selon l’orthographe de 1990
[^] # Re: passé sous zsh...
Posté par Jiehong (site web personnel) . Évalué à 3.
Je trouve que
bash-argsparse
à l'air vraiment plus pratique à utiliser, et surtout à retenir !Merci pour ce code !
# Vulgaire ?
Posté par Cyril F (site web personnel) . Évalué à 2.
getopt n'est pas vulgaire, juste un peu rustre …
http://la-rache.com
[^] # Re: Vulgaire ?
Posté par Benoît Sibaud (site web personnel) . Évalué à 3.
Disons plutôt simple. Je modifie.
[^] # Re: Vulgaire ?
Posté par Ignatz Ledebur . Évalué à 1.
Pendant qu'on est dans les corrections, c'est getopt**s**, et non getopt (le man de dash indiquant que celle-là est une évolution de celle-ci, qui ne supportait pas les espaces au sein des arguments). :)
[^] # Re: Vulgaire ?
Posté par Dams Nadé (site web personnel) . Évalué à 1.
Non, je voulais bien parler de [/usr]/bin/getopt qui fait partie de util-linux. Mais getopts etant sensiblement moins evolue (pas d'option longue.. -_-) que getopt, tu vois bien la transitivite.
[^] # Re: Vulgaire ?
Posté par Ignatz Ledebur . Évalué à 2.
Ah oui d'accord, j'avais pas vu qu'il y avait toujours un utilitaire. C'est un peu spécial comme fonctionnement: tu parses une première fois la ligne de commande avec getopt, tu redéfinis la première à partir de sa sortie avec set, puis tu parses à nouveau la nouvelle ligne de commande avec le shell… je croyais faire des trucs tordus ci-dessous, mais le /usr/share/getopt/getopt-parse.bash n'est pas mal non plus dans le genre. :)
Pour l'absence d'option longue avec getopts, c'est sûrement parce qu'ils se sont arrêtés à une version POSIX, pour qui les options ne peuvent être que courtes.
# Exemple d'utilisation
Posté par JGO . Évalué à 8.
Merci pour le logiciel et pour la dépêche. Cependant j'aurais bien aimé un petit exemple directement dans la dépêche. Je pourrais fouiller sur github et/ou lire le code, mais ça serait tellement plus pratique d'avoir juste au-dessous un exemple basique pour illustrer le propos, surtout que c'est la première fois que ce logiciel est présenté et donc personne n'est censé déjà connaitre.
[^] # Re: Exemple d'utilisation
Posté par Dams Nadé (site web personnel) . Évalué à 6.
C'est vrai que j'aurai pu rajouter un lien direct vers le didacticiel.
https://github.com/Anvil/bash-argsparse/blob/master/tutorial/
Et commençons par le commencement : https://github.com/Anvil/bash-argsparse/blob/master/tutorial/1-basics
Chaque fichier du tuto est un shell script a la fois a lire et a exécuter.
C'est sur qu'il est pas commenté en français, mais si c'est obscure je suis prêt a le rendre plus clair.
Si tu veux un exemple rapido-trivial, tu peux toujours essayer ça :
Ça tient en 4 lignes, la ou tu aurais du invoquer getopt, faire ta fonction usage, etc..
# Les grands esprits toussa...
Posté par Ignatz Ledebur . Évalué à 3.
Amusant, je suis en ce moment également en train de chercher une alternative plus souple à getopts, dans une autre approche cependant: je cherche quelque chose de compact et POSIX. Comme j'aime beaucoup les interfaces BSD/POSIX (à base d'options courtes exclusivement), voici à quoi je suis arrivé:
Qui à l'exécution nous donne ceci:
C'est bien sûr loin d'être aussi complet que ce qui est proposé par argsparse, mais c'est portable et pour ma part je préfère avoir la pleine maîtrise de l'interface (dans la gestion des erreurs en particulier).
# Exemple simple
Posté par Romuald Delavergne . Évalué à 4.
Votre librairie apporte certainement de la souplesse d'utilisation.
Cependant le code ci-dessous suffit dans la plupart des cas.
[^] # Re: Exemple simple
Posté par barmic . Évalué à 2.
Bof, moi j'aime pouvoir combiner les flags ("-l -o" devient "-lo" voir "lo" comme avec tar).
Tous les contenus que j'écris ici sont sous licence CC0 (j'abandonne autant que possible mes droits d'auteur sur mes écrits)
[^] # Re: Exemple simple
Posté par Dams Nadé (site web personnel) . Évalué à 5. Dernière modification le 12 octobre 2013 à 15:34.
Je ne force personne (a part certains, qui se reconnaitront - private joke) mais je refute l'argument.
J'ai constate que ce genre de bout de code etait tres souvent 1. dupliqué partout, tout le temps 2. penible a ecrire 3. penible a ecrire correctement, a la fois dans la syntaxe (manque de double-quotes, "eval" utilise a mauvais escient et mal controle) et dans le design (gestions des options longues hasardeuse, variables utilisees nommees aleatoirement, ce qui nuit a la lisibilite).
Typiquement, ton exemple ne gere pas le cas d'une chaine vide passee en parametre.
Pour la ligne de commande
Ton script ignorera completement 1, 2 et 3.
C'est peut-etre un detail pour vous mais pour moi ca veut dire beaucoup.Et peut-etre que tu n'en as rien a faire pour ton cas specifique mais de la a dire que ca convient dans la plupart des cas je trouve ca un tantinet exagere.Pour moins de lignes de code, je te propose d'avoir en plus :
Je pense qu'argsparse est encore moins contraignant pour les gens qui ne veulent pas se prendre la tete.
Suivre le flux des commentaires
Note : les commentaires appartiennent à celles et ceux qui les ont postés. Nous n’en sommes pas responsables.