Merge remote-tracking branch 'origin/master'
commit
8cea008459
194
src/ui.c
194
src/ui.c
|
@ -8,122 +8,33 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include "ui.h"
|
#include "ui.h"
|
||||||
#include "planner.h"
|
#include <assert.h>
|
||||||
#include "iCal.h"
|
|
||||||
#include "db.h"
|
#include "db.h"
|
||||||
|
#include "llist.h"
|
||||||
|
|
||||||
typedef struct task {
|
|
||||||
char name;
|
|
||||||
int priority;
|
|
||||||
struct task *nextTask;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct task task_1;
|
|
||||||
typedef struct task* task_ptr;
|
|
||||||
task_ptr firsttask = NULL;
|
|
||||||
|
|
||||||
typedef struct time {
|
|
||||||
int time;
|
|
||||||
struct time *nextTime;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct time time_1;
|
|
||||||
typedef struct time* time_ptr;
|
|
||||||
time_ptr firsttime = NULL;
|
|
||||||
|
|
||||||
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)
|
int main(void)
|
||||||
{
|
{
|
||||||
|
char taskname ;
|
||||||
|
int taskcreation_date = 0;
|
||||||
|
int taskdeadline_date = 0;
|
||||||
|
int taskpriority = 0;
|
||||||
|
int taskspare = 0;
|
||||||
|
llist *list = NULL;
|
||||||
|
|
||||||
|
Task *task = newTask(taskname, taskcreation_date, taskdeadline_date, taskpriority, taskspare);
|
||||||
|
if (task == NULL) {
|
||||||
|
printf("Fehler beim Erstellen der Aufgabe.\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (list == NULL) {
|
||||||
|
list = llistNew(task, cmpTaskN);
|
||||||
|
} else {
|
||||||
|
list = llistAppend(list, task); // Rückgabewert verwenden
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int choice = 0, i = 0;
|
int choice = 0, i = 0;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
@ -132,25 +43,70 @@ int main(void)
|
||||||
printf(" -3- Alle vorhandenen Faecher aufliesten\n");
|
printf(" -3- Alle vorhandenen Faecher aufliesten\n");
|
||||||
printf(" -4- Kalenderlink ausgeben\n");
|
printf(" -4- Kalenderlink ausgeben\n");
|
||||||
printf(" -5- Planer beenden\n");
|
printf(" -5- Planer beenden\n");
|
||||||
|
printf(" Wähle die gewünschte Option aus\n");
|
||||||
if( scanf("%d", &choice) != 1){
|
if( scanf("%d", &choice) != 1){
|
||||||
printf("Falsche Eingabe\n");};
|
printf("Falsche Eingabe\n");};
|
||||||
choice = 0;
|
choice = 0;
|
||||||
dump_buffer(stdin);
|
|
||||||
|
|
||||||
|
while(( choice < 1 || choice > 5)){
|
||||||
switch (choice)
|
switch (choice)
|
||||||
{
|
{
|
||||||
case 1: newTask();break;
|
case 1:
|
||||||
case 2: newTime();break;
|
{
|
||||||
case 3: if( firsttask == NULL){
|
printf(" Geben sie das gewünschte Fach ein: \n");
|
||||||
|
if (scanf("%255s", taskname) != 1) {
|
||||||
|
printf("Ungültige Eingabe für den Namen.\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
printf(" Wie viel Zeit bleibt ihnen:\n");
|
||||||
|
if (scanf("%d", &taskdeadline_date) != 1) {
|
||||||
|
printf("Ungültige Eingabe.\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
printf(" Gib die Priorität des Faches an: \n");
|
||||||
|
if (scanf("%d", &taskpriority) != 1) {
|
||||||
|
printf("Ungültige Eingabe.\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
printf(" Wie viel Zeit habe Sie für dieses Fach: \n");
|
||||||
|
if (scanf("%d", &taskspare) != 1) {
|
||||||
|
printf("Ungültige Eingabe.\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
printf("Geben Sie die zur verfuegung stehende Zeit für die Fächer an: \n");
|
||||||
|
scanf("%c", &taskspare);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 3: if( task == NULL){
|
||||||
printf("Die Liste ist leer");
|
printf("Die Liste ist leer");
|
||||||
}
|
}
|
||||||
else{
|
else
|
||||||
tasklisting();
|
{
|
||||||
}break;
|
llist *iterator = list;
|
||||||
case 4: iCAl();break;
|
while (iterator != NULL) {
|
||||||
|
Task *currentTask = (Task *)(iterator->data); // Cast zu Task
|
||||||
|
printf("Fach: %s, Deadline: %ld, Priorität: %d\n",
|
||||||
|
currentTask->name, currentTask->deadline, currentTask->priority);
|
||||||
|
iterator = iterator->next; // Gehe zum nächsten Listenelement
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
// case 4: iCAl();break;
|
||||||
}
|
}
|
||||||
}while (choice !=5);
|
}while (choice !=5);
|
||||||
return EXIT_SUCCESS;
|
return EXIT_SUCCESS;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue