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

C Discussion :

Rediriger perror dans un fichier texte


Sujet :

C

  1. #1
    Membre éclairé Avatar de sorry60
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    802
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 802
    Par défaut Rediriger perror dans un fichier texte
    Bonjour,

    Je n'arrive pas à rediriger perror() vers un fichier texte.

    Extrait man perror()
    La fonction perror() affiche un message sur la sortie d'erreur standard, décrivant la dernière erreur rencontrée durant un appel système ou une fonction de bibliothèque. La chaîne de caractère s est imprimée en premier, suivie d'un double-point ou d'un blanc, puis le message, suivi d'un saut de ligne.
    J'ai donc redirigé stderr vers mon fichier texte, mais ça ne fonctionne pas.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    FILE *fp;
    ...
    fp = freopen("log.txt","w",stderr);
    ...
    fprintf(stderr,"Erreur\n");
    perror();
    ...
    Le fichier texte contient bien le message "Erreur", mais pas le message de perror()

  2. #2
    Membre émérite Avatar de crocodilex
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    697
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 697
    Par défaut
    La fonction perror() attends une chaine de caractère en paramètre.

  3. #3
    Membre éclairé Avatar de sorry60
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    802
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 802
    Par défaut
    Citation Envoyé par crocodilex
    La fonction perror() attends une chaine de caractère en paramètre.
    Oui j'ai mis un exemple rapide, dans mon code c'est :


  4. #4
    Membre émérite Avatar de crocodilex
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    697
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 697
    Par défaut
    Ceci :
    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
    #include <stdio.h>
     
    int main(void)
    {
        FILE *fp;
     
        fp = freopen("log.txt","w",stderr);
        fprintf(stderr,"Erreur\n");
        fflush(stderr);
        perror("fflush()");
     
        fclose(fp);
     
        return 0;
    }
    me donne ça dans le fichier log.txt :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Erreur
    fflush(): No error

  5. #5
    Membre éclairé Avatar de sorry60
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    802
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 802
    Par défaut
    Ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    FILE *log;
    ...
    log = freopen ("log.txt","w",stderr); 
    ...
    ...
    while ( connect(sock,(struct sockaddr *) &addrServ,sizeof(addrServ)) == SOCKET_ERROR ){
            fprintf(stderr,"Pas de connexion avec le serveur...\n");
    	fflush(stderr);
    	perror("Connect()");
    	sleep(60000);
    	closesocket(sock);
    	sock = socket(AF_INET, SOCK_STREAM, 0);
    }
    Me donne dans log.txt :

    Pas de connexion avec le serveur...
    Pas de connexion avec le serveur...
    Pas de connexion avec le serveur...
    Pas de connexion avec le serveur...
    Edit: projet win32 GUI sous devcpp

  6. #6
    Membre émérite Avatar de crocodilex
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    697
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 697
    Par défaut
    Essayes de faire un fflush à chaque écriture dans stderr, c'est a dire meme apres l'appel de la fonction perror()...

  7. #7
    Membre éclairé Avatar de sorry60
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    802
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 802
    Par défaut
    Citation Envoyé par crocodilex
    Essayes de faire un fflush à chaque écriture dans stderr, c'est a dire meme apres l'appel de la fonction perror()...
    Déjà essayé, ça ne change rien

  8. #8
    Membre émérite Avatar de crocodilex
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    697
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 697
    Par défaut
    Juste une remarque sur ton code, j'espère que tu es conscient que l'appel de perror doit se faire juste après l'appel de la fonction qui est sensé échouer.
    Donc dans ton cas, si tu soupçonnes la fonction connect(), perror doit etre appelée juste après.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    if (connect(.......) != 0)
    {
        perror("connect()");
    }
    else
    {
         /* pas d'erreur */
         [suite du code]
    }

  9. #9
    Membre éclairé Avatar de sorry60
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    802
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 802
    Par défaut
    Oui en effet j'avais mis le fprintf() avant perror().
    Mais meme en les inversant perror() n'ecrit pas dans le fichier

  10. #10
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par sorry60
    Je n'arrive pas à rediriger perror() vers un fichier texte.
    Essaye ça et dit moi ce qu'il y a dans le fichier.
    Précise quel est ton système et ton compilateur.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    #include <stdio.h>
    #include <errno.h>
    #include <string.h>
     
    int main (void)
    {
       freopen ("err.txt", "w", stderr);
       perror ("test by perror()");
       fprintf (stderr, "test by fprintf() : %s\n", strerror(errno));
       return 0;
    }

  11. #11
    Membre éclairé Avatar de sorry60
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    802
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 802
    Par défaut
    Citation Envoyé par Emmanuel Delahaye
    Essaye ça et dit moi ce qu'il y a dans le fichier.
    Précise quel est ton système et ton compilateur.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    #include <stdio.h>
    #include <errno.h>
    #include <string.h>
     
    int main (void)
    {
       freopen ("err.txt", "w", stderr);
       perror ("test by perror()");
       fprintf (stderr, "test by fprintf() : %s\n", strerror(errno));
       return 0;
    }
    Ca donne :

    test by fprintf() : Bad file descriptor
    Comme précisé plus haut, projet win32 GUI sous devcpp.

  12. #12
    Membre émérite Avatar de crocodilex
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    697
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 697
    Par défaut
    C'est bizarre tout ça.
    Peux tu essayer le petit exemple (celui d'Emmanuel ou le mien) en mode console et non pas en mode "win32 Gui".

  13. #13
    Membre éclairé Avatar de sorry60
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    802
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 802
    Par défaut
    Citation Envoyé par crocodilex
    C'est bizarre tout ça.
    Peux tu essayer le petit exemple (celui d'Emmanuel ou le mien) en mode console et non pas en mode "win32 Gui".
    En projet console ça marche bien.

    test by perror(): No error
    test by fprintf() : No error
    Mais pourquoi pas en win32 gui ?

  14. #14
    Membre émérite Avatar de crocodilex
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    697
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 697
    Par défaut
    Citation Envoyé par sorry60
    En projet console ça marche bien.



    Mais pourquoi pas en win32 gui ?
    On dirait une histoire de jeu de caractère étendue......

    Un début de réponse ici : http://www.open-std.org/jtc1/sc22/wg...ocs/dr_322.htm

  15. #15
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    À mon avis, ce doit plutôt être un problème de perror() qui n'est pas lié à stderr dans un projet GUI...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. Rediriger le résultat d'un code java dans un fichier texte
    Par ysahel dans le forum Général Java
    Réponses: 9
    Dernier message: 27/03/2009, 14h57
  2. Réponses: 2
    Dernier message: 02/03/2004, 19h38
  3. Réponses: 3
    Dernier message: 22/02/2004, 20h09
  4. [LG]rechercher dans un fichier texte
    Par BadFox dans le forum Langage
    Réponses: 11
    Dernier message: 01/12/2003, 15h57
  5. recherche de doublons dans un fichier texte
    Par portu dans le forum Algorithmes et structures de données
    Réponses: 3
    Dernier message: 07/10/2003, 14h13

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