aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoe <rbo@gmx.us>2024-01-18 20:20:20 +0100
committerJoe <rbo@gmx.us>2024-01-18 20:20:20 +0100
commitbfc6e7a122d7cb9686823af6516a450f18222c28 (patch)
tree848aa48dc07d7a19f4a9602c5d2900916f853c00
parentgo (diff)
downloadhardflip-bfc6e7a122d7cb9686823af6516a450f18222c28.tar.gz
hardflip-bfc6e7a122d7cb9686823af6516a450f18222c28.tar.bz2
hardflip-bfc6e7a122d7cb9686823af6516a450f18222c28.tar.xz
hardflip-bfc6e7a122d7cb9686823af6516a450f18222c28.tar.zst
hardflip-bfc6e7a122d7cb9686823af6516a450f18222c28.zip
nobody will every see this
-rw-r--r--ROADMAP.md1
-rw-r--r--c_defs.go4
-rw-r--r--c_hardflip.go12
-rw-r--r--c_init.go29
-rw-r--r--i_events.go2
-rw-r--r--i_ui.go47
6 files changed, 65 insertions, 30 deletions
diff --git a/ROADMAP.md b/ROADMAP.md
index f3a976f..533c84c 100644
--- a/ROADMAP.md
+++ b/ROADMAP.md
@@ -8,6 +8,7 @@
## v0.2
+- [ ] load scr
- [ ] err msg
## v0.3
diff --git a/c_defs.go b/c_defs.go
index b809db8..d6a55e4 100644
--- a/c_defs.go
+++ b/c_defs.go
@@ -63,8 +63,7 @@ const (
[x](m)kdir -
[x](s)earch -
[x](?) help`
- DELETE_KEYS_HINTS = `
-(q)uit -
+ DELETE_KEYS_HINTS = `(q)uit -
(y)es -
(n)o`
)
@@ -72,6 +71,7 @@ const (
const (
NORMAL_MODE = 0
DELETE_MODE = 1
+ LOAD_MODE = 2
)
var (
diff --git a/c_hardflip.go b/c_hardflip.go
index 0ec601a..e4aec6c 100644
--- a/c_hardflip.go
+++ b/c_hardflip.go
@@ -64,15 +64,5 @@ type HardData struct {
func main() {
data_dir := c_get_data_dir()
opts := HardOpts{true, true, false, ""}
- ldirs := c_load_data_dir(data_dir, opts)
- litems := c_load_litems(ldirs)
- data := HardData{
- litems,
- ldirs,
- HardUI{},
- opts,
- data_dir,
- make(map[*DirsNode]*ItemsList),
- }
- i_ui(&data)
+ i_ui(data_dir, opts)
}
diff --git a/c_init.go b/c_init.go
index cd12001..d39ab71 100644
--- a/c_init.go
+++ b/c_init.go
@@ -52,6 +52,7 @@
package main
import (
+ "strconv"
"os"
"path/filepath"
)
@@ -63,11 +64,15 @@ type HardOpts struct {
Term string
}
+// HACK: fuck global vars
+var count int = 0
+
// this function recurses into the specified root directory in order to load
// every yaml file into memory
func c_recurse_data_dir(dir, root string, opts HardOpts,
ldirs *DirsList,
- name string, parent *DirsNode, depth uint16) {
+ name string, parent *DirsNode, depth uint16,
+ ui *HardUI) {
files, err := os.ReadDir(root + dir)
if err != nil {
c_die("could not read data directory", err)
@@ -84,7 +89,7 @@ func c_recurse_data_dir(dir, root string, opts HardOpts,
filename := file.Name()
if file.IsDir() == true {
c_recurse_data_dir(dir + filename + "/", root, opts, ldirs,
- file.Name(), &dir_node, depth + 1)
+ file.Name(), &dir_node, depth + 1, ui)
} else if filepath.Ext(filename) == ".yml" {
host_node := c_read_yaml_file(root + dir + filename)
if host_node == nil {
@@ -93,14 +98,30 @@ func c_recurse_data_dir(dir, root string, opts HardOpts,
host_node.Filename = filename
host_node.Parent = &dir_node
dir_node.lhost.add_back(host_node)
+ ui.s.Clear()
+ count += 1
+ text := "Loading " + strconv.Itoa(count) + " hosts"
+ text_len := len(text) / 2
+ i_draw_box(ui.s,
+ (ui.dim[W] / 2) - (text_len + 2),
+ (ui.dim[H] / 2) - 2,
+ (ui.dim[W] / 2) + (text_len + 2),
+ (ui.dim[H] / 2) + 2, " Loading hosts ", false)
+ i_draw_text(ui.s,
+ (ui.dim[W] / 2) - text_len,
+ (ui.dim[H] / 2),
+ (ui.dim[W] / 2) + text_len,
+ (ui.dim[H] / 2),
+ ui.def_style, text)
+ ui.s.Show()
}
}
}
-func c_load_data_dir(dir string, opts HardOpts) *DirsList {
+func c_load_data_dir(dir string, opts HardOpts, ui *HardUI) *DirsList {
ldirs := DirsList{}
- c_recurse_data_dir("", dir + "/", opts, &ldirs, "", nil, 1)
+ c_recurse_data_dir("", dir + "/", opts, &ldirs, "", nil, 1, ui)
return &ldirs
}
diff --git a/i_events.go b/i_events.go
index 9bc52ab..d799824 100644
--- a/i_events.go
+++ b/i_events.go
@@ -168,7 +168,7 @@ func i_fold_dir(data *HardData, item *ItemsNode) {
func i_reload_data(data *HardData) {
data.data_dir = c_get_data_dir()
- data.ldirs = c_load_data_dir(data.data_dir, data.opts)
+ data.ldirs = c_load_data_dir(data.data_dir, data.opts, &data.ui)
data.litems = c_load_litems(data.ldirs)
data.folds = make(map[*DirsNode]*ItemsList)
}
diff --git a/i_ui.go b/i_ui.go
index cbaf78e..6757f9b 100644
--- a/i_ui.go
+++ b/i_ui.go
@@ -55,6 +55,7 @@ import (
"strconv"
"github.com/gdamore/tcell/v2"
+ "golang.org/x/term"
)
type HardUI struct {
@@ -118,7 +119,7 @@ func i_draw_box(s tcell.Screen, x1, y1, x2, y2 int, title string, fill bool) {
}
}
}
- i_draw_text(s, x1 + 1, y1, x2 - 1, y2 - 1, style, title)
+ i_draw_text(s, x1 + 1, y1, x2 - 1, y1, style, title)
}
func i_bottom_text(ui HardUI) {
@@ -161,6 +162,7 @@ func i_draw_zhosts_box(ui HardUI) {
func i_draw_delete_box(ui HardUI, item *ItemsNode) {
var text string
var file string
+
if item.is_dir() == true {
text = "Really delete this directory and all of its content?"
file = item.Dirs.path()
@@ -511,7 +513,6 @@ func i_info_panel(ui HardUI, percent bool, litems *ItemsList) {
ui.dim[H] - 2,
ui.def_style,
text)
- i_draw_text(ui.s, 0, ui.dim[H] - 2, len(text), ui.dim[H] - 2, ui.def_style, text)
} else {
text := " 0 hosts "
i_draw_text(ui.s,
@@ -555,9 +556,20 @@ func i_scrollhint(ui HardUI, litems *ItemsList) {
}
}
-func i_ui(data *HardData) {
+func i_load_ui(data_dir string,
+ opts HardOpts,
+ ui *HardUI) (*DirsList, *ItemsList) {
+ ui.s.Clear()
+ ldirs := c_load_data_dir(data_dir, opts, ui)
+ litems := c_load_litems(ldirs)
+ ui.s.Show()
+ ui.mode = NORMAL_MODE
+ return ldirs, litems
+}
+
+func i_ui(data_dir string, opts HardOpts) {
+ ui := HardUI{}
var err error
- ui := &data.ui
ui.s, err = tcell.NewScreen()
if err != nil {
@@ -576,19 +588,30 @@ func i_ui(data *HardData) {
Background(tcell.ColorReset).
Foreground(tcell.ColorBlue).Dim(true).Bold(true)
ui.s.SetStyle(ui.def_style)
+ ui.dim[W], ui.dim[H], _ = term.GetSize(0)
+ ui.mode = LOAD_MODE
+ ldirs, litems := i_load_ui(data_dir, opts, &ui)
+ data := HardData{
+ litems,
+ ldirs,
+ ui,
+ opts,
+ data_dir,
+ make(map[*DirsNode]*ItemsList),
+ }
for {
- ui.s.Clear()
- i_bottom_text(*ui)
- i_host_panel(data.ui, data.opts.Icon, data.litems, data)
+ data.ui.s.Clear()
+ i_bottom_text(data.ui)
+ i_host_panel(data.ui, data.opts.Icon, data.litems, &data)
i_info_panel(data.ui, data.opts.Perc, data.litems)
i_scrollhint(data.ui, data.litems)
if data.litems.head == nil {
- i_draw_zhosts_box(*ui)
+ i_draw_zhosts_box(data.ui)
}
- if ui.mode == DELETE_MODE {
- i_draw_delete_box(*ui, data.litems.curr)
+ if data.ui.mode == DELETE_MODE {
+ i_draw_delete_box(data.ui, data.litems.curr)
}
- ui.s.Show()
- i_events(data)
+ data.ui.s.Show()
+ i_events(&data)
}
}