IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Shell et commandes GNU Discussion :

[bash] gestion des erreurs


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 17
    Par défaut [bash] gestion des erreurs
    bonjour,

    Je voudrais l'avis de gens expérimentés concernant la gestion des erreurs dans les scripts bash.

    J'ai fait une fonction assert_function qui sert à sortir du script en cas d'erreur.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    function assert_function ()
    {
        if [ 0 != $? ]
        then
            printf "erreur.\n" >&2
            exit 1
        fi
    }
     
    function test ()
    {
        assert_function
     
        # ...
    }
    Je pense l'utiliser systématiquement en début de toutes mes fonctions.

    Pensez-vous que c'est une bonne démarche, faite correctement ?
    Est-ce que c'est vouloir trop contrôler ?
    Voyez-vous des faiblesses dans le code ?

    Merci,

  2. #2
    Modérateur
    Avatar de jlliagre
    Homme Profil pro
    Ingénieur support avancé & développement
    Inscrit en
    Juin 2007
    Messages
    2 695
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur support avancé & développement
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 695
    Par défaut
    Ce code teste le code retour de la commande ayant été exécutée juste avant l'appel des fonctions, ce qui n'est pas exhaustif.

    Si toutes les erreurs doivent être détectées et entraîner la sortie du script, le plus simple est d'utiliser l'option "-e"
    ou le trap ERR, plus souple (on peut afficher/executer ce que l'on veut):


  3. #3
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 835
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par dev_KooK Voir le message
    Voyez-vous des faiblesses dans le code ?
    Bonjour
    Oui, il y a une faiblesse: la comparaison des numériques se fait avec les flags -eq et -ne (et d'autres comme -gt, -ge, etc). Pas avec "=" ou "!=" qui sont réservés à la comparaison des chaines.
    Ainsi, test 5 = 000005 renverra faux alors que test 5 -eq 000005 renverra vrai...

    Citation Envoyé par dev_KooK Voir le message
    Est-ce que c'est vouloir trop contrôler ?
    Pour moi on ne contrôle que ce dont on a besoin. Déjà que le shell n'est pas rapide, si en plus on lui inflige des cycles inutiles... Surtout que tu as effectivement l'option "-e" (que perso je préfère positionner via set ce qui permet de ne contrôler qu'une partie du code)...
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    #!/bin/bash
    ...
    ... (code non critique)
    ...
     
    # Début du code critique
    set -e
    ...
    ... (code critique)
    ...
    # Fin du code critique
    set +e
     
    ...
    ... (code non critique)
    ...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 17
    Par défaut
    Merci à vous.
    En effet set -e semble répondre parfaitement à ce que je voulais.
    La remarque sur les tests était la bienvenue aussi.


  5. #5
    Modérateur
    Avatar de jlliagre
    Homme Profil pro
    Ingénieur support avancé & développement
    Inscrit en
    Juin 2007
    Messages
    2 695
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur support avancé & développement
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 695
    Par défaut
    Juste un commentaire sur le test justement:

    Bien que correct, l'ordre des deux arguments du test dans :

    n'est pas habituel en shell. On le rencontre souvent en java pour éviter les nullPointerException mais en shell script, on met plutôt:

    D'autre part, la remarque de Sve@r sur -ne est bonne à connaitre mais n'a aucun impact dans ce cas précis. $? contient toujours une valeur numérique valide et que l'on teste sa valeur sous forme de chaine ou convertie en entier est strictement équivalent.

  6. #6
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 835
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par jlliagre Voir le message
    D'autre part, la remarque de Sve@r sur -ne est bonne à connaitre mais n'a aucun impact dans ce cas précis.
    Utiliser les instructions adaptées aux éléments qu'on manipule a deux avantages indéniables
    1. ça fonctionne dans ce cas précis
    2. ça fonctionne aussi dans tous les autres cas


    Citation Envoyé par jlliagre Voir le message
    $? contient toujours une valeur numérique valide
    Argument légèrement bancal car 000005 est aussi une valeur numérique valide. Mais on comprend ce que tu veux dire. $? contient toujours une valeur numérique expurgée de tout chiffre non significatif.
    Ce qui ne m'empêche pas de redire qu'il vaut mieux utiliser une instruction qui fonctionne tout le temps que de se laisser aller sur la pente dangereuse du "double salto sans filet"...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [FB] Gestion des erreurs et application francophone
    Par Benjamin GAGNEUX dans le forum Installation
    Réponses: 10
    Dernier message: 20/05/2006, 14h54
  2. [struts][Datasource]Gestion des erreurs
    Par GreenJay dans le forum Struts 1
    Réponses: 8
    Dernier message: 15/09/2004, 16h51
  3. [VB6] Gestion des erreurs dans une dll
    Par zimba-tm dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 02/08/2004, 11h20
  4. [XSLT]Est ce qu'il y'a la gestion des erreur en xslt ?
    Par miloud dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 04/02/2004, 17h19
  5. [LG]gestion des erreurs
    Par frontin dans le forum Langage
    Réponses: 3
    Dernier message: 29/11/2003, 22h41

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo