Compare commits
9 Commits
Author | SHA1 | Date |
---|---|---|
ketrptr | 6bf5d08b9b | |
ketrptr | 7f487016dc | |
ketrptr | cd7094263a | |
ketrptr | cb6571a0d6 | |
ketrptr | bc53d5bcf3 | |
ketrptr | c616b98589 | |
ketrptr | 0922b8d6b8 | |
ketrptr | bcb08c6da9 | |
ketrptr | e5b5fd3b50 |
|
@ -1,6 +1,8 @@
|
|||
testing
|
||||
debugOut
|
||||
.idea
|
||||
.run
|
||||
.vscode
|
||||
# ---> C
|
||||
# Prerequisites
|
||||
*.d
|
||||
|
|
|
@ -1,7 +0,0 @@
|
|||
<component name="ProjectRunConfigurationManager">
|
||||
<configuration default="false" name="StudyPlanner" type="CMakeRunConfiguration" factoryName="Application" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" EMULATE_TERMINAL="false" PASS_PARENT_ENVS_2="true" RUN_PATH="$PROJECT_DIR$/Makefile" EXPLICIT_BUILD_TARGET_NAME="all">
|
||||
<method v="2">
|
||||
<option name="com.jetbrains.cidr.execution.CidrBuildBeforeRunTaskProvider$BuildBeforeRunTask" enabled="true" />
|
||||
</method>
|
||||
</configuration>
|
||||
</component>
|
15
Makefile
15
Makefile
|
@ -12,10 +12,17 @@ CALF=src/iCal.c src/iCal.h
|
|||
LLST=src/llist.c src/llist.h
|
||||
CONFIG=src/config.h #config file
|
||||
|
||||
ALLF=$(UIF) $(PLF) $(DBF) $(LLST)
|
||||
|
||||
all: debug
|
||||
#targets
|
||||
debug: test ui planner db iCal llist
|
||||
gcc test.o ui.o planner.o db.o iCal.o llist.o -o debugOut
|
||||
gcc -DDEBUG test.o ui.o planner.o db.o iCal.o llist.o -o debugOut
|
||||
|
||||
|
||||
# release: $(ALLF)
|
||||
# gcc -DRELEASE -fPIC -shared -o $(ALLF)
|
||||
|
||||
|
||||
# config: $(CONFIG)
|
||||
llist: $(LLST)
|
||||
|
@ -25,7 +32,7 @@ test: src/test.c
|
|||
iCal: $(CALF)
|
||||
gcc -c $(CFLAGS) $(CALF)
|
||||
ui: $(UIF)
|
||||
gcc -c $(CFLAGS) $(UIF)
|
||||
gcc -DDEBUG -c $(CFLAGS) $(UIF)
|
||||
planner: $(PLF)
|
||||
gcc -c $(CFLAGS) $(PLF)
|
||||
db: $(DBF)
|
||||
|
@ -33,10 +40,10 @@ db: $(DBF)
|
|||
|
||||
|
||||
edit:
|
||||
nvim $(PLF) Makefile $(LLST) src/test.c
|
||||
nvim $(PLF) Makefile $(ALLF)
|
||||
|
||||
clean:
|
||||
rm -rf *.o debugOut src/*.gch *.csv *.ics
|
||||
rm -rf *.o debugOut src/*.gch *.csv *.ics *.so
|
||||
|
||||
|
||||
|
||||
|
|
10
README.md
10
README.md
|
@ -13,6 +13,16 @@
|
|||
|
||||
Time management optimisation tool.
|
||||
|
||||
# How to use
|
||||
|
||||
- to use program directly compile with
|
||||
make debug
|
||||
. this creates executable binary.
|
||||
|
||||
- to integrate in other software use:
|
||||
make release
|
||||
. This creates shared library. use StudyPlanner.h (untested)
|
||||
|
||||
# Procedure
|
||||
|
||||
## User input
|
||||
|
|
|
@ -0,0 +1,6 @@
|
|||
#ifndef SPLANNER
|
||||
#define SPLANNER
|
||||
|
||||
int StudyPlanner();
|
||||
|
||||
#endif // StudyPlanner
|
3
src/db.h
3
src/db.h
|
@ -3,7 +3,6 @@
|
|||
|
||||
#include "planner.h"
|
||||
|
||||
#endif
|
||||
|
||||
void write_linkedlist_to_csv(llist *head, const char *filename);
|
||||
llist *write_csv_to_llist(const char *filename);
|
||||
#endif
|
||||
|
|
124
src/planner.c
124
src/planner.c
|
@ -161,6 +161,14 @@ int cmpEvent(const void *a, const void *b) {
|
|||
return cmpTaskN(aa->task, bb->task);
|
||||
}
|
||||
|
||||
void resetPrio(Task **sortedPrio, int len) {
|
||||
for (int i = 0; i < len; i++) {
|
||||
if ((*sortedPrio)[i].priority < 0) // ignore past deadline
|
||||
continue;
|
||||
printf("incrementing prio!\n");
|
||||
(*sortedPrio)[i].priority += 10;
|
||||
}
|
||||
}
|
||||
llist *genPlan(llist *head, time_t timeAvail) {
|
||||
|
||||
// map llist to pointer arr & sort by priority
|
||||
|
@ -170,7 +178,7 @@ llist *genPlan(llist *head, time_t timeAvail) {
|
|||
printf("len: %d\n", lLen);
|
||||
llistPrintT(head);
|
||||
|
||||
// Task *sortedNames = calloc(lLen, sizeof(Task));
|
||||
time_t now = time(NULL);
|
||||
Task *sortedPrio = calloc(lLen, sizeof(Task));
|
||||
if (/*sortedNames == NULL ||*/ sortedPrio == NULL) {
|
||||
planLog("gen plan : calloc failed!!\n", true);
|
||||
|
@ -180,23 +188,16 @@ llist *genPlan(llist *head, time_t timeAvail) {
|
|||
// add Tasks from llist to arr
|
||||
llist *c = head;
|
||||
for (int i = 0; c != NULL; i++) {
|
||||
// sortedNames[i] = *copyTask(c->data);
|
||||
// sortedPrio[i] = *copyTask(c->data);
|
||||
// sortedNames[i] = *(Task *)c->data;
|
||||
sortedPrio[i] = *(Task *)c->data;
|
||||
if (sortedPrio[i].deadline + 1 < now) {
|
||||
sortedPrio[i].priority = -1; // ignore past deadlines
|
||||
}
|
||||
c = c->next;
|
||||
}
|
||||
|
||||
// sort
|
||||
// qsort(sortedNames, lLen, sizeof(Task), cmpTaskN);
|
||||
qsort(sortedPrio, lLen, sizeof(Task), cmpTaskP);
|
||||
|
||||
// // test print
|
||||
// planLog("sortendName", 0);
|
||||
// for (int i = 0; i < lLen; i++) {
|
||||
// printTask(sortedNames + i);
|
||||
// }
|
||||
|
||||
planLog("sortendPrio", 0);
|
||||
for (int i = 0; i < lLen; i++) {
|
||||
printTask(sortedPrio + i);
|
||||
|
@ -205,16 +206,20 @@ llist *genPlan(llist *head, time_t timeAvail) {
|
|||
planLog("creating eventList", false);
|
||||
|
||||
// genertate plan based on priorities and available time
|
||||
time_t now = time(NULL);
|
||||
now = time(NULL);
|
||||
struct tm *lc = localtime(&now);
|
||||
llist *events_ll = llistNew(NULL, cmpEvent);
|
||||
if (events_ll == NULL) {
|
||||
exit(1);
|
||||
}
|
||||
// time_t avail = mktime(timeAvail);
|
||||
time_t start, end;
|
||||
// (mktime(lc) < mktime(timeAvail))
|
||||
do {
|
||||
if ((*sortedPrio).priority < 0) {
|
||||
continue;
|
||||
} else if ((*sortedPrio).priority == 0) {
|
||||
printf("All tasks have priority <0!!");
|
||||
resetPrio(&sortedPrio, lLen);
|
||||
}
|
||||
start = mktime(lc); // start now
|
||||
lc->tm_min += intervalLen;
|
||||
end = mktime(lc); //
|
||||
|
@ -225,9 +230,9 @@ llist *genPlan(llist *head, time_t timeAvail) {
|
|||
c = newEvent(tmp->data, start, end,
|
||||
0); // use elem with wighest priority
|
||||
}
|
||||
|
||||
llistAppend(events_ll, c);
|
||||
printEvent(c);
|
||||
// printEvent((Event *)((events_ll)->next)->data);
|
||||
|
||||
// decrement priority of first elem and resort list
|
||||
(*sortedPrio).priority -= 1;
|
||||
|
@ -237,29 +242,12 @@ llist *genPlan(llist *head, time_t timeAvail) {
|
|||
|
||||
} while (mktime(lc) < timeAvail);
|
||||
|
||||
// for (int i = 0; i < lLen; i++) {
|
||||
// time_t start = mktime(lc);
|
||||
//
|
||||
// printf("start:: %s\n", ctime(&start));
|
||||
// lc->tm_min += 45;
|
||||
// time_t end = mktime(lc);
|
||||
// printf("end:: %s\n", ctime(&end));
|
||||
//
|
||||
// Event *c = newEvent(sortedPrio + i, start, end, 0);
|
||||
// printEvent(c);
|
||||
// lc->tm_min += 15;
|
||||
// llistAppend(events_ll, c);
|
||||
// }
|
||||
//
|
||||
|
||||
// free empty head
|
||||
llist *tmp = events_ll;
|
||||
events_ll = events_ll->next;
|
||||
tmp->next = NULL;
|
||||
llistFreeE(tmp);
|
||||
printf("====EVENTSLL:\n");
|
||||
llistPrintE(events_ll);
|
||||
printf("====EVENTSLL:\n");
|
||||
// llistPrintE(events_ll);
|
||||
// update prioriteis in original llist
|
||||
for (int i = 0; i < lLen; i++) {
|
||||
llist *tmp = llistGet(head, sortedPrio + i);
|
||||
|
@ -270,77 +258,7 @@ llist *genPlan(llist *head, time_t timeAvail) {
|
|||
free(sortedPrio);
|
||||
|
||||
planLog("END GEN PLAN", 0);
|
||||
// llistFreeT(head);
|
||||
// send updated tasks to db for storage
|
||||
|
||||
return events_ll;
|
||||
}
|
||||
//
|
||||
// const char *iCalHeader = "BEGIN:VCALENDAR\r\n"
|
||||
// "VERSION:2.0\r\n"
|
||||
// "PRODID:-//hacksw/handcal//NONSGML v1.0//EN\r\n";
|
||||
// const char *iCalEvent = "BEGIN:VEVENT\r\n"
|
||||
// "UID:%s%d\r\n"
|
||||
// "DTSTAMP:%s\r\n"
|
||||
// "DTSTART:%s\r\n"
|
||||
// "DTEND:%s\r\n"
|
||||
// "SUMMARY:%s\r\n"
|
||||
// "END:VEVENT\r\n";
|
||||
//
|
||||
// int exportiCal(llist *events_ll) {
|
||||
//
|
||||
// llist *ev_ll = events_ll;
|
||||
//
|
||||
// llistPrintE(ev_ll);
|
||||
//
|
||||
// printf("%s", iCalHeader);
|
||||
//
|
||||
// time_t now = time(NULL);
|
||||
// struct tm lc;
|
||||
// localtime_r(&now, &lc);
|
||||
//
|
||||
// // gen filename & open for write
|
||||
// char nameBuf[32];
|
||||
// strftime(nameBuf, 32 - 12, "%F", &lc);
|
||||
// strcat(nameBuf, "dayplan.ics");
|
||||
// FILE *fp = fopen(nameBuf, "w");
|
||||
// if (fp == NULL) {
|
||||
// planLog("fopen failed!!", 1);
|
||||
// return 1;
|
||||
// }
|
||||
// // write iCal header to file
|
||||
// fprintf(fp, "%s", iCalHeader);
|
||||
//
|
||||
// // for every event in events_ll create VEVENT str and write to fp
|
||||
// int count = 0;
|
||||
// while (ev_ll != NULL) {
|
||||
// // gen iCal compatible time str
|
||||
// Event *current = ev_ll->data;
|
||||
// struct tm startlc;
|
||||
// struct tm endlc;
|
||||
// localtime_r(¤t->plannedStartTime, &startlc);
|
||||
// localtime_r(¤t->plannedEndTime, &endlc);
|
||||
// char timeStartBuf[17];
|
||||
// char timeEndBuf[17];
|
||||
// char timeStamp[17];
|
||||
// strftime(timeStamp, 17, "%Y%m%dT%k%M%SZ", &lc);
|
||||
// printf("%s\n", timeStamp);
|
||||
// strftime(timeStartBuf, 17, "%Y%m%dT%k%M%SZ", &startlc);
|
||||
// printf("%s\n", timeStartBuf);
|
||||
// strftime(timeEndBuf, 17, "%Y%m%dT%k%M%SZ", &endlc);
|
||||
// printf("%s\n", timeEndBuf);
|
||||
//
|
||||
// fprintf(fp, iCalEvent, current->task->name, count, timeStamp,
|
||||
// timeStartBuf,
|
||||
// timeEndBuf, current->task->name);
|
||||
// ev_ll = ev_ll->next;
|
||||
// count += 1;
|
||||
// }
|
||||
//
|
||||
// // after all events are written end cal with
|
||||
// // END:VCALENDAR
|
||||
// fprintf(fp, "END:VCALENDAR\r\n");
|
||||
// fclose(fp);
|
||||
//
|
||||
// return 0;
|
||||
// }
|
||||
|
|
15
src/ui.c
15
src/ui.c
|
@ -6,6 +6,7 @@
|
|||
*/
|
||||
#define _GNU_SOURCE
|
||||
#include "ui.h"
|
||||
#include "StudyPlanner.h"
|
||||
#include "db.h"
|
||||
#include "iCal.h"
|
||||
#include "llist.h"
|
||||
|
@ -20,9 +21,18 @@
|
|||
#define localtime_r(T, Tm) (_localtime64_s(Tm, T) ? NULL : Tm)
|
||||
#endif
|
||||
|
||||
const char *dbName = "db.csv";
|
||||
#define minutes(n) (60 * n)
|
||||
#define hours(n) (60 * minutes(n))
|
||||
#define days(n) (24 * hours(n))
|
||||
|
||||
const char *dbName = "db.csv";
|
||||
#define DEBUG
|
||||
#ifdef DEBUG
|
||||
int main(void) {
|
||||
#endif
|
||||
#ifdef RELEASE
|
||||
int StudyPlanner() {
|
||||
#endif
|
||||
int taskcreation_date = 0;
|
||||
int taskdeadline_date = 0;
|
||||
int taskpriority = 0;
|
||||
|
@ -84,8 +94,7 @@ int main(void) {
|
|||
// }
|
||||
|
||||
// create deadline timestamp
|
||||
lc.tm_yday += taskdeadline_date;
|
||||
time_t deadline = mktime(&lc);
|
||||
time_t deadline = now + days(taskdeadline_date);
|
||||
Task *newT = newTask(taskname, now, deadline, taskpriority, 0);
|
||||
if (listT == NULL) {
|
||||
listT = llistNew(newT, cmpTaskN);
|
||||
|
|
Loading…
Reference in New Issue