X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=taskasaur.c;h=353ca5d891010c3df59cd0fb153b70ed7162cfc0;hb=afa94c9493bdb91807c1dc2b4e1ffddbe2df1fd6;hp=8eb2f89ebe7456274f527c0b06bd4c08d3af82b0;hpb=500e16bc4c9c43a8ef4ab65e6eb37ff3b0d3093c;p=taskasaur.git diff --git a/taskasaur.c b/taskasaur.c index 8eb2f89..353ca5d 100644 --- a/taskasaur.c +++ b/taskasaur.c @@ -5,6 +5,9 @@ #include "headers/utils.h" #include "config.h" +// this is temp +#define MENU_WIDTH 40 + typedef struct BoardMenu { Menu** menu_list; int menu_count; @@ -12,17 +15,22 @@ typedef struct BoardMenu { } BoardMenu; BoardMenu* create_board_menu(Board* board); +Board* boardmenu_to_board(BoardMenu* boardmenu); int set_selected_menu(BoardMenu* boardmenu, int index); MenuItem** todolist_to_menuitem(TodoItem** item_list, int list_length); Menu** make_menus(Board* board, int todolist_length); +int swap_menu(BoardMenu* boardmenu, int src_index, int dest_index); int main(int argc, char** argv) { + char* boardfile_name = "test_board.md"; + printf("%c]0;%s - %s%c", '\033', "taskasaur", boardfile_name, '\007'); // need to reset after program exits + /* read from todo file */ Board* board; - board = begin_parse("test_board.md"); + board = begin_parse(boardfile_name); /* log_todo(board); */ /* init curses */ @@ -71,9 +79,60 @@ main(int argc, char** argv) menu_driver(active_menu, MENU_MOVE_DOWN); break; case BINDING_MOVE_ITEM_LEFT: + if (boardmenu->selected-1 < 0) break; + { + Menu* from_menu; + Menu* to_menu; + + from_menu = boardmenu->menu_list[boardmenu->selected], + to_menu = boardmenu->menu_list[boardmenu->selected-1], + + insert_item( + to_menu, + get_menu_item( + from_menu, + get_selected_item(from_menu) + ), + min( + get_selected_item(from_menu), + get_menu_length(to_menu) + ) + ); + delete_item( + from_menu, + get_selected_item(from_menu) + ); + set_selected_menu(boardmenu, boardmenu->selected-1); + } break; case BINDING_MOVE_ITEM_RIGHT: + if (boardmenu->selected >= boardmenu->menu_count-1) break; + // this is legit cpy paste please fix this + { + Menu* from_menu; + Menu* to_menu; + + from_menu = boardmenu->menu_list[boardmenu->selected], + to_menu = boardmenu->menu_list[boardmenu->selected+1], + + insert_item( + to_menu, + get_menu_item( + from_menu, + get_selected_item(from_menu) + ), + min( + get_selected_item(from_menu), + get_menu_length(to_menu) + ) + ); + delete_item( + from_menu, + get_selected_item(from_menu) + ); + set_selected_menu(boardmenu, boardmenu->selected+1); + } break; case BINDING_DELETE_ITEM: @@ -88,8 +147,40 @@ main(int argc, char** argv) case BINDING_INSERT_BELOW: menu_driver(active_menu, MENU_INSERT_BELOW); break; + /* case BINDING_MOVE_MENU_LEFT: */ + /* if (boardmenu->selected-1 < 0) break; */ + + /* swap_menu(boardmenu, boardmenu->selected, boardmenu->selected-1); */ + /* boardmenu->selected -= 1; */ + /* set_selected_menu(boardmenu, boardmenu->selected); */ + + /* break; */ + /* case BINDING_MOVE_MENU_RIGHT: */ + /* if (boardmenu->selected >= boardmenu->menu_count-1) break; */ + /* swap_menu(boardmenu, boardmenu->selected, boardmenu->selected+1); */ + /* boardmenu->selected += 1; */ + /* set_selected_menu(boardmenu, boardmenu->selected); */ + + /* break; */ case BINDING_EDIT_ITEM: menu_driver(active_menu, MENU_EDIT); + break; + case BINDING_SELECT: + + break; + case BINDING_WRITE: + { + Board* writeboard; + + writeboard = boardmenu_to_board(boardmenu); + + /* mvprintw(30, 5, "%s", writeboard->todolist_list[0]->list_name); */ + begin_write(boardfile_name, writeboard); + + /* now free the writeborad */ + + } + break; } @@ -97,7 +188,6 @@ main(int argc, char** argv) render_menu(boardmenu->menu_list[i]); } - } exit_tscurses(); @@ -118,6 +208,51 @@ create_board_menu(Board* board) return new_boardmenu; } +Board* +boardmenu_to_board(BoardMenu* boardmenu) +{ // STRINGS are sharing the same address as the one in MENU + // and MENUITEM, this may break something if u free this board + // consider copying the string + + Board* newboard = malloc(sizeof(Board)); + TodoList** new_todolist_list = malloc(sizeof(TodoList*)); + + for (int i = 0; i < boardmenu->menu_count; i++) { + Menu* curmenu = boardmenu->menu_list[i]; + + TodoList* new_todolist = malloc(sizeof(TodoList)); + TodoItem** item_list = malloc(sizeof(TodoItem*)); + new_todolist->list_name = get_menu_name(curmenu); + new_todolist->item_count = get_menu_length(curmenu); + + for (int j = 0; j < get_menu_length(curmenu); j++) { + MenuItem* curmenuitem = get_menu_item(curmenu, j); + + TodoItem* new_todoitem = malloc(sizeof(TodoItem)); + + new_todoitem->item_name = get_menuitem_title(curmenuitem); + new_todoitem->description = get_menuitem_descrip(curmenuitem); + new_todoitem->due = 0; //TEMP! + new_todoitem->subtask_list = 0; //TEMP! + new_todoitem->subtask_count = 0; //TEMP! + + item_list[j] = new_todoitem; + + } + + new_todolist->item_list = item_list; + + new_todolist_list[i] = new_todolist; + + } + + newboard->todolist_list = new_todolist_list; + newboard->todolist_count = boardmenu->menu_count; + + return newboard; + +} + int set_selected_menu(BoardMenu* boardmenu, int index) { @@ -133,8 +268,7 @@ set_selected_menu(BoardMenu* boardmenu, int index) /* also try to jump to a similar position if possible */ /* rn theres a bug if old menu is empty */ - new_pos = (get_selected_item(old_menu) > get_menu_length(new_menu)-1) ? - get_menu_length(new_menu)-1 : get_selected_item(old_menu); + new_pos = min(get_selected_item(old_menu), get_menu_length(new_menu)-1); set_selected_item(new_menu, new_pos); boardmenu->selected = index; @@ -159,8 +293,6 @@ todolist_to_menuitem(TodoItem** item_list, int list_length) Menu** make_menus(Board* board, int todolist_length) { - // this is temp - #define MENU_WIDTH 40 Menu** menu_list; @@ -191,3 +323,29 @@ make_menus(Board* board, int todolist_length) return menu_list; } + +int +swap_menu(BoardMenu* boardmenu, int src_index, int dest_index) +{ + /* reposition menus */ + mvwin(get_menu_win(boardmenu->menu_list[src_index]), + 1, 1+MENU_WIDTH*dest_index + ); + mvwin(get_menu_win(boardmenu->menu_list[dest_index]), + 1, 1+MENU_WIDTH*src_index + ); + refresh(); + wrefresh(get_menu_win(boardmenu->menu_list[src_index])); + wrefresh(get_menu_win(boardmenu->menu_list[dest_index])); + /* wclear(get_menu_win(boardmenu->menu_list[src_index])); */ + /* wclear(get_menu_win(boardmenu->menu_list[dest_index])); */ + /* touchwin(get_menu_win(boardmenu->menu_list[src_index])); */ + /* touchwin(get_menu_win(boardmenu->menu_list[dest_index])); */ + clear(); + + /* swap in array */ + ar_swap_item((void*)boardmenu->menu_list, src_index, dest_index); + + return 0; +} +