aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--c_defs.go4
-rw-r--r--c_utils.go10
-rw-r--r--i_events.go40
-rw-r--r--i_ui.go29
4 files changed, 64 insertions, 19 deletions
diff --git a/c_defs.go b/c_defs.go
index d6a55e4..4145613 100644
--- a/c_defs.go
+++ b/c_defs.go
@@ -54,6 +54,8 @@ package main
const (
W = 0
H = 1
+ ERROR_MSG = 0
+ ERROR_ERR = 1
DATA_DIR_NAME = "hardflip"
VERSION = "v0.1"
)
@@ -66,12 +68,14 @@ const (
DELETE_KEYS_HINTS = `(q)uit -
(y)es -
(n)o`
+ ERROR_KEYS_HINTS = "[Enter] Ok"
)
const (
NORMAL_MODE = 0
DELETE_MODE = 1
LOAD_MODE = 2
+ ERROR_MODE = 3
)
var (
diff --git a/c_utils.go b/c_utils.go
index 4af14de..72761d8 100644
--- a/c_utils.go
+++ b/c_utils.go
@@ -95,3 +95,13 @@ func c_die(str string, err error) {
fmt.Fprintf(os.Stderr, "\n")
os.Exit(1)
}
+
+func c_error_mode(msg string, err error, ui *HardUI) {
+ ui.mode = ERROR_MODE
+ err_str := ""
+ if err != nil {
+ err_str = fmt.Sprintf("%v", err)
+ }
+ ui.err[ERROR_MSG] = msg
+ ui.err[ERROR_ERR] = err_str
+}
diff --git a/i_events.go b/i_events.go
index f2430d2..e0889f4 100644
--- a/i_events.go
+++ b/i_events.go
@@ -43,7 +43,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*
* hardflip: src/i_events.go
- * Thu Jan 18 18:01:23 2024
+ * Fri Jan 19 19:25:52 2024
* Joe
*
* events in the code
@@ -62,7 +62,6 @@ func i_list_follow_cursor(litems *ItemsList, ui *HardUI) {
if litems.draw == nil || litems.curr == nil {
return
}
- // HACK: find workaround to kill ids
scrolloff := 4
if litems.last.ID - (ui.dim[H] - 4) <= litems.draw.ID {
scrolloff = 0
@@ -174,12 +173,16 @@ func i_reload_data(data *HardData) {
data.folds = make(map[*DirsNode]*ItemsList)
}
-func i_delete_dir(data *HardData) {
+func i_delete_dir(data *HardData) error {
if data.litems.curr == nil || data.litems.curr.Dirs == nil {
- return
+ return nil
}
curr := data.litems.curr
dir_path := data.data_dir + data.litems.curr.Dirs.path()
+ if err := os.RemoveAll(dir_path); err != nil {
+ c_error_mode("can't remove " + dir_path, err, &data.ui)
+ return err
+ }
if data.folds[curr.Dirs] == nil {
i_fold_dir(data, curr)
}
@@ -203,29 +206,25 @@ func i_delete_dir(data *HardData) {
data.litems.curr = curr.prev
}
data.litems.reset_id()
- if err := os.RemoveAll(dir_path); err != nil {
- data.ui.s.Fini()
- c_die("can't remove " + dir_path, err)
- }
+ return nil
}
-func i_delete_host(data *HardData) {
+func i_delete_host(data *HardData) error {
if data.litems.curr == nil {
- return
+ return nil
}
if data.litems.curr.is_dir() == true {
- i_delete_dir(data)
- return
+ return i_delete_dir(data)
}
host := data.litems.curr.Host
if host == nil {
- return
+ return nil
}
file_path := data.data_dir + host.Parent.path() + host.Filename
if err := os.Remove(file_path); err != nil {
- data.ui.s.Fini()
- c_die("can't remove " + file_path, err)
+ c_error_mode("can't remove " + file_path, err, &data.ui)
+ return err
}
tmp := data.litems.curr.prev
host.Parent.lhost.del(host)
@@ -234,6 +233,7 @@ func i_delete_host(data *HardData) {
tmp = data.litems.head
}
data.litems.curr = tmp
+ return nil
}
// screen events such as keypresses
@@ -333,8 +333,14 @@ func i_events(data *HardData) {
event.Rune() == 'q' ||
event.Rune() == 'n' {
ui.mode = NORMAL_MODE
- } else if event.Rune() == 'y' {
- i_delete_host(data)
+ } else if event.Key() == tcell.KeyEnter ||
+ event.Rune() == 'y' {
+ if err := i_delete_host(data); err == nil {
+ ui.mode = NORMAL_MODE
+ }
+ }
+ case ERROR_MODE:
+ if event.Key() == tcell.KeyEnter {
ui.mode = NORMAL_MODE
}
}
diff --git a/i_ui.go b/i_ui.go
index b0c2414..05e5141 100644
--- a/i_ui.go
+++ b/i_ui.go
@@ -43,7 +43,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*
* hardflip: src/i_ui.go
- * Fri Jan 19 18:45:35 2024
+ * Fri Jan 19 19:23:24 2024
* Joe
*
* interfacing with the user
@@ -66,6 +66,7 @@ type HardUI struct {
dir_style tcell.Style
title_style tcell.Style
dim [2]int
+ err [2]string
}
func i_left_right(text_len int, ui *HardUI) (int, int) {
@@ -179,6 +180,10 @@ func i_draw_bottom_text(ui HardUI) {
text = NORMAL_KEYS_HINTS
case DELETE_MODE:
text = DELETE_KEYS_HINTS
+ case LOAD_MODE:
+ text = ""
+ case ERROR_MODE:
+ text = ERROR_KEYS_HINTS
}
i_draw_text(ui.s,
0, ui.dim[H] - 1, ui.dim[W], ui.dim[H] - 1,
@@ -220,7 +225,24 @@ func i_draw_delete_msg(ui HardUI, item *ItemsNode) {
ui.def_style.Bold(true), file)
}
-func i_draw_err_box() {
+func i_draw_error_msg(ui HardUI) {
+ lines := 2
+ if len(ui.err[ERROR_ERR]) == 0 {
+ lines = 1
+ }
+ i_draw_msg(ui.s, lines, ui.dim, " Delete ")
+ left, right := i_left_right(len(ui.err[ERROR_MSG]), &ui)
+ line := ui.dim[H] - 2 - 2
+ if len(ui.err[ERROR_ERR]) == 0 {
+ line += 1
+ }
+ i_draw_text(ui.s, left, line, right, line, ui.def_style, ui.err[ERROR_MSG])
+ if len(ui.err[ERROR_ERR]) > 0 {
+ left, right = i_left_right(len(ui.err[ERROR_ERR]), &ui)
+ line += 1
+ i_draw_text(ui.s, left, line, right, line,
+ ui.def_style, ui.err[ERROR_ERR])
+ }
}
func i_draw_scrollhint(ui HardUI, litems *ItemsList) {
@@ -334,6 +356,9 @@ func i_ui(data_dir string, opts HardOpts) {
if data.ui.mode == DELETE_MODE {
i_draw_delete_msg(data.ui, data.litems.curr)
}
+ if data.ui.mode == ERROR_MODE {
+ i_draw_error_msg(data.ui)
+ }
data.ui.s.Show()
i_events(&data)
}