Merge remote-tracking branch 'origin/ui.c' into ui.c

# Conflicts:
#	src/ui.c
ui.c
Jürgen Büchel 2024-12-14 21:24:24 +01:00
commit 62f9e676a0
1 changed files with 106 additions and 65 deletions

153
src/ui.c
View File

@ -8,36 +8,103 @@
#include <stdio.h>
#include <stdlib.h>
#include "ui.h"
#include <assert.h>
#include "planner.h"
#include "iCal.h"
#include "db.h"
#include "llist.h"
void dump_buffer(FILE *fp){
int ch;
while((ch = fgetc(fp)) != EOF && ch != '\n');
}
void insertTask(task_ptr newtask)
{
task_ptr TaskPointer;
if (firsttask == NULL){
firsttask = newtask;
newtask->nextTask ;
}
else {
TaskPointer = firsttask;
while(TaskPointer->nextTask!=NULL)
{
TaskPointer = TaskPointer->nextTask;
}
TaskPointer->nextTask = newtask;
newtask ->nextTask;
}
}
void newTask (void)
{
task_ptr new = malloc(sizeof(task_1));
if (new == NULL){
printf("Die Liste ist leer?!\n");
}
printf(" Neues Fach eigeben: ");
if(scanf("%d", &newTask)!=1)
{
dump_buffer(stdin);
printf("Fehlerhafte eingabe\n");
free(new);
return;
}
dump_buffer (stdin);
insertTask(new);
}
void inserttime(time_ptr newtime)
{
time_ptr TimePointer;
if (firsttime == NULL){
firsttime = newtime;
newtime->nextTime =NULL;
}
else {
TimePointer = firsttime;
while(TimePointer->nextTime!=NULL)
{
TimePointer = TimePointer->nextTime;
}
TimePointer->nextTime = newtime;
newtime ->nextTime = NULL;
}
}
void newTime(void)
{
time_ptr newtime = malloc(sizeof(task_1));
if (newtime == NULL){
printf("Die Liste ist leer?!\n");
}
printf(" Neue Zeit eingeben: ");
if(scanf("%d",&newTime)!=1)
{
dump_buffer(stdin);
printf("Fehlerhafte eingabe\n");
free(newtime);
return;
}
dump_buffer (stdin);
inserttime(newtime);
}
void tasklisting(void){
task_ptr TaskPointer = firsttask;
printf("Erfasste Fächer:\n");
while(TaskPointer!=NULL)
printf("\t->%d\n", TaskPointer->name);
TaskPointer = TaskPointer->nextTask;
}
void getlink (void)
{
}
int main(void)
{
char taskname;
int taskcreation_date;
int taskdeadline_date;
int taskpriority;
int taskspare;
Task *task = newTask(taskname, taskcreation_date, taskdeadline_date, taskpriority, taskspare);
{
// Insert task into the linked list
if (list == NULL) {
// If the list is empty, initialize it with the first task
list = llistNew(task, cmpTaskN);
}
else {
// Append the task to the linked list
llistAppend(list, task);
}
}
int time;
int choice = 0, i = 0;
do
{
@ -46,51 +113,25 @@ int main(void)
printf(" -3- Alle vorhandenen Faecher aufliesten\n");
printf(" -4- Kalenderlink ausgeben\n");
printf(" -5- Planer beenden\n");
printf(" Wähle die gewünschte Option aus\n");
if( scanf("%d", &choice) != 1){
printf("Falsche Eingabe\n");};
choice = 0;
dump_buffer(stdin);
while(( choice < 1 || choice > 5)){
switch (choice)
{
case 1:
{
printf(" Geben sie das gewünschte Fach ein: \n");
scanf("%c",taskname);
printf(" Wie viel Zeit bleibt ihnen:\n")
scanf("%c", taskdeadline_date);
printf(" Gib die Priorität des Faches an: \n");
scanf("%c", &taskpriority);
printf(" Wie viel Zeit habe Sie für dieses Fach: \n");
scanf("%c", taskspare);
}
case 2:
printf("Geben Sie die zur verfuegung stehende Zeit für die Fächer an: \n");
scanf("%c", &taskspare);
case 3: if( task == NULL){
case 1: newTask();break;
case 2: newTime();break;
case 3: if( firsttask == NULL){
printf("Die Liste ist leer");
}
else{
while (task != NULL)
{
printf("Faecher %d: \n", llistAppend(task));
}
tasklisting();
}break;
// case 4: iCAl();break;
case 4: iCAl();break;
}
}while (choice !=5);
return EXIT_SUCCESS;
}
}