Problème avec la fonction fseek

Vikeo Messages postés 3 Date d'inscription dimanche 9 janvier 2011 Statut Membre Dernière intervention 4 juillet 2011 - 4 juil. 2011 à 00:13
cs_patatalo Messages postés 1466 Date d'inscription vendredi 2 janvier 2004 Statut Modérateur Dernière intervention 14 février 2014 - 4 juil. 2011 à 06:16
Bonjour à tous,

Je me résouds à poster ce message car je ne trouve décidemment pas la solution à mon problème, je vous explique :

Lorsque l'on souhaite sauvegarder une map, je demande à l'utilisateur qu'il tape le nom de celle-ci, ce nom se retrouve dans le tableau de caractères nomfichier[181]. J'envois ce même tableau a une fonction enregistrement qui en plus de sauvegarder la map, ajoute son nom dans un fichier binaire (que je nomme listing.txt). Je souhaite modifier ce listing à chaque nouvel enregistrement de map, mais qu'il reste dans un ordre alphabétique. Lorsque l'on ajoute le nom d'une map qui doit se placer en toute fin du fichier, pas de problèmes, c'est lorsqu'on doit ajouter ce nom en plein milieu que ça part en vrille. J'ai, d'après l'onglet Variables Locales de Visual Studio 2010, constaté que la fonction fseek pose problème.
En effet, lorsque je fais ceci : fseek(pfich, -181*sizeof(char), SEEK_CUR); il ne déplace pas le pointeur de 181 caractères vers l'arrière mais se repositionne au début.
J'utilise aussi la bibliothèque SDL, je ne sais pas si ça pourrait créer des problèmes.
Voici le code en simplifié :

void enregistrement_fichier(char nomfichier[])
{
FILE *pfich;

int pause, choix, positionfich;
char chemin[500], nomfichlu[181];

pfich = fopen("maps/listing.txt", "rb");
if (pfich == NULL) {
pfich = fopen("maps/listing.txt", "w+b");
fwrite(nomfichier,sizeof(char),181,pfich);
}
        else {
fread(nomfichlu,sizeof(char),181,pfich);
while ((!(feof(pfich)))&&(strcmp(nomfichlu, nomfichier) < 0))
fread(nomfichlu,sizeof(char),181,pfich);
if (!(feof(pfich))) {
choix = fseek(pfich,-181*sizeof(char),SEEK_CUR);



if (strcmp(nomfichier, nomfichlu) != 0) {
fwrite(nomfichier,sizeof(char),181,pfich);
strcpy(nomfichier, nomfichlu);
fread(nomfichlu,sizeof(char),181,pfich);
while (!(feof(pfich))) {
choix = fseek(pfich,-181*sizeof(char),SEEK_CUR);
fwrite(nomfichier,sizeof(char),181,pfich);
strcpy(nomfichier, nomfichlu);
fread(nomfichlu,sizeof(char),181,pfich);
}
}
}
fwrite(nomfichier, sizeof(char), 181, pfich);
}
fclose(pfich);	
}

1 réponse

cs_patatalo Messages postés 1466 Date d'inscription vendredi 2 janvier 2004 Statut Modérateur Dernière intervention 14 février 2014 2
4 juil. 2011 à 06:16
salut,

Le truc qui me paraît bizarre dans ton code serait plutôt:
pfich = fopen("maps/listing.txt", "rb");

fichier ouvert en lecture seule, mais on a:
fwrite(nomfichier,sizeof(char),181,pfich);

algo simplifié:
#define rowsz 181*sizeof(char)
void enregistrement_fichier(char nomfichier[])
{
    FILE *pfich;
    int c = -1;
    char row[181];

    pfich = fopen("maps/listing.txt", "r+b");

    if (pfich == NULL) 
        pfich = fopen("maps/listing.txt", "w+b");

    if (pfich)
    {
        while ((c<0) && (fread(row, rowsz,1,pfich)>0))
            c = strcmp(row, nomfichier);

        if (c > 0)
            fseek(pfich, -1*rowsz, SEEK_CUR);

        if (c)
            fwrite(nomfichier, rowsz, 1, pfich);
        // else
        //     nom map déjà existant. 

        fclose(pfich);
    }
}
0
Rejoignez-nous