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 :

tester la fin d un fichier


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 83
    Par défaut tester la fin d un fichier
    bonjour,

    j ai besoin de lire des donnee se trouvant dans un fichier .obj se presentnt de cette maniere :


    # XSI Wavefront OBJ Export v3.0
    # File Created: Wed Nov 7 10:49:04 2007
    # XSI Version: 6.02.2007.0613
    o 6.02.2007.0613
    mtllib aircraft.mtl


    # Hierarchy (from self to top father)
    g cylinder

    #begin 62 vertices
    v 0.000000 0.000000 -3.931000
    v 0.000000 -0.000000 3.931000
    v -0.241153 0.000000 -3.931000
    v -0.482306 0.000000 -3.931000
    v -0.482306 -0.000000 3.931000
    v -0.241153 -0.000000 3.931000
    v -0.170521 -0.170521 -3.931000
    v -0.341042 -0.341042 -3.931000 etc...

    #begin 265 normals
    n 535 153 153
    etc...

    #begin 158 Faces
    f 1 2 3
    etc...
    en faisant :



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
            objfile = fopen("monFichier.obj", "r");
    	if (objfile == NULL) {
    		printf("error opening .OBJ file\n");
    		exit(EXIT_FAILURE);
    	}
     
    	/* read  material  (.mtl )  */
     
    	char FileMTL[12];
    	fseek(objfile, 127 * sizeof(char), SEEK_SET);
    	fscanf(objfile,"%s ", FileMTL);
    	printf(" materials file : %s \n", FileMTL);
    je peu afficher le point mtl : "aircraft.mtl"
    mai ensuite je n'arrive pas a reprendre la lecture de mon fichier sans "erreurs de segmentation"


    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
     
    	while ( fgetc(objfile)!=EOF ){
    		nbVertices=0;
    		nbNormals=0;
    		nbFaces=0;
     
    		fscanf(objfile,"#begin %d vertices", &nbVertices);
    		fscanf(objfile,"#begin %d normals", &nbNormals);	
    		fscanf(objfile,"#begin %d faces", &nbFaces);
     
    		if(nbVertices !=0){
    			printf(" nb vertices : %d \n", nbVertices);
    			*vertices = malloc(nbVertices * sizeof(*vertices));
    			/* read vertices*/
    			for (row = 0; row < nbVertices; row++){
    						fscanf(objfile,"v %f %f %f",  &vertices[row][0], &vertices[row][1],  &vertices[row][2]);
    			}
     
    /*print out vertices to check */
    			for (row = 0; row < nbVertices; row++){
    				for (col = 0; col < 3; col++){
    					printf("%f\t", vertices[row][col]);
    				}
    				printf("\n");
    			}
    		}
     
    		else if(nbNormals !=0){
    			printf(" nb normals : %d \n", nbNormals);
     
    			*normals = malloc(nbNormals * sizeof(*normals));
     
    			/*read NormalsLists */
    			for (row = 0; row < nbNormals; row++){
    				fscanf(objfile, "vn %f %f %f",  &normals[row][0], &normals[row][1],  &normals[row][2]);
     
    			}
     
    			/*print out normalslist to check */
    			for (row = 0; row < nbNormals; row++){
    				for (col = 0; col < 2; col++){
    					printf("%f\t", normals[row][col]);
    				}
    				printf("\n");
    			}
    		}
     
    		else if(nbFaces !=0){
    			*facelist = malloc(nbFaces * sizeof(*facelist));
    			*material = malloc(nbFaces * sizeof(*material));
     
    			/* read facelist*/
    			/* f vector1//normal1 vector2//normal2 vector3//normal3*/
    			for (row = 0; row < nbFaces; row++){
    				fscanf(objfile,"usemtl %s", &material[row]);
     
    			fscanf(objfile,"f %d//%d %d//%d %d//%d", &facelist[row][0], &facelist[row][3], &facelist[row][1], &facelist[row][4], 	&facelist[row][2], &facelist[row][5]);
    				// facelists[no of face][data for face]
    				// data are : [vert1 | vert2 | vert3 | norm1 | norm2 | norm3]
    			}
     
    			/*print out facelist to check */
    			for (row = 0; row < 6; row++){
    				for (col = 0; col < 4; col++)
    					printf("%d\t", facelist[row][col]);
    				printf("\n");
    			}
     
    		}

    ce dernier bout de code et sense lire les vertices /normals /Faces et les stockes dans des tableaux correspondants ...

    je pense que mon test de fin de fichier est mauvais (si je met while(1) la boucle infinie tourne indefiniement sans erreur de segmentation...)

    pouvez vous m'aider a comprendre ?



    avant d essayer de tester la fin du fichier j ai essayer de reprendre la lecture de mes donnee grace a :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     
    fseek(objfile, 187 * sizeof(char), SEEK_SET); // 187 est la position du  prochain int que je veu lire dans le fichier
    fscanf(objfile,"#begin %d vertices", &nbVertices);
    sans succes :: erreur de segmentation a l execution

  2. #2
    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 guian Voir le message
    j ai besoin de lire des donnee se trouvant dans un fichier .obj se presentnt de cette maniere :
    Chaque fonction de lecture retourne un état qui indique si on rencontré une fin de lecture. Bien lire la doc de chaque fonction.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 83
    Par défaut
    oui tout a fait justement, peut tu m expliker poukoi "while( fgetc(objfile)!=EOF )" me renvoi une erreur de segmentation ? car je ne comprend pas

  4. #4
    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 guian Voir le message
    oui tout a fait justement, peut tu m expliker poukoi "while( fgetc(objfile)!=EOF )" me renvoi une erreur de segmentation ? car je ne comprend pas
    Es-tu certain qu'à ce moment, objfile est valide ?

    Ton code est en petits morceaux, il n'est pas compilable... J'essaye de recoller les bouts et de mettre des rustines, mais je ne suis pas censé fait de la rétro-ingéniérie...

    Ca donne ça :
    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
     
    #include <stdio.h>
    #include <stdlib.h>
     
    typedef float Tvertexf[3];
    typedef int Tvertexi[3];
    typedef char Tmaterial;
     
    int main (void)
    {
       FILE *objfile = fopen ("monFichier.obj", "r");
       if (objfile == NULL)
       {
          printf ("error opening .OBJ file\n");
          exit (EXIT_FAILURE);
       }
     
       /* read  material  (.mtl )  */
       {
          char FileMTL[12];
          fseek (objfile, 127 * sizeof (char), SEEK_SET);
          fscanf (objfile, "%s ", FileMTL);
          printf (" materials file : %s \n", FileMTL);
     
          while (fgetc (objfile) != EOF)
          {
             int nbVertices = 0;
             int nbNormals = 0;
             int nbFaces = 0;
     
             fscanf (objfile, "#begin %d vertices", &nbVertices);
             fscanf (objfile, "#begin %d normals", &nbNormals);
             fscanf (objfile, "#begin %d faces", &nbFaces);
     
             if (nbVertices != 0)
             {
                printf (" nb vertices : %d \n", nbVertices);
                Tvertexf *vertices = malloc (nbVertices * sizeof (*vertices));
                /* read vertices */
                {
                   int row;
                   for (row = 0; row < nbVertices; row++)
                   {
                      fscanf (objfile, "v %f %f %f", &vertices[row][0],
                              &vertices[row][1], &vertices[row][2]);
                   }
                }
    /*print out vertices to check */
                {
                   int row;
                   for (row = 0; row < nbVertices; row++)
                   {
                      int col;
                      for (col = 0; col < 3; col++)
                      {
                         printf ("%f\t", vertices[row][col]);
                      }
                      printf ("\n");
                   }
                }
             }
             else if (nbNormals != 0)
             {
                printf (" nb normals : %d \n", nbNormals);
                Tvertexf *normals = malloc (nbNormals * sizeof (*normals));
                /*read NormalsLists */
                {
                   int row;
                   for (row = 0; row < nbNormals; row++)
                   {
                      fscanf (objfile, "vn %f %f %f", &normals[row][0],
                              &normals[row][1], &normals[row][2]);
                   }
                }
                /*print out normalslist to check */
                {
                   int row;
                   for (row = 0; row < nbNormals; row++)
                   {
                      int col;
                      for (col = 0; col < 2; col++)
                      {
                         printf ("%f\t", normals[row][col]);
                      }
                      printf ("\n");
                   }
                }
             }
             else if (nbFaces != 0)
             {
                Tvertexi *facelist = malloc (nbFaces * sizeof (*facelist));
                Tmaterial *material = malloc (nbFaces * sizeof (*material));
     
                /* read facelist */
                /* f vector1//normal1 vector2//normal2 vector3//normal3 */
                {
                   int row;
                   for (row = 0; row < nbFaces; row++)
                   {
                      fscanf (objfile, "usemtl %s", &material[row]);
     
                      fscanf (objfile, "f %d//%d %d//%d %d//%d",
                              &facelist[row][0], &facelist[row][3],
                              &facelist[row][1], &facelist[row][4],
                              &facelist[row][2], &facelist[row][5]);
                      // facelists[no of face][data for face]
                      // data are : [vert1 | vert2 | vert3 | norm1 | norm2 | norm3]
                   }
                }
                /*print out facelist to check */
                {
                   int row;
                   for (row = 0; row < 6; row++)
                   {
                      int col;
                      for (col = 0; col < 4; col++)
                         printf ("%d\t", facelist[row][col]);
                      printf ("\n");
                   }
                }
             }
     
          }
       }
       return 0;
    }
    J'aurais du faire archéologue... En tous cas, avec le fichier que tu m'as donné, ça fonctionne (pas de plantage), à part évidemment que rien n'est libéré...

Discussions similaires

  1. [Débutant] comment tester la fin d'un fichier Excel ?
    Par xingjing910 dans le forum VB.NET
    Réponses: 1
    Dernier message: 20/06/2012, 15h55
  2. [Débutant] Tester la fin d'écriture sur un fichier
    Par SmileSoft dans le forum MATLAB
    Réponses: 3
    Dernier message: 26/05/2011, 13h42
  3. tester la fin d'un fichier
    Par guian dans le forum C
    Réponses: 5
    Dernier message: 14/11/2007, 10h17
  4. tester la fin d'un fichier
    Par guian dans le forum C#
    Réponses: 1
    Dernier message: 13/11/2007, 15h16
  5. Comment tester la fin d'un fichier ?
    Par Teddy dans le forum Delphi
    Réponses: 3
    Dernier message: 25/05/2007, 08h22

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