Class: Bitcoin::MerkleTree::Node
Overview
node of merkle tree
Instance Attribute Summary collapse
-
#flag ⇒ Object
Returns the value of attribute flag.
-
#left ⇒ Object
Returns the value of attribute left.
-
#parent ⇒ Object
Returns the value of attribute parent.
-
#right ⇒ Object
Returns the value of attribute right.
-
#value ⇒ Object
Returns the value of attribute value.
Instance Method Summary collapse
-
#depth ⇒ Object
calculate the depth of this node in the tree.
-
#find_node(target) ⇒ Object
Node which has same value as target.
- #index ⇒ Object
-
#initialize(value = nil) ⇒ Node
constructor
A new instance of Node.
- #leaf? ⇒ Boolean
- #next_partial ⇒ Object
- #partial? ⇒ Boolean
- #root? ⇒ Boolean
Constructor Details
#initialize(value = nil) ⇒ Node
Returns a new instance of Node.
73 74 75 |
# File 'lib/bitcoin/merkle_tree.rb', line 73 def initialize(value = nil) @value = value end |
Instance Attribute Details
#flag ⇒ Object
Returns the value of attribute flag.
67 68 69 |
# File 'lib/bitcoin/merkle_tree.rb', line 67 def flag @flag end |
#left ⇒ Object
Returns the value of attribute left.
70 71 72 |
# File 'lib/bitcoin/merkle_tree.rb', line 70 def left @left end |
#parent ⇒ Object
Returns the value of attribute parent.
69 70 71 |
# File 'lib/bitcoin/merkle_tree.rb', line 69 def parent @parent end |
#right ⇒ Object
Returns the value of attribute right.
71 72 73 |
# File 'lib/bitcoin/merkle_tree.rb', line 71 def right @right end |
#value ⇒ Object
Returns the value of attribute value.
68 69 70 |
# File 'lib/bitcoin/merkle_tree.rb', line 68 def value @value end |
Instance Method Details
#depth ⇒ Object
calculate the depth of this node in the tree.
114 115 116 117 118 119 120 121 122 |
# File 'lib/bitcoin/merkle_tree.rb', line 114 def depth d = 0 current_node = self until current_node.root? do current_node = current_node.parent d += 1 end d end |
#find_node(target) ⇒ Object
Returns node which has same value as target. nil if this node and any children don’t have same value.
126 127 128 129 130 |
# File 'lib/bitcoin/merkle_tree.rb', line 126 def find_node(target) return self if value == target return nil if flag && flag.zero? return left&.find_node(target) || right&.find_node(target) end |
#index ⇒ Object
132 133 134 135 136 137 138 139 140 141 142 |
# File 'lib/bitcoin/merkle_tree.rb', line 132 def index i = 0 d = 1 current_node = self until current_node.root? do i += d if current_node.parent.right == current_node current_node = current_node.parent d *= 2 end i end |
#leaf? ⇒ Boolean
97 98 99 |
# File 'lib/bitcoin/merkle_tree.rb', line 97 def leaf? right.nil? && left.nil? end |
#next_partial ⇒ Object
105 106 107 108 109 110 111 |
# File 'lib/bitcoin/merkle_tree.rb', line 105 def next_partial return nil if root? && (flag.zero? || (left.partial? && right.partial?)) return parent.next_partial if flag.zero? || leaf? return left unless left.partial? self.right = left.dup unless right right.partial? ? parent.next_partial : right end |
#partial? ⇒ Boolean
101 102 103 |
# File 'lib/bitcoin/merkle_tree.rb', line 101 def partial? !flag.nil? end |
#root? ⇒ Boolean
93 94 95 |
# File 'lib/bitcoin/merkle_tree.rb', line 93 def root? parent.nil? end |