github ddddddO/gtree v1.11.0

latest releases: v1.11.2, v1.11.1
7 days ago

What's Changed

  • WalkIterProgrammably func implemented by @ddddddO in #303
    • Iterator implementation
    • It returns each node resulting from a recursive traversal of the tree structure, so you can process on each node
    • πŸ‘‡The following is sample codeπŸ‘‡
package main

import (
	"fmt"
	"os"

	"github.com/ddddddO/gtree"
)

func main() {
	root := gtree.NewRoot("root")
	root.Add("child 1").Add("child 2").Add("child 3")
	root.Add("child 5")
	root.Add("child 1").Add("child 2").Add("child 4")

	for wn, err := range gtree.WalkIterProgrammably(root) {
		if err != nil {
			fmt.Fprintln(os.Stderr, err)
			os.Exit(1)
		}

		fmt.Println(wn.Row())
	}
	// Output:
	// root
	// β”œβ”€β”€ child 1
	// β”‚   └── child 2
	// β”‚       β”œβ”€β”€ child 3
	// β”‚       └── child 4
	// └── child 5


	for wn, err := range gtree.WalkIterProgrammably(root) {
		if err != nil {
			fmt.Fprintln(os.Stderr, err)
			os.Exit(1)
		}

		fmt.Println("WalkerNode's methods called...")
		fmt.Printf("\tName     : %s\n", wn.Name())
		fmt.Printf("\tBranch   : %s\n", wn.Branch())
		fmt.Printf("\tRow      : %s\n", wn.Row())
		fmt.Printf("\tLevel    : %d\n", wn.Level())
		fmt.Printf("\tPath     : %s\n", wn.Path())
		fmt.Printf("\tHasChild : %t\n", wn.HasChild())
	}
	// Output:
	// WalkerNode's methods called...
	//         Name     : root
	//         Branch   : 
	//         Row      : root
	//         Level    : 1
	//         Path     : root
	//         HasChild : true
	// WalkerNode's methods called...
	//         Name     : child 1
	//         Branch   : β”œβ”€β”€
	//         Row      : β”œβ”€β”€ child 1
	//         Level    : 2
	//         Path     : root/child 1
	//         HasChild : true
	// WalkerNode's methods called...
	//         Name     : child 2
	//         Branch   : β”‚   └──
	//         Row      : β”‚   └── child 2
	//         Level    : 3
	//         Path     : root/child 1/child 2
	//         HasChild : true
	// WalkerNode's methods called...
	//         Name     : child 3
	//         Branch   : β”‚       β”œβ”€β”€
	//         Row      : β”‚       β”œβ”€β”€ child 3
	//         Level    : 4
	//         Path     : root/child 1/child 2/child 3
	//         HasChild : false
	// WalkerNode's methods called...
	//         Name     : child 4
	//         Branch   : β”‚       └──
	//         Row      : β”‚       └── child 4
	//         Level    : 4
	//         Path     : root/child 1/child 2/child 4
	//         HasChild : false
	// WalkerNode's methods called...
	//         Name     : child 5
	//         Branch   : └──
	//         Row      : └── child 5
	//         Level    : 2
	//         Path     : root/child 5
	//         HasChild : false
}

Full Changelog: v1.10.15...v1.11.0

Don't miss a new gtree release

NewReleases is sending notifications on new releases.