diff --git a/input.c b/input.c index ad4907b..4008b96 100644 --- a/input.c +++ b/input.c @@ -1,4 +1,4 @@ -//erstellt von Harun Faizi am 01.11.2025 +//erstellt von Harun Faizi am 01.11.2025; Informatik 2 Praktikum; Projekt 1 #include "input.h" #include #include @@ -20,32 +20,46 @@ int readWords(FILE *file, char words[][MAX_WORD_LEN], unsigned int maxWordCount) { //Gibt die Anzahl der eingelesen Wörter zurück (wordCount), für main wie viel gelesen wurde //FILE *file: Zeiger auf Datei --> FILE komplexes Objekt, müssen mit Adresse arbeiten - //Wort = String = Array von Zeichen (char) --> Zeilen: Wörteranzahl und Spalten: Buchstaben der Wörter - //wie viele Wörter max in Array geschrieben werden dürfen + //word[][...]: Wort = String = Array von Zeichen (char) --> Zeilen: Wörteranzahl und Spalten: Buchstaben der Wörter + //maxWordCount: wie viele Wörter max in Array geschrieben werden dürfen if (file == 0) return 0; //Sicherheitsprüfung - char line[MAX_LINE_LEN]; // Puffer für eine Zeile aus Datei + char line[MAX_LINE_LEN]; // Puffer für eine Zeile aus Datei --> Wörter später mit strtok() aus der Zeile extrahieren unsigned int wordCount = 0; // zählt wie viele Wörter gefunden wurden //Lese Datei Zeile für Zeile - while(fgets(line, sizeof(line), file) != NULL) + while(fgets(line, sizeof(line), file) != NULL) //liest Zeile für Zeile { + // fgets: liest komplette Zeile aus Datei + // fgets(Zielfeld, maximaleLänge, DateiZeiger); + // ==> "Lies aus Datei file bis 1024 Zeichen oder bis Zeilenumbruch \n kommt und speichere das Erg. in line" + // fgets gibt NULL zurück wenn Dateiende (EOF) erreicht ist + // fgets hängt IMMER automatisch \0 ans Ende des gelesen Textes + // Zerlege die Datei in einzelne Wörter char *token = strtok(line, ".,;\n\t"); + //strtok(): "Zerlege ein String in einzelne Teile (Wörter) nach bestimmten Trennzeichen + //strtok(): ersetzt Trennzeichen mit \0, merkt sich wo aufgehört hat und macht dann weiter + //char * token: Zeiger auf ein Zeichen (Anfang eines Strings) + + //"Solange es noch ein Wort gibt UND Speicherlimit noch nicht erreicht wurde, mach weiter" while (token != NULL && wordCount < maxWordCount) { //aktuelles Wort in Array kopieren - strncpy(words[wordCount], token, MAX_WORD_LEN -1); - words[wordCount][MAX_WORD_LEN -1] = '\0'; + strncpy(words[wordCount], token, MAX_WORD_LEN -1);//Kopiert Inhalt von token (aktuelles Wort) in das Array words + //strcpy(Ziel, Quelle, maximaleAnzahl); - wordCount++; - token = strtok(NULL, ",;\n"); + words[wordCount][MAX_WORD_LEN -1] = '\0';//jedes Wort im array endet mit \0 + + + wordCount++; //Wort gespeichert, zähle eins hoch + token = strtok(NULL, ",;\n");// sucht nächstes Wort ab Stelle, wo es aufgehört hat zuletzt } - // Wenn max Wortzahl erreicht ist abbrechen! + // Wenn max Wortzahl erreicht ist abbrechen if (wordCount >= maxWordCount) break; } @@ -53,6 +67,7 @@ int readWords(FILE *file, char words[][MAX_WORD_LEN], unsigned int maxWordCount) return wordCount; } - - - +/* Arrays im Überblick: +line[]: eine Zeile aus der Datei +words[][]: alle Wörter einzelnd gespeichert +token: Zeiger auf das aktuelle Wort