Je vais essayer d'analyser une ligne dans ce format:strtok() NULL de retour au milieu de l'analyse syntaxique
1: 2,3,4,5,6,7,8,9,10
si Im en utilisant la fonction strtok()
avec 2 délimiteurs et
,
(espace et virgule) Mais pour une raison quelconque, quand j'arriverai à 6, la fonction retournera NULL.
fileName = strtok(line, spaceToken);
fileName[strlen(fileName) - 1] = 0; //remove the ':'
...
//doing something with fileName
...
fileName = strtok(NULL, commaToken);
while (fileName != NULL) <-----THE PROBLEM
...
//doing something with fileName
fileName = strtok(NULL, commaToken);
}
Ainsi, lorsque le fichier sera 6
, je me NULL
.
Avec cette entrée:
file1: file2,file3,file4
Où je me file2
pour pourrais-le fileName
je reçois 'fil'
, et la prochaine itération sera NULL
.
Ceci est le code complet si elle est aider
#include <stdio.h>
#include <memory.h>
#define MAX_LINE_NUMBER 11
#define MAX_FILE_NAME_NUMER 255
#define MAX_FILES 10
//function declaration
void parseFile(char path[]);
int contain(char fileName[]);
int addToDependencieArray(char fileName[], int currentFileIndex);
enum COLOR
{
WHITE, GRAY, BLACK
};
typedef struct MyFile
{
char name[MAX_FILE_NAME_NUMER];
int neighbors[MAX_FILES];
int neighborsCounter;
enum COLOR myColor;
int predecessor;
} MyFile;
//global
MyFile gDependencies[MAX_FILES];
int gCurrentFilesWriten = 0;
int main(int argc, char *argv[])
{
parseFile(argv[1]);
puts("hello");
}
void parseFile(char path[])
{
FILE *fPointer = fopen(path, "r");
char line[MAX_LINE_NUMBER];
char spaceToken[2] = " ";
char commaToken[2] = ",";
char *fileName;
int currentFileIndex = 0;
int sourseFile = 0;
while (fgets(line, sizeof(line), fPointer))
{
fileName = strtok(line, spaceToken);
fileName[strlen(fileName) - 1] = 0; //remove the :
int sourse = contain(fileName);
if (sourse == -1) // isn't contains
{// to create function add.
currentFileIndex = addToDependencieArray(fileName, currentFileIndex);
sourseFile = currentFileIndex - 1;
}
else // contain
{
sourseFile = sourse;
}
fileName = strtok(NULL, commaToken);
while (fileName != NULL)
{
if (contain(fileName) == -1)
{
currentFileIndex = addToDependencieArray(fileName, currentFileIndex);
int neighborIndex = gDependencies[sourseFile].neighborsCounter;
gDependencies[sourseFile].neighbors[neighborIndex] = currentFileIndex - 1;
gDependencies[sourseFile].neighborsCounter++;
}
fileName = strtok(NULL, commaToken);
}
}
fclose(fPointer);
}
int contain(char fileName[])
{
int res = -1;
for (int i = 0; i < gCurrentFilesWriten; i++)
{
if (!strcmp(fileName, gDependencies[i].name))
{
return i;
}
else
{
i++;
}
}
return res;
}
int addToDependencieArray(char fileName[], int currentFileIndex)
{
strcpy(gDependencies[currentFileIndex].name, fileName);
gCurrentFilesWriten++;
gDependencies[currentFileIndex].neighborsCounter = 0;
currentFileIndex++;
return currentFileIndex;
}
'fileName [strlen (fileName) - 1] = 0; 'Note: strlen() peut retourner zéro. (et le nom de fichier pourrait même être NULL dans ce cas) – joop
Merci, mais je peux supposer qu'il n'y aura pas de ligne vide. – limitless
Pourquoi ne pas écrire un petit programme principal avec des données codées en dur au lieu de supposer que les choses sont "ok"? – PaulMcKenzie