X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=parser.c;h=bad287aa2a95a06a04d30d19050891d94b61f73e;hb=b93f9808ed43d0b1ef875aaaa4047a9ce8123eda;hp=89c1ec0ccdb45aa69f6fedf3c6eeaac1c7d6d3b4;hpb=afa94c9493bdb91807c1dc2b4e1ffddbe2df1fd6;p=taskasaur.git diff --git a/parser.c b/parser.c index 89c1ec0..bad287a 100644 --- a/parser.c +++ b/parser.c @@ -147,8 +147,8 @@ enter_todoitem(State* state, char* item_name) new_todoitem = malloc(sizeof(TodoItem)); new_todoitem->item_name = item_name; - new_todoitem->description = NULL; - new_todoitem->due = NULL; + new_todoitem->description = strdup(""); + new_todoitem->due = strdup(""); new_todoitem->subtask_list = malloc(0); new_todoitem->subtask_count = 0; @@ -181,7 +181,7 @@ set_description(State* state, char* description) void set_due(State* state, char* due) { - + state->cur_todoitem->due = due; } void @@ -281,7 +281,7 @@ leave_span(MD_SPANTYPE type, void* detail, void* userdata) switch (type) { case MD_SPAN_STRONG: - printf("date, %s\n", state->last_block_text); + set_due(state, state->last_block_text); break; } return 0; @@ -381,3 +381,33 @@ log_todo(Board* board) } } } + +int +free_board(Board* board) +{ // all the fields are being leaked rn + + for (int i = 0; i < board->todolist_count; i++) { + TodoList* cur_todolist = board->todolist_list[i]; + + /* free(cur_todolist->list_name); */ + + for (int j = 0; j < cur_todolist->item_count; j++) { + TodoItem* cur_todoitem = cur_todolist->item_list[j]; + + /* free(cur_todoitem->item_name); */ + /* free(cur_todoitem->description); */ + /* free(cur_todoitem->due); */ + + /* free subtask later too */ + + free(cur_todoitem); + } + + free(cur_todolist); + } + + /* free(board->board_name); */ + free(board); + + return 0; +}