diff options
| author | Joe <rbo@gmx.us> | 2024-01-05 20:20:20 +0100 | 
|---|---|---|
| committer | Joe <rbo@gmx.us> | 2024-01-05 20:20:20 +0100 | 
| commit | 1e69cade4a6a82c66d5d60000d00aaaf4a084d4d (patch) | |
| tree | a5e7a73c76687776f25e8f29b3940fe78bc74c89 | |
| parent | now really draw (diff) | |
| download | hardflip-1e69cade4a6a82c66d5d60000d00aaaf4a084d4d.tar.gz hardflip-1e69cade4a6a82c66d5d60000d00aaaf4a084d4d.tar.bz2 hardflip-1e69cade4a6a82c66d5d60000d00aaaf4a084d4d.tar.xz hardflip-1e69cade4a6a82c66d5d60000d00aaaf4a084d4d.tar.zst hardflip-1e69cade4a6a82c66d5d60000d00aaaf4a084d4d.zip | |
it builds at least
| -rw-r--r-- | c_init.go | 4 | ||||
| -rw-r--r-- | c_lhosts.go | 1 | ||||
| -rw-r--r-- | i_ui.go | 53 | 
3 files changed, 34 insertions, 24 deletions
| @@ -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  } @@ -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 { | 
