aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoe <rbo@gmx.us>2024-01-05 20:20:20 +0100
committerJoe <rbo@gmx.us>2024-01-05 20:20:20 +0100
commit1e69cade4a6a82c66d5d60000d00aaaf4a084d4d (patch)
treea5e7a73c76687776f25e8f29b3940fe78bc74c89
parentnow really draw (diff)
downloadhardflip-1e69cade4a6a82c66d5d60000d00aaaf4a084d4d.tar.gz
hardflip-1e69cade4a6a82c66d5d60000d00aaaf4a084d4d.tar.bz2
hardflip-1e69cade4a6a82c66d5d60000d00aaaf4a084d4d.tar.xz
hardflip-1e69cade4a6a82c66d5d60000d00aaaf4a084d4d.tar.zst
hardflip-1e69cade4a6a82c66d5d60000d00aaaf4a084d4d.zip
it builds at least
Diffstat (limited to '')
-rw-r--r--c_init.go4
-rw-r--r--c_lhosts.go1
-rw-r--r--i_ui.go53
3 files changed, 34 insertions, 24 deletions
diff --git a/c_init.go b/c_init.go
index 413d91a..dada0c8 100644
--- a/c_init.go
+++ b/c_init.go
@@ -43,7 +43,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*
* hardflip: src/c_init.go
- * Tue Dec 26 16:32:26 2023
+ * Fri Jan 05 16:53:38 2024
* Joe
*
* init functions
@@ -100,7 +100,7 @@ func c_recurse_data_dir(dir, root string, opts HardOpts,
// item_node.Host = host_node
// litems.add_back(&item_node)
host_node.Filename = filename
- // host_node.Parent = &dir_node
+ host_node.Parent = &dir_node
dir_node.lhost.add_back(host_node)
}
}
diff --git a/c_lhosts.go b/c_lhosts.go
index 48c3a8b..fde5881 100644
--- a/c_lhosts.go
+++ b/c_lhosts.go
@@ -74,6 +74,7 @@ type HostNode struct {
Dynamic bool `yaml:"dynamic"`
Note string `yaml:"note"`
Filename string
+ Parent *DirsNode
next *HostNode
}
diff --git a/i_ui.go b/i_ui.go
index 72a7ecf..d022bb8 100644
--- a/i_ui.go
+++ b/i_ui.go
@@ -43,7 +43,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*
* hardflip: src/i_ui.go
- * Fri Jan 05 16:40:33 2024
+ * Fri Jan 05 16:59:59 2024
* Joe
*
* interfacing with the user
@@ -269,13 +269,13 @@ func i_host_panel_dirs(ui HardUI, icons bool, dirs *DirsNode, line int) {
}
func i_host_panel_host(ui HardUI, icons bool,
- dirs *DirsNode, host *HostNode, line int) {
- style := ui.def_style
+ depth uint16, host *HostNode, line int) {
+ style := ui.def_style
if ui.sel_id == host.ID {
style = style.Reverse(true)
}
text := ""
- for i := 0; i < int(dirs.Depth) - 2; i++ {
+ for i := 0; i < int(depth) - 2; i++ {
text += " "
}
if icons == true {
@@ -292,29 +292,38 @@ func i_host_panel_host(ui HardUI, icons bool,
style, text)
}
-func i_host_panel(ui HardUI, icons bool, ldirs *DirsList) {
+func i_host_panel(ui HardUI, icons bool, litems *ItemsList) {
i_draw_box(ui.s, 0, 0,
ui.dim[W] / 3, ui.dim[H] - 2,
" Hosts ", false)
line := 1
- dirs := ldirs.head
- for host := dirs.lhost.head;
- dirs.Folded == false && host != nil;
- host = host.next {
- i_host_panel_host(ui, icons, dirs, host, line)
- line++
- }
- dirs = dirs.next
- for line = line; line < ui.dim[H] - 2 && dirs != nil; dirs = dirs.next {
- i_host_panel_dirs(ui, icons, dirs, line)
- line++
- for host := dirs.lhost.head;
- dirs.Folded == false && host != nil;
- host = host.next {
- i_host_panel_host(ui, icons, dirs, host, line)
- line++
+ for ptr := litems.head; ptr != nil; ptr = ptr.next {
+ if ptr.is_dir() == false {
+ i_host_panel_host(ui, icons, ptr.Host.Parent.Depth, ptr.Host, line)
+ } else {
+ i_host_panel_dirs(ui, icons, ptr.Dirs, line)
}
+ line++
}
+
+ // dirs := litems.head.Dirs
+ // for host := dirs.lhost.head;
+ // dirs.Folded == false && host != nil;
+ // host = host.next {
+ // i_host_panel_host(ui, icons, dirs.Depth, host, line)
+ // line++
+ // }
+ // dirs = dirs.next
+ // for line = line; line < ui.dim[H] - 2 && dirs != nil; dirs = dirs.next {
+ // i_host_panel_dirs(ui, icons, dirs, line)
+ // line++
+ // for host := dirs.lhost.head;
+ // dirs.Folded == false && host != nil;
+ // host = host.next {
+ // i_host_panel_host(ui, icons, dirs.Depth, host, line)
+ // line++
+ // }
+ // }
if ui.sel_max == 0 {
i_draw_text(ui.s,
1, ui.dim[H] - 2, (ui.dim[W] / 3) - 1, ui.dim[H] - 2,
@@ -537,7 +546,7 @@ func i_ui(data *HardData) {
ui.dim[W], ui.dim[H], _ = term.GetSize(0)
ui.s.Clear()
i_bottom_text(*ui)
- i_host_panel(data.ui, data.opts.Icon, data.ldirs)
+ i_host_panel(data.ui, data.opts.Icon, data.litems)
// TODO: info panel
// i_info_panel(data.ui, data.lhost)
if data.ldirs.head.lhost.head == nil && data.ldirs.head.next == nil {