X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=taskasaur.c;h=c9bddb8490f1dc2cac5bc4fdefb639c1783a52e9;hb=8b6f14fe02e0bb9a851cf0e134fc109f311c2e4d;hp=a4c0f4e4938827982894b5ab6b367bdd6e12c68c;hpb=f74c3f9aca7f090530179355c399a08bb9ae164a;p=taskasaur.git diff --git a/taskasaur.c b/taskasaur.c index a4c0f4e..c9bddb8 100644 --- a/taskasaur.c +++ b/taskasaur.c @@ -1,153 +1,178 @@ -#include -#include -#include -#include -#include -void winch_handler(int sig); +#include "headers/parser.h" +#include "headers/render.h" +#include "headers/menu.h" +#include "headers/utils.h" +#include "config.h" -char** read_todo(FILE* file); +typedef struct BoardMenu { + Menu** menu_list; + int menu_count; + int selected; +} BoardMenu; -WINDOW* create_list_win(int height, int width, int y, int x); +BoardMenu* create_board_menu(Board* board); +int set_selected_menu(BoardMenu* boardmenu, int index); -#include "config.h" +MenuItem** todolist_to_menuitem(TodoItem** item_list, int list_length); +Menu** make_menus(Board* board, int todolist_length); -int -main(int argc, char** argv) +int +main(int argc, char** argv) { - int flag; - FILE* board_file; - int height, width; - int x, y; - int ch; - WINDOW* todo_win; - - signal(SIGWINCH, winch_handler); - - // read command line args - flag = getopt(argc, argv, "o:n:"); - switch (flag) { - case 'o': - - // read from task file (might need to check for read and write permissions) - board_file = fopen(optarg, "r"); - if (!board_file) { - printf("%s does not exist\n", optarg); - return 1; - } - - char** todos = read_todo(board_file); - printf(todos[0]); - fclose(board_file); - - break; - - case 'n': - - // make sure file does not exist - // however, it maybe be possible that an different error has occured (besides the file not existing) - if (access(optarg, F_OK) == 0) { - printf("%s already exists\n", optarg); - return 1; - } - // create a file here - printf("Successfully created %s\n", optarg); - break; - - case -1: - case '?': - printf("Help string\n"); - return 2; - } + /* read from todo file */ + Board* board; + board = begin_parse("test_board.md"); + /* log_todo(board); */ + /* init curses */ + init_tscurses(); + BoardMenu* boardmenu; + boardmenu = create_board_menu(board); - return 0; + // this is temp + for (int i = 0; i < boardmenu->menu_count; i++) { + render_menu(boardmenu->menu_list[i]); + } - // start ncurses - initscr(); - cbreak(); - /* raw(); */ - noecho(); - start_color(); - - init_pair(1, COLOR_CYAN, COLOR_BLACK); - init_pair(2, COLOR_BLACK, COLOR_CYAN); + char ch; + while ((ch = getch()) != BINDING_QUIT) { - getmaxyx(stdscr, height, width); - x = y = 0; - refresh(); + Menu* active_menu; + active_menu = boardmenu->menu_list[boardmenu->selected]; - todo_win = create_list_win(20, 20, 5, 5); - - move(y,x); - while ((ch = getch()) != 113) { // while not q - - // ofc the first thing we need is vim keys switch (ch) { - case 104: // h - x -= 1; + + case BINDING_SCROLL_UP: + menu_driver(active_menu, MENU_UP); + break; + case BINDING_SCROLL_DOWN: + menu_driver(active_menu, MENU_DOWN); + break; + case BINDING_SCROLL_LEFT: + if (boardmenu->selected-1 < 0) break; + set_selected_menu(boardmenu, boardmenu->selected-1); + break; + case BINDING_SCROLL_RIGHT: + if (boardmenu->selected+1 > boardmenu->menu_count-1) break; + set_selected_menu(boardmenu, boardmenu->selected+1); break; - case 106: // j - y += 1; + case BINDING_JUMP_TOP: + menu_driver(active_menu, MENU_TOP); break; - case 107: // k - y -= 1; + case BINDING_JUMP_BOTTOM: + menu_driver(active_menu, MENU_BOTTOM); break; - case 108: // l - x += 1; + case BINDING_MOVE_ITEM_UP: + menu_driver(active_menu, MENU_MOVE_UP); break; - } + case BINDING_MOVE_ITEM_DOWN: + menu_driver(active_menu, MENU_MOVE_DOWN); + break; + case BINDING_DELETE_ITEM: + menu_driver(active_menu, MENU_DELETE); + break; + case BINDING_APPEND_ITEM: + menu_driver(active_menu, MENU_APPEND); + break; + } + + for (int i = 0; i < boardmenu->menu_count; i++) { + render_menu(boardmenu->menu_list[i]); + } + - move(y,x); - refresh(); - /* clear(); */ } - endwin(); - return 0; + exit_tscurses(); + return 0; } -void -winch_handler(int sig) +BoardMenu* +create_board_menu(Board* board) { - endwin(); - refresh(); + BoardMenu* new_boardmenu; + + new_boardmenu = malloc(sizeof(BoardMenu)); + + new_boardmenu->menu_list = make_menus(board, board->todolist_count); + new_boardmenu->menu_count = board->todolist_count; + new_boardmenu->selected = 0; + + return new_boardmenu; } +int +set_selected_menu(BoardMenu* boardmenu, int index) +{ + Menu* old_menu; + Menu* new_menu; + int new_pos; + + old_menu = boardmenu->menu_list[boardmenu->selected]; + new_menu = boardmenu->menu_list[index]; + + set_menu_focus(old_menu, false); + set_menu_focus(new_menu, true); + + /* 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); + set_selected_item(new_menu, new_pos); -char** -read_todo(FILE* file) -{ // apparently getline isn't rly that portable, so consider other options - char** out_arr; - int out_len; - char* lineptr; - size_t len; - ssize_t nread; - - out_arr = NULL; - out_len = 0; - lineptr = NULL; - len = 0; - - while ((nread = getline(&lineptr, &len, file)) != -1) { - out_len++; - out_arr = realloc(out_arr, (sizeof(char*))*out_len); // bad to keep resizing? - printf("Pointer set to: %p\n", lineptr); - out_arr[out_len-1] = lineptr; - - lineptr = NULL; - len = 0; + boardmenu->selected = index; + + return 0; +} + +MenuItem** +todolist_to_menuitem(TodoItem** item_list, int list_length) +{ + MenuItem** items; + + items = malloc((list_length+1)*sizeof(MenuItem*)); + for (int i = 0; i < list_length; i++) { + items[i] = create_menuitem(item_list[i]->item_name); } - return out_arr; + items[list_length] = 0; //null terminate + return items; } -WINDOW* -create_list_win(int height, int width, int y, int x) +Menu** +make_menus(Board* board, int todolist_length) { - WINDOW* new_win = newwin(height, width, y, x); - box(new_win, 0, 0); - wrefresh(new_win); - return new_win; + // this is temp + #define MENU_WIDTH 40 + + Menu** menu_list; + + menu_list = malloc(todolist_length*sizeof(Menu*)); + + for (int i = 0; i < todolist_length; i++) { + + /* read from parsed */ + TodoList* todo_list = board->todolist_list[i]; + MenuItem** item_list = todolist_to_menuitem(todo_list->item_list, todo_list->item_count); + + Menu* new_menu = create_menu(todo_list->list_name, item_list); + + /* make window */ + WINDOW* win = newwin(20, MENU_WIDTH, 1, 1+MENU_WIDTH*i); + box(win, 0, 0); + + /* some menu settings */ + set_menu_win(new_menu, win); + set_menu_focus(new_menu, i == 0); // make first win focused + + /* refresh */ + refresh(); + wrefresh(win); + + menu_list[i] = new_menu; + } + + return menu_list; }