kommentiert

This commit is contained in:
Harun Faizi 2025-11-02 22:50:25 +01:00
parent 16ab4a59ab
commit 5d13734da6

41
input.c
View File

@ -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 <string.h>
#include <ctype.h>
@ -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