diff options
-rw-r--r-- | src/c_hardflip.go | 2 | ||||
-rw-r--r-- | src/c_init.go | 15 | ||||
-rw-r--r-- | src/i_events.go | 6 | ||||
-rw-r--r-- | src/i_ui.go | 27 |
4 files changed, 28 insertions, 22 deletions
diff --git a/src/c_hardflip.go b/src/c_hardflip.go index 538cb30..8ffdaba 100644 --- a/src/c_hardflip.go +++ b/src/c_hardflip.go @@ -59,7 +59,7 @@ type HardData struct { opts HardOpts folds map[*DirsNode]*ItemsList data_dir string - load_err *[]error + load_err []error } func main() { diff --git a/src/c_init.go b/src/c_init.go index 5d399e2..5c9f115 100644 --- a/src/c_init.go +++ b/src/c_init.go @@ -92,24 +92,23 @@ func c_recurse_data_dir(dir, root string, opts HardOpts, host_node, err := c_read_yaml_file(root + dir + filename, ui) if err != nil { *load_err = append(*load_err, err) - return - } else if host_node == nil { - return + } else if host_node != nil { + host_node.Filename = filename + host_node.Parent = &dir_node + dir_node.lhost.add_back(host_node) } - host_node.Filename = filename - host_node.Parent = &dir_node - dir_node.lhost.add_back(host_node) i_draw_load_ui(ui) } } } -func c_load_data_dir(dir string, opts HardOpts, ui *HardUI) (*DirsList, *[]error) { +func c_load_data_dir(dir string, opts HardOpts, + ui *HardUI) (*DirsList, []error) { ldirs := DirsList{} var load_err []error c_recurse_data_dir("", dir + "/", opts, &ldirs, "", nil, 1, ui, &load_err) - return &ldirs, &load_err + return &ldirs, load_err } // fills litems sorting with dirs last diff --git a/src/i_events.go b/src/i_events.go index 427f9c1..7ca1511 100644 --- a/src/i_events.go +++ b/src/i_events.go @@ -168,7 +168,8 @@ func i_fold_dir(data *HardData, item *ItemsNode) { func i_reload_data(data *HardData) { data.data_dir = c_get_data_dir() g_load_count = -1 - data.ldirs, data.litems, data.load_err = i_load_ui(data.data_dir, data.opts, &data.ui) + data.ldirs, data.litems, data.load_err = i_load_ui(data.data_dir, data.opts, + &data.ui) // FIX: must input to start reloading for some reason data.folds = make(map[*DirsNode]*ItemsList) } @@ -325,6 +326,7 @@ func i_events(data *HardData) { i_unfold_dir(data, data.litems.curr) } } else if event.Key() == tcell.KeyCtrlR { + event = nil i_reload_data(data) } i_list_follow_cursor(data.litems, ui) @@ -341,7 +343,7 @@ func i_events(data *HardData) { } } case ERROR_MODE: - if event.Rune() == 'q' || + if event.Rune() != 0 || event.Key() == tcell.KeyEnter { ui.mode = NORMAL_MODE data.load_err = nil diff --git a/src/i_ui.go b/src/i_ui.go index 53bd056..6777f6c 100644 --- a/src/i_ui.go +++ b/src/i_ui.go @@ -221,19 +221,24 @@ func i_draw_delete_msg(ui HardUI, item *ItemsNode) { ui.style[DEF_STYLE].Bold(true), file) } -func i_draw_load_error_msg(ui HardUI, load_err *[]error) { - lines := len(*load_err) +func i_draw_load_error_msg(ui HardUI, load_err []error) { + lines := len(load_err) i_draw_msg(ui.s, lines, ui.style[BOX_STYLE], ui.dim, " Load time errors ") - left, right := 1, ui.dim[W] - 2 - for i, err := range *load_err { + left, right := 1, ui.dim[W] - 1 + line := ui.dim[H] - 2 - 1 - len(load_err) + if line < 0 { + line = 0 + } + for i, err := range load_err { + line += 1 err_str := fmt.Sprintf("%v", err) - i_draw_text(ui.s, left, i, right, i, - ui.style[ERR_STYLE], strconv.Itoa(i) + err_str) + i_draw_text(ui.s, left, line, right, line, + ui.style[ERR_STYLE], strconv.Itoa(i + 1) + " " + err_str) } } -func i_draw_error_msg(ui HardUI, load_err *[]error) { - if len(*load_err) > 0 { +func i_draw_error_msg(ui HardUI, load_err []error) { + if len(load_err) > 0 { i_draw_load_error_msg(ui, load_err) return } @@ -316,12 +321,12 @@ func i_draw_load_ui(ui *HardUI) { func i_load_ui(data_dir string, opts HardOpts, - ui *HardUI) (*DirsList, *ItemsList, *[]error) { + ui *HardUI) (*DirsList, *ItemsList, []error) { ui.mode = LOAD_MODE ldirs, load_err := c_load_data_dir(data_dir, opts, ui) litems := c_load_litems(ldirs) ui.mode = NORMAL_MODE - if len(*load_err) == 0 { + if len(load_err) == 0 { load_err = nil } return ldirs, litems, load_err @@ -378,7 +383,7 @@ func i_ui(data_dir string, opts HardOpts) { i_draw_host_panel(data.ui, data.opts.Icon, data.litems, &data) i_draw_info_panel(data.ui, data.opts.Perc, data.litems) i_draw_scrollhint(data.ui, data.litems) - if data.load_err != nil && len(*data.load_err) > 0 { + if data.load_err != nil && len(data.load_err) > 0 { data.ui.mode = ERROR_MODE } if data.litems.head == nil { |