2014-05-19 20:46:41 -07:00
|
|
|
package merkle
|
|
|
|
|
2014-05-20 16:33:10 -07:00
|
|
|
import (
|
2014-07-01 14:50:24 -07:00
|
|
|
"fmt"
|
2014-05-20 16:33:10 -07:00
|
|
|
)
|
|
|
|
|
2014-11-04 16:21:40 -08:00
|
|
|
// Prints the in-memory children recursively.
|
2014-05-20 16:33:10 -07:00
|
|
|
func PrintIAVLNode(node *IAVLNode) {
|
2014-07-01 14:50:24 -07:00
|
|
|
fmt.Println("==== NODE")
|
|
|
|
if node != nil {
|
|
|
|
printIAVLNode(node, 0)
|
|
|
|
}
|
|
|
|
fmt.Println("==== END")
|
2014-05-20 16:33:10 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
func printIAVLNode(node *IAVLNode, indent int) {
|
2014-07-01 14:50:24 -07:00
|
|
|
indentPrefix := ""
|
|
|
|
for i := 0; i < indent; i++ {
|
|
|
|
indentPrefix += " "
|
|
|
|
}
|
2014-05-27 22:31:47 -07:00
|
|
|
|
2014-10-06 01:46:39 -07:00
|
|
|
if node.rightNode != nil {
|
|
|
|
printIAVLNode(node.rightNode, indent+1)
|
2014-10-06 00:15:37 -07:00
|
|
|
} else if node.rightHash != nil {
|
|
|
|
fmt.Printf("%s %X\n", indentPrefix, node.rightHash)
|
2014-07-01 14:50:24 -07:00
|
|
|
}
|
2014-05-27 22:31:47 -07:00
|
|
|
|
2014-07-01 14:50:24 -07:00
|
|
|
fmt.Printf("%s%v:%v\n", indentPrefix, node.key, node.height)
|
2014-05-27 22:31:47 -07:00
|
|
|
|
2014-10-06 01:46:39 -07:00
|
|
|
if node.leftNode != nil {
|
|
|
|
printIAVLNode(node.leftNode, indent+1)
|
2014-10-06 00:15:37 -07:00
|
|
|
} else if node.leftHash != nil {
|
|
|
|
fmt.Printf("%s %X\n", indentPrefix, node.leftHash)
|
2014-07-01 14:50:24 -07:00
|
|
|
}
|
2014-05-27 22:31:47 -07:00
|
|
|
|
2014-05-20 16:33:10 -07:00
|
|
|
}
|
2014-05-23 17:49:28 -07:00
|
|
|
|
2015-06-25 20:28:34 -07:00
|
|
|
func maxInt8(a, b int8) int8 {
|
2014-07-01 14:50:24 -07:00
|
|
|
if a > b {
|
|
|
|
return a
|
|
|
|
}
|
|
|
|
return b
|
2014-05-23 23:11:22 -07:00
|
|
|
}
|