mirror of
https://github.com/seigler/dash-docs
synced 2025-07-27 17:56:16 +00:00
615 lines
30 KiB
HTML
615 lines
30 KiB
HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
<meta name="generator" content="Doxygen 1.8.14"/>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1"/>
|
|
<title>Dash Core: CPartialMerkleTree Class Reference</title>
|
|
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="jquery.js"></script>
|
|
<script type="text/javascript" src="dynsections.js"></script>
|
|
<link href="navtree.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="resize.js"></script>
|
|
<script type="text/javascript" src="navtreedata.js"></script>
|
|
<script type="text/javascript" src="navtree.js"></script>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
$(document).ready(initResizable);
|
|
/* @license-end */</script>
|
|
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
<script type="text/javascript" src="search/search.js"></script>
|
|
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
</head>
|
|
<body>
|
|
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
<div id="titlearea">
|
|
<table cellspacing="0" cellpadding="0">
|
|
<tbody>
|
|
<tr style="height: 56px;">
|
|
<td id="projectlogo"><img alt="Logo" src="bitcoin_logo_doxygen.png"/></td>
|
|
<td id="projectalign" style="padding-left: 0.5em;">
|
|
<div id="projectname">Dash Core
|
|
 <span id="projectnumber">0.12.2.1</span>
|
|
</div>
|
|
<div id="projectbrief">P2P Digital Currency</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<!-- end header part -->
|
|
<!-- Generated by Doxygen 1.8.14 -->
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
var searchBox = new SearchBox("searchBox", "search",false,'Search');
|
|
/* @license-end */
|
|
</script>
|
|
<script type="text/javascript" src="menudata.js"></script>
|
|
<script type="text/javascript" src="menu.js"></script>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
$(function() {
|
|
initMenu('',true,false,'search.php','Search');
|
|
$(document).ready(function() { init_search(); });
|
|
});
|
|
/* @license-end */</script>
|
|
<div id="main-nav"></div>
|
|
</div><!-- top -->
|
|
<div id="side-nav" class="ui-resizable side-nav-resizable">
|
|
<div id="nav-tree">
|
|
<div id="nav-tree-contents">
|
|
<div id="nav-sync" class="sync"></div>
|
|
</div>
|
|
</div>
|
|
<div id="splitbar" style="-moz-user-select:none;"
|
|
class="ui-resizable-handle">
|
|
</div>
|
|
</div>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
$(document).ready(function(){initNavTree('classCPartialMerkleTree.html','');});
|
|
/* @license-end */
|
|
</script>
|
|
<div id="doc-content">
|
|
<!-- window showing the filter options -->
|
|
<div id="MSearchSelectWindow"
|
|
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
</div>
|
|
|
|
<!-- iframe showing the search results (closed by default) -->
|
|
<div id="MSearchResultsWindow">
|
|
<iframe src="javascript:void(0)" frameborder="0"
|
|
name="MSearchResults" id="MSearchResults">
|
|
</iframe>
|
|
</div>
|
|
|
|
<div class="header">
|
|
<div class="summary">
|
|
<a href="#pub-methods">Public Member Functions</a> |
|
|
<a href="#pub-attribs">Public Attributes</a> |
|
|
<a href="#pro-methods">Protected Member Functions</a> |
|
|
<a href="#pro-attribs">Protected Attributes</a> |
|
|
<a href="classCPartialMerkleTree-members.html">List of all members</a> </div>
|
|
<div class="headertitle">
|
|
<div class="title">CPartialMerkleTree Class Reference</div> </div>
|
|
</div><!--header-->
|
|
<div class="contents">
|
|
|
|
<p><code>#include <<a class="el" href="merkleblock_8h_source.html">merkleblock.h</a>></code></p>
|
|
<table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
|
|
Public Member Functions</h2></td></tr>
|
|
<tr class="memitem:a44903b156e6c77f3ef977324b24daf1f"><td class="memTemplParams" colspan="2">template<typename Stream , typename Operation > </td></tr>
|
|
<tr class="memitem:a44903b156e6c77f3ef977324b24daf1f"><td class="memTemplItemLeft" align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a44903b156e6c77f3ef977324b24daf1f">SerializationOp</a> (Stream &s, Operation ser_action, int nType, int nVersion)</td></tr>
|
|
<tr class="separator:a44903b156e6c77f3ef977324b24daf1f"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a0656767dc0d8f3d603c54e5be21d3890"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a0656767dc0d8f3d603c54e5be21d3890">CPartialMerkleTree</a> (const std::vector< <a class="el" href="classuint256.html">uint256</a> > &vTxid, const std::vector< bool > &vMatch)</td></tr>
|
|
<tr class="separator:a0656767dc0d8f3d603c54e5be21d3890"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aad4948ace869c92614310846f9d9980d"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#aad4948ace869c92614310846f9d9980d">CPartialMerkleTree</a> ()</td></tr>
|
|
<tr class="separator:aad4948ace869c92614310846f9d9980d"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a28c3456d1159b33b6c2689ac88eb56ad"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classuint256.html">uint256</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a28c3456d1159b33b6c2689ac88eb56ad">ExtractMatches</a> (std::vector< <a class="el" href="classuint256.html">uint256</a> > &vMatch)</td></tr>
|
|
<tr class="separator:a28c3456d1159b33b6c2689ac88eb56ad"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table><table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-attribs"></a>
|
|
Public Attributes</h2></td></tr>
|
|
<tr class="memitem:ae218db8103edb6672fe0d642535c7490"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#ae218db8103edb6672fe0d642535c7490">ADD_SERIALIZE_METHODS</a></td></tr>
|
|
<tr class="separator:ae218db8103edb6672fe0d642535c7490"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table><table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pro-methods"></a>
|
|
Protected Member Functions</h2></td></tr>
|
|
<tr class="memitem:a7dd0288d62321fb5aa2c27a3372ee8fe"><td class="memItemLeft" align="right" valign="top">unsigned int </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a7dd0288d62321fb5aa2c27a3372ee8fe">CalcTreeWidth</a> (int height)</td></tr>
|
|
<tr class="separator:a7dd0288d62321fb5aa2c27a3372ee8fe"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a69e7771f95c498f6a340dcc227abcde4"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classuint256.html">uint256</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a69e7771f95c498f6a340dcc227abcde4">CalcHash</a> (int height, unsigned int pos, const std::vector< <a class="el" href="classuint256.html">uint256</a> > &vTxid)</td></tr>
|
|
<tr class="separator:a69e7771f95c498f6a340dcc227abcde4"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a62bdcaf5b5ee6c6327ef67fb027a5fef"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a62bdcaf5b5ee6c6327ef67fb027a5fef">TraverseAndBuild</a> (int height, unsigned int pos, const std::vector< <a class="el" href="classuint256.html">uint256</a> > &vTxid, const std::vector< bool > &vMatch)</td></tr>
|
|
<tr class="separator:a62bdcaf5b5ee6c6327ef67fb027a5fef"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a3ddbe75a92d93059c30f6e60bacc7054"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classuint256.html">uint256</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a3ddbe75a92d93059c30f6e60bacc7054">TraverseAndExtract</a> (int height, unsigned int pos, unsigned int &nBitsUsed, unsigned int &nHashUsed, std::vector< <a class="el" href="classuint256.html">uint256</a> > &vMatch)</td></tr>
|
|
<tr class="separator:a3ddbe75a92d93059c30f6e60bacc7054"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table><table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pro-attribs"></a>
|
|
Protected Attributes</h2></td></tr>
|
|
<tr class="memitem:a0d3bd530f19f2c75c140a05c6f99782a"><td class="memItemLeft" align="right" valign="top">unsigned int </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a0d3bd530f19f2c75c140a05c6f99782a">nTransactions</a></td></tr>
|
|
<tr class="separator:a0d3bd530f19f2c75c140a05c6f99782a"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a22a522d1fb8d449f4c91b65283339e7d"><td class="memItemLeft" align="right" valign="top">std::vector< bool > </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a22a522d1fb8d449f4c91b65283339e7d">vBits</a></td></tr>
|
|
<tr class="separator:a22a522d1fb8d449f4c91b65283339e7d"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a863cf9024be1b8fa97db08dfd6dbd687"><td class="memItemLeft" align="right" valign="top">std::vector< <a class="el" href="classuint256.html">uint256</a> > </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a863cf9024be1b8fa97db08dfd6dbd687">vHash</a></td></tr>
|
|
<tr class="separator:a863cf9024be1b8fa97db08dfd6dbd687"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a24bb0d9d17d6001dcfbca4d550c64ba3"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classCPartialMerkleTree.html#a24bb0d9d17d6001dcfbca4d550c64ba3">fBad</a></td></tr>
|
|
<tr class="separator:a24bb0d9d17d6001dcfbca4d550c64ba3"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table>
|
|
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
|
|
<div class="textblock"><p>Data structure that represents a partial merkle tree.</p>
|
|
<p>It represents a subset of the txid's of a known block, in a way that allows recovery of the list of txid's and the merkle root, in an authenticated way.</p>
|
|
<p>The encoding works as follows: we traverse the tree in depth-first order, storing a bit for each traversed node, signifying whether the node is the parent of at least one matched leaf txid (or a matched txid itself). In case we are at the leaf level, or this bit is 0, its merkle node hash is stored, and its children are not explorer further. Otherwise, no hash is stored, but we recurse into both (or the only) child branch. During decoding, the same depth-first traversal is performed, consuming bits and hashes as they written during encoding.</p>
|
|
<p>The serialization is fixed and provides a hard guarantee about the encoded size:</p>
|
|
<p>SIZE <= 10 + ceil(32.25*N)</p>
|
|
<p>Where N represents the number of leaf nodes of the partial tree. N itself is bounded by:</p>
|
|
<p>N <= total_transactions N <= 1 + matched_transactions*tree_height</p>
|
|
<p>The serialization format:</p><ul>
|
|
<li>uint32 total_transactions (4 bytes)</li>
|
|
<li>varint number of hashes (1-3 bytes)</li>
|
|
<li><a class="el" href="classuint256.html">uint256</a>[] hashes in depth-first order (<= 32*N bytes)</li>
|
|
<li>varint number of bytes of flag bits (1-3 bytes)</li>
|
|
<li>byte[] flag bits, packed per 8 in a byte, least significant bit first (<= 2*N-1 bits) The size constraints follow from this. </li>
|
|
</ul>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8h_source.html#l00050">50</a> of file <a class="el" href="merkleblock_8h_source.html">merkleblock.h</a>.</p>
|
|
</div><h2 class="groupheader">Constructor & Destructor Documentation</h2>
|
|
<a id="a0656767dc0d8f3d603c54e5be21d3890"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a0656767dc0d8f3d603c54e5be21d3890">◆ </a></span>CPartialMerkleTree() <span class="overload">[1/2]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">CPartialMerkleTree::CPartialMerkleTree </td>
|
|
<td>(</td>
|
|
<td class="paramtype">const std::vector< <a class="el" href="classuint256.html">uint256</a> > & </td>
|
|
<td class="paramname"><em>vTxid</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const std::vector< bool > & </td>
|
|
<td class="paramname"><em>vMatch</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>Construct a partial merkle tree from a list of transaction ids, and a mask that selects a subset of them </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8cpp_source.html#l00134">134</a> of file <a class="el" href="merkleblock_8cpp_source.html">merkleblock.cpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="aad4948ace869c92614310846f9d9980d"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#aad4948ace869c92614310846f9d9980d">◆ </a></span>CPartialMerkleTree() <span class="overload">[2/2]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">CPartialMerkleTree::CPartialMerkleTree </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8cpp_source.html#l00148">148</a> of file <a class="el" href="merkleblock_8cpp_source.html">merkleblock.cpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<h2 class="groupheader">Member Function Documentation</h2>
|
|
<a id="a69e7771f95c498f6a340dcc227abcde4"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a69e7771f95c498f6a340dcc227abcde4">◆ </a></span>CalcHash()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classuint256.html">uint256</a> CPartialMerkleTree::CalcHash </td>
|
|
<td>(</td>
|
|
<td class="paramtype">int </td>
|
|
<td class="paramname"><em>height</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int </td>
|
|
<td class="paramname"><em>pos</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const std::vector< <a class="el" href="classuint256.html">uint256</a> > & </td>
|
|
<td class="paramname"><em>vTxid</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>calculate the hash of a node in the merkle tree (at leaf level: the txid's themselves) </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8cpp_source.html#l00063">63</a> of file <a class="el" href="merkleblock_8cpp_source.html">merkleblock.cpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a7dd0288d62321fb5aa2c27a3372ee8fe"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a7dd0288d62321fb5aa2c27a3372ee8fe">◆ </a></span>CalcTreeWidth()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">unsigned int CPartialMerkleTree::CalcTreeWidth </td>
|
|
<td>(</td>
|
|
<td class="paramtype">int </td>
|
|
<td class="paramname"><em>height</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">protected</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>helper function to efficiently calculate the number of nodes at given height in the merkle tree </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8h_source.html#l00066">66</a> of file <a class="el" href="merkleblock_8h_source.html">merkleblock.h</a>.</p>
|
|
|
|
<p class="reference">Referenced by <a class="el" href="merkleblock_8cpp_source.html#l00134">CPartialMerkleTree()</a>, and <a class="el" href="merkleblock_8cpp_source.html#l00150">ExtractMatches()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a28c3456d1159b33b6c2689ac88eb56ad"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a28c3456d1159b33b6c2689ac88eb56ad">◆ </a></span>ExtractMatches()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classuint256.html">uint256</a> CPartialMerkleTree::ExtractMatches </td>
|
|
<td>(</td>
|
|
<td class="paramtype">std::vector< <a class="el" href="classuint256.html">uint256</a> > & </td>
|
|
<td class="paramname"><em>vMatch</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>extract the matching txid's represented by this partial merkle tree. returns the merkle root, or 0 in case of failure </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8cpp_source.html#l00150">150</a> of file <a class="el" href="merkleblock_8cpp_source.html">merkleblock.cpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a44903b156e6c77f3ef977324b24daf1f"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a44903b156e6c77f3ef977324b24daf1f">◆ </a></span>SerializationOp()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<typename Stream , typename Operation > </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void CPartialMerkleTree::SerializationOp </td>
|
|
<td>(</td>
|
|
<td class="paramtype">Stream & </td>
|
|
<td class="paramname"><em>s</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">Operation </td>
|
|
<td class="paramname"><em>ser_action</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">int </td>
|
|
<td class="paramname"><em>nType</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">int </td>
|
|
<td class="paramname"><em>nVersion</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8h_source.html#l00088">88</a> of file <a class="el" href="merkleblock_8h_source.html">merkleblock.h</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a62bdcaf5b5ee6c6327ef67fb027a5fef"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a62bdcaf5b5ee6c6327ef67fb027a5fef">◆ </a></span>TraverseAndBuild()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void CPartialMerkleTree::TraverseAndBuild </td>
|
|
<td>(</td>
|
|
<td class="paramtype">int </td>
|
|
<td class="paramname"><em>height</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int </td>
|
|
<td class="paramname"><em>pos</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const std::vector< <a class="el" href="classuint256.html">uint256</a> > & </td>
|
|
<td class="paramname"><em>vTxid</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const std::vector< bool > & </td>
|
|
<td class="paramname"><em>vMatch</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>recursive function that traverses tree nodes, storing the data as bits and hashes </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8cpp_source.html#l00080">80</a> of file <a class="el" href="merkleblock_8cpp_source.html">merkleblock.cpp</a>.</p>
|
|
|
|
<p class="reference">Referenced by <a class="el" href="merkleblock_8cpp_source.html#l00134">CPartialMerkleTree()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a3ddbe75a92d93059c30f6e60bacc7054"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a3ddbe75a92d93059c30f6e60bacc7054">◆ </a></span>TraverseAndExtract()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classuint256.html">uint256</a> CPartialMerkleTree::TraverseAndExtract </td>
|
|
<td>(</td>
|
|
<td class="paramtype">int </td>
|
|
<td class="paramname"><em>height</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int </td>
|
|
<td class="paramname"><em>pos</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int & </td>
|
|
<td class="paramname"><em>nBitsUsed</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int & </td>
|
|
<td class="paramname"><em>nHashUsed</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">std::vector< <a class="el" href="classuint256.html">uint256</a> > & </td>
|
|
<td class="paramname"><em>vMatch</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>recursive function that traverses tree nodes, consuming the bits and hashes produced by TraverseAndBuild. it returns the hash of the respective node. </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8cpp_source.html#l00098">98</a> of file <a class="el" href="merkleblock_8cpp_source.html">merkleblock.cpp</a>.</p>
|
|
|
|
<p class="reference">Referenced by <a class="el" href="merkleblock_8cpp_source.html#l00150">ExtractMatches()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<h2 class="groupheader">Member Data Documentation</h2>
|
|
<a id="ae218db8103edb6672fe0d642535c7490"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#ae218db8103edb6672fe0d642535c7490">◆ </a></span>ADD_SERIALIZE_METHODS</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">CPartialMerkleTree::ADD_SERIALIZE_METHODS</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>serialization implementation </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8h_source.html#l00085">85</a> of file <a class="el" href="merkleblock_8h_source.html">merkleblock.h</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a24bb0d9d17d6001dcfbca4d550c64ba3"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a24bb0d9d17d6001dcfbca4d550c64ba3">◆ </a></span>fBad</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">bool CPartialMerkleTree::fBad</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>flag set when encountering invalid data </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8h_source.html#l00063">63</a> of file <a class="el" href="merkleblock_8h_source.html">merkleblock.h</a>.</p>
|
|
|
|
<p class="reference">Referenced by <a class="el" href="merkleblock_8cpp_source.html#l00150">ExtractMatches()</a>, and <a class="el" href="merkleblock_8h_source.html#l00088">SerializationOp()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a0d3bd530f19f2c75c140a05c6f99782a"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a0d3bd530f19f2c75c140a05c6f99782a">◆ </a></span>nTransactions</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">unsigned int CPartialMerkleTree::nTransactions</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>the total number of transactions in the block </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8h_source.html#l00054">54</a> of file <a class="el" href="merkleblock_8h_source.html">merkleblock.h</a>.</p>
|
|
|
|
<p class="reference">Referenced by <a class="el" href="merkleblock_8h_source.html#l00066">CalcTreeWidth()</a>, <a class="el" href="merkleblock_8cpp_source.html#l00150">ExtractMatches()</a>, and <a class="el" href="merkleblock_8h_source.html#l00088">SerializationOp()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a22a522d1fb8d449f4c91b65283339e7d"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a22a522d1fb8d449f4c91b65283339e7d">◆ </a></span>vBits</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">std::vector<bool> CPartialMerkleTree::vBits</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>node-is-parent-of-matched-txid bits </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8h_source.html#l00057">57</a> of file <a class="el" href="merkleblock_8h_source.html">merkleblock.h</a>.</p>
|
|
|
|
<p class="reference">Referenced by <a class="el" href="merkleblock_8cpp_source.html#l00134">CPartialMerkleTree()</a>, <a class="el" href="merkleblock_8cpp_source.html#l00150">ExtractMatches()</a>, and <a class="el" href="merkleblock_8h_source.html#l00088">SerializationOp()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a863cf9024be1b8fa97db08dfd6dbd687"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a863cf9024be1b8fa97db08dfd6dbd687">◆ </a></span>vHash</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">std::vector<<a class="el" href="classuint256.html">uint256</a>> CPartialMerkleTree::vHash</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>txids and internal hashes </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="merkleblock_8h_source.html#l00060">60</a> of file <a class="el" href="merkleblock_8h_source.html">merkleblock.h</a>.</p>
|
|
|
|
<p class="reference">Referenced by <a class="el" href="merkleblock_8cpp_source.html#l00134">CPartialMerkleTree()</a>, <a class="el" href="merkleblock_8cpp_source.html#l00150">ExtractMatches()</a>, and <a class="el" href="merkleblock_8h_source.html#l00088">SerializationOp()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<hr/>The documentation for this class was generated from the following files:<ul>
|
|
<li>src/<a class="el" href="merkleblock_8h_source.html">merkleblock.h</a></li>
|
|
<li>src/<a class="el" href="merkleblock_8cpp_source.html">merkleblock.cpp</a></li>
|
|
</ul>
|
|
</div><!-- contents -->
|
|
</div><!-- doc-content -->
|
|
<!-- start footer part -->
|
|
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
|
|
<ul>
|
|
<li class="navelem"><a class="el" href="classCPartialMerkleTree.html">CPartialMerkleTree</a></li>
|
|
<li class="footer">Generated on Thu Dec 14 2017 13:15:12 for Dash Core by
|
|
<a href="http://www.doxygen.org/index.html">
|
|
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.14 </li>
|
|
</ul>
|
|
</div>
|
|
</body>
|
|
</html>
|