This commit is contained in:
seelabs
2021-11-19 13:45:43 +00:00
parent e4e2fce0b3
commit ef77e7e117
3534 changed files with 54687 additions and 52679 deletions

View File

@@ -102,96 +102,97 @@ $(function() {
<div class="line"><a name="l00031"></a><span class="lineno"> 31</span>&#160; , fbCache_(<a class="code" href="namespacestd.html">std</a>::make_shared&lt;<a class="code" href="classripple_1_1detail_1_1BasicFullBelowCache.html">FullBelowCache</a>&gt;(</div>
<div class="line"><a name="l00032"></a><span class="lineno"> 32</span>&#160; <span class="stringliteral">&quot;Node family full below cache&quot;</span>,</div>
<div class="line"><a name="l00033"></a><span class="lineno"> 33</span>&#160; <a class="code" href="namespaceripple.html#ac70521ab6e1277870a9e400e7a08e937">stopwatch</a>(),</div>
<div class="line"><a name="l00034"></a><span class="lineno"> 34</span>&#160; cm.collector(),</div>
<div class="line"><a name="l00035"></a><span class="lineno"> 35</span>&#160; <a class="code" href="namespaceripple.html#aef07fa1142a7973847f45894ad5f9ebf">fullBelowTargetSize</a>,</div>
<div class="line"><a name="l00036"></a><span class="lineno"> 36</span>&#160; <a class="code" href="namespaceripple.html#a5c370593e8a1e99cb6e68c961339143d">fullBelowExpiration</a>))</div>
<div class="line"><a name="l00037"></a><span class="lineno"> 37</span>&#160; , tnCache_(<a class="code" href="namespacestd.html">std</a>::make_shared&lt;<a class="code" href="classripple_1_1TaggedCache.html">TreeNodeCache</a>&gt;(</div>
<div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160; <span class="stringliteral">&quot;Node family tree node cache&quot;</span>,</div>
<div class="line"><a name="l00039"></a><span class="lineno"> 39</span>&#160; app.config().getValueFor(<a class="code" href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcb">SizedItem</a>::<a class="code" href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcbad8fa646add8fc293b385aafc538e896e">treeCacheSize</a>),</div>
<div class="line"><a name="l00040"></a><span class="lineno"> 40</span>&#160; <a class="code" href="namespacestd.html">std</a>::chrono::seconds(</div>
<div class="line"><a name="l00041"></a><span class="lineno"> 41</span>&#160; app.config().getValueFor(<a class="code" href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcb">SizedItem</a>::<a class="code" href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcbab4f2ec48d846301c36ab8824e62fde66">treeCacheAge</a>)),</div>
<div class="line"><a name="l00042"></a><span class="lineno"> 42</span>&#160; <a class="code" href="namespaceripple.html#ac70521ab6e1277870a9e400e7a08e937">stopwatch</a>(),</div>
<div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160; j_))</div>
<div class="line"><a name="l00044"></a><span class="lineno"> 44</span>&#160;{</div>
<div class="line"><a name="l00045"></a><span class="lineno"> 45</span>&#160;}</div>
<div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160; </div>
<div class="line"><a name="l00047"></a><span class="lineno"> 47</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00048"></a><span class="lineno"><a class="line" href="classripple_1_1NodeFamily.html#a656e8cb2fa08a2f5549c9b42228b5d57"> 48</a></span>&#160;<a class="code" href="classripple_1_1NodeFamily.html#a656e8cb2fa08a2f5549c9b42228b5d57">NodeFamily::sweep</a>()</div>
<div class="line"><a name="l00049"></a><span class="lineno"> 49</span>&#160;{</div>
<div class="line"><a name="l00050"></a><span class="lineno"> 50</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a79d99eed7c458981a1f535af6d0b1531">fbCache_</a>-&gt;sweep();</div>
<div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a65159b09901f85cf031b27383708187a">tnCache_</a>-&gt;sweep();</div>
<div class="line"><a name="l00052"></a><span class="lineno"> 52</span>&#160;}</div>
<div class="line"><a name="l00053"></a><span class="lineno"> 53</span>&#160; </div>
<div class="line"><a name="l00054"></a><span class="lineno"> 54</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00055"></a><span class="lineno"><a class="line" href="classripple_1_1NodeFamily.html#acd15a63c12f9d7bfd363ef35707171da"> 55</a></span>&#160;<a class="code" href="classripple_1_1NodeFamily.html#acd15a63c12f9d7bfd363ef35707171da">NodeFamily::reset</a>()</div>
<div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160;{</div>
<div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160; {</div>
<div class="line"><a name="l00058"></a><span class="lineno"> 58</span>&#160; <a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/lock_guard.html">std::lock_guard</a> lock(<a class="code" href="classripple_1_1NodeFamily.html#acc158cf12dc02f60d4207fba066152e9">maxSeqMutex_</a>);</div>
<div class="line"><a name="l00059"></a><span class="lineno"> 59</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> = 0;</div>
<div class="line"><a name="l00060"></a><span class="lineno"> 60</span>&#160; }</div>
<div class="line"><a name="l00061"></a><span class="lineno"> 61</span>&#160; </div>
<div class="line"><a name="l00062"></a><span class="lineno"> 62</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a79d99eed7c458981a1f535af6d0b1531">fbCache_</a>-&gt;reset();</div>
<div class="line"><a name="l00063"></a><span class="lineno"> 63</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a65159b09901f85cf031b27383708187a">tnCache_</a>-&gt;reset();</div>
<div class="line"><a name="l00064"></a><span class="lineno"> 64</span>&#160;}</div>
<div class="line"><a name="l00065"></a><span class="lineno"> 65</span>&#160; </div>
<div class="line"><a name="l00066"></a><span class="lineno"> 66</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00067"></a><span class="lineno"><a class="line" href="classripple_1_1NodeFamily.html#ae28638a42e0a37921b85da75d6d73ba3"> 67</a></span>&#160;<a class="code" href="classripple_1_1NodeFamily.html#ae28638a42e0a37921b85da75d6d73ba3">NodeFamily::missingNode</a>(<a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">std::uint32_t</a> seq)</div>
<div class="line"><a name="l00068"></a><span class="lineno"> 68</span>&#160;{</div>
<div class="line"><a name="l00069"></a><span class="lineno"> 69</span>&#160; JLOG(<a class="code" href="classripple_1_1NodeFamily.html#ac5217d806641ec88676fd00cbca56386">j_</a>.<a class="code" href="classbeast_1_1Journal.html#a49b0713e65bb8e2c51b76fbf16252afe">error</a>()) &lt;&lt; <span class="stringliteral">&quot;Missing node in &quot;</span> &lt;&lt; seq;</div>
<div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160; </div>
<div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160; <a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/unique_lock.html">std::unique_lock&lt;std::mutex&gt;</a> lock(<a class="code" href="classripple_1_1NodeFamily.html#acc158cf12dc02f60d4207fba066152e9">maxSeqMutex_</a>);</div>
<div class="line"><a name="l00072"></a><span class="lineno"> 72</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> == 0)</div>
<div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160; {</div>
<div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> = seq;</div>
<div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160; </div>
<div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160; <span class="keywordflow">do</span></div>
<div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160; {</div>
<div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; <span class="comment">// Try to acquire the most recent missing ledger</span></div>
<div class="line"><a name="l00079"></a><span class="lineno"> 79</span>&#160; seq = <a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a>;</div>
<div class="line"><a name="l00080"></a><span class="lineno"> 80</span>&#160; </div>
<div class="line"><a name="l00081"></a><span class="lineno"> 81</span>&#160; lock.unlock();</div>
<div class="line"><a name="l00082"></a><span class="lineno"> 82</span>&#160; </div>
<div class="line"><a name="l00083"></a><span class="lineno"> 83</span>&#160; <span class="comment">// This can invoke the missing node handler</span></div>
<div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a7599daa25d6d2fd8ee537e8396f381c4">acquire</a>(<a class="code" href="classripple_1_1NodeFamily.html#ab62b56575e85ed3f0fb7dc81f779a1f0">app_</a>.<a class="code" href="classripple_1_1Application.html#a57929fa83c551514e364fe6981b0c104">getLedgerMaster</a>().<a class="code" href="classripple_1_1LedgerMaster.html#a4f59228c74d5491f68333ef250431cdb">getHashBySeq</a>(seq), seq);</div>
<div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160; </div>
<div class="line"><a name="l00086"></a><span class="lineno"> 86</span>&#160; lock.lock();</div>
<div class="line"><a name="l00087"></a><span class="lineno"> 87</span>&#160; } <span class="keywordflow">while</span> (<a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> != seq);</div>
<div class="line"><a name="l00088"></a><span class="lineno"> 88</span>&#160; }</div>
<div class="line"><a name="l00089"></a><span class="lineno"> 89</span>&#160; <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> &lt; seq)</div>
<div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160; {</div>
<div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160; <span class="comment">// We found a more recent ledger with a missing node</span></div>
<div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> = seq;</div>
<div class="line"><a name="l00093"></a><span class="lineno"> 93</span>&#160; }</div>
<div class="line"><a name="l00094"></a><span class="lineno"> 94</span>&#160;}</div>
<div class="line"><a name="l00095"></a><span class="lineno"> 95</span>&#160; </div>
<div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00097"></a><span class="lineno"><a class="line" href="classripple_1_1NodeFamily.html#a7599daa25d6d2fd8ee537e8396f381c4"> 97</a></span>&#160;<a class="code" href="classripple_1_1NodeFamily.html#a7599daa25d6d2fd8ee537e8396f381c4">NodeFamily::acquire</a>(<a class="code" href="classripple_1_1base__uint.html">uint256</a> <span class="keyword">const</span>&amp; hash, <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">std::uint32_t</a> seq)</div>
<div class="line"><a name="l00098"></a><span class="lineno"> 98</span>&#160;{</div>
<div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160; <span class="keywordflow">if</span> (hash.<a class="code" href="classripple_1_1base__uint.html#ad2bffc75e554b89befbb9388e07392c0">isNonZero</a>())</div>
<div class="line"><a name="l00100"></a><span class="lineno"> 100</span>&#160; {</div>
<div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160; JLOG(<a class="code" href="classripple_1_1NodeFamily.html#ac5217d806641ec88676fd00cbca56386">j_</a>.<a class="code" href="classbeast_1_1Journal.html#a49b0713e65bb8e2c51b76fbf16252afe">error</a>()) &lt;&lt; <span class="stringliteral">&quot;Missing node in &quot;</span> &lt;&lt; <a class="code" href="namespaceripple.html#af9776f187d3686a7fba4c2d2fbeebdf4">to_string</a>(hash);</div>
<div class="line"><a name="l00102"></a><span class="lineno"> 102</span>&#160; </div>
<div class="line"><a name="l00103"></a><span class="lineno"> 103</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#ab62b56575e85ed3f0fb7dc81f779a1f0">app_</a>.<a class="code" href="classripple_1_1Application.html#a6d349a4ada03689eae062c0399762dad">getInboundLedgers</a>().<a class="code" href="classripple_1_1InboundLedgers.html#ad346b5eb8ce7d749218ad3fb1ef45530">acquire</a>(</div>
<div class="line"><a name="l00104"></a><span class="lineno"> 104</span>&#160; hash, seq, <a class="code" href="classripple_1_1InboundLedger.html#a3e8d7f8b5fa089a184dcc9b00b6e0da7ac942dc2a9f958acddc67e11472d3ca0b">InboundLedger::Reason::GENERIC</a>);</div>
<div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160; }</div>
<div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160;}</div>
<div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160; </div>
<div class="line"><a name="l00108"></a><span class="lineno"> 108</span>&#160;} <span class="comment">// namespace ripple</span></div>
<div class="line"><a name="l00034"></a><span class="lineno"> 34</span>&#160; app.journal(<span class="stringliteral">&quot;NodeFamilyFulLBelowCache&quot;</span>),</div>
<div class="line"><a name="l00035"></a><span class="lineno"> 35</span>&#160; cm.collector(),</div>
<div class="line"><a name="l00036"></a><span class="lineno"> 36</span>&#160; <a class="code" href="namespaceripple.html#aef07fa1142a7973847f45894ad5f9ebf">fullBelowTargetSize</a>,</div>
<div class="line"><a name="l00037"></a><span class="lineno"> 37</span>&#160; <a class="code" href="namespaceripple.html#a5c370593e8a1e99cb6e68c961339143d">fullBelowExpiration</a>))</div>
<div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160; , tnCache_(<a class="code" href="namespacestd.html">std</a>::make_shared&lt;<a class="code" href="classripple_1_1TaggedCache.html">TreeNodeCache</a>&gt;(</div>
<div class="line"><a name="l00039"></a><span class="lineno"> 39</span>&#160; <span class="stringliteral">&quot;Node family tree node cache&quot;</span>,</div>
<div class="line"><a name="l00040"></a><span class="lineno"> 40</span>&#160; app.config().getValueFor(<a class="code" href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcb">SizedItem</a>::<a class="code" href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcbad8fa646add8fc293b385aafc538e896e">treeCacheSize</a>),</div>
<div class="line"><a name="l00041"></a><span class="lineno"> 41</span>&#160; <a class="code" href="namespacestd.html">std</a>::chrono::seconds(</div>
<div class="line"><a name="l00042"></a><span class="lineno"> 42</span>&#160; app.config().getValueFor(<a class="code" href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcb">SizedItem</a>::<a class="code" href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcbab4f2ec48d846301c36ab8824e62fde66">treeCacheAge</a>)),</div>
<div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160; <a class="code" href="namespaceripple.html#ac70521ab6e1277870a9e400e7a08e937">stopwatch</a>(),</div>
<div class="line"><a name="l00044"></a><span class="lineno"> 44</span>&#160; j_))</div>
<div class="line"><a name="l00045"></a><span class="lineno"> 45</span>&#160;{</div>
<div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160;}</div>
<div class="line"><a name="l00047"></a><span class="lineno"> 47</span>&#160; </div>
<div class="line"><a name="l00048"></a><span class="lineno"> 48</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00049"></a><span class="lineno"><a class="line" href="classripple_1_1NodeFamily.html#a656e8cb2fa08a2f5549c9b42228b5d57"> 49</a></span>&#160;<a class="code" href="classripple_1_1NodeFamily.html#a656e8cb2fa08a2f5549c9b42228b5d57">NodeFamily::sweep</a>()</div>
<div class="line"><a name="l00050"></a><span class="lineno"> 50</span>&#160;{</div>
<div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a79d99eed7c458981a1f535af6d0b1531">fbCache_</a>-&gt;sweep();</div>
<div class="line"><a name="l00052"></a><span class="lineno"> 52</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a65159b09901f85cf031b27383708187a">tnCache_</a>-&gt;sweep();</div>
<div class="line"><a name="l00053"></a><span class="lineno"> 53</span>&#160;}</div>
<div class="line"><a name="l00054"></a><span class="lineno"> 54</span>&#160; </div>
<div class="line"><a name="l00055"></a><span class="lineno"> 55</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00056"></a><span class="lineno"><a class="line" href="classripple_1_1NodeFamily.html#acd15a63c12f9d7bfd363ef35707171da"> 56</a></span>&#160;<a class="code" href="classripple_1_1NodeFamily.html#acd15a63c12f9d7bfd363ef35707171da">NodeFamily::reset</a>()</div>
<div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160;{</div>
<div class="line"><a name="l00058"></a><span class="lineno"> 58</span>&#160; {</div>
<div class="line"><a name="l00059"></a><span class="lineno"> 59</span>&#160; <a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/lock_guard.html">std::lock_guard</a> lock(<a class="code" href="classripple_1_1NodeFamily.html#acc158cf12dc02f60d4207fba066152e9">maxSeqMutex_</a>);</div>
<div class="line"><a name="l00060"></a><span class="lineno"> 60</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> = 0;</div>
<div class="line"><a name="l00061"></a><span class="lineno"> 61</span>&#160; }</div>
<div class="line"><a name="l00062"></a><span class="lineno"> 62</span>&#160; </div>
<div class="line"><a name="l00063"></a><span class="lineno"> 63</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a79d99eed7c458981a1f535af6d0b1531">fbCache_</a>-&gt;reset();</div>
<div class="line"><a name="l00064"></a><span class="lineno"> 64</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a65159b09901f85cf031b27383708187a">tnCache_</a>-&gt;reset();</div>
<div class="line"><a name="l00065"></a><span class="lineno"> 65</span>&#160;}</div>
<div class="line"><a name="l00066"></a><span class="lineno"> 66</span>&#160; </div>
<div class="line"><a name="l00067"></a><span class="lineno"> 67</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00068"></a><span class="lineno"><a class="line" href="classripple_1_1NodeFamily.html#ae28638a42e0a37921b85da75d6d73ba3"> 68</a></span>&#160;<a class="code" href="classripple_1_1NodeFamily.html#ae28638a42e0a37921b85da75d6d73ba3">NodeFamily::missingNode</a>(<a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">std::uint32_t</a> seq)</div>
<div class="line"><a name="l00069"></a><span class="lineno"> 69</span>&#160;{</div>
<div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160; JLOG(<a class="code" href="classripple_1_1NodeFamily.html#ac5217d806641ec88676fd00cbca56386">j_</a>.<a class="code" href="classbeast_1_1Journal.html#a49b0713e65bb8e2c51b76fbf16252afe">error</a>()) &lt;&lt; <span class="stringliteral">&quot;Missing node in &quot;</span> &lt;&lt; seq;</div>
<div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160; </div>
<div class="line"><a name="l00072"></a><span class="lineno"> 72</span>&#160; <a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/unique_lock.html">std::unique_lock&lt;std::mutex&gt;</a> lock(<a class="code" href="classripple_1_1NodeFamily.html#acc158cf12dc02f60d4207fba066152e9">maxSeqMutex_</a>);</div>
<div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> == 0)</div>
<div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160; {</div>
<div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> = seq;</div>
<div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160; </div>
<div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160; <span class="keywordflow">do</span></div>
<div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; {</div>
<div class="line"><a name="l00079"></a><span class="lineno"> 79</span>&#160; <span class="comment">// Try to acquire the most recent missing ledger</span></div>
<div class="line"><a name="l00080"></a><span class="lineno"> 80</span>&#160; seq = <a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a>;</div>
<div class="line"><a name="l00081"></a><span class="lineno"> 81</span>&#160; </div>
<div class="line"><a name="l00082"></a><span class="lineno"> 82</span>&#160; lock.unlock();</div>
<div class="line"><a name="l00083"></a><span class="lineno"> 83</span>&#160; </div>
<div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160; <span class="comment">// This can invoke the missing node handler</span></div>
<div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a7599daa25d6d2fd8ee537e8396f381c4">acquire</a>(<a class="code" href="classripple_1_1NodeFamily.html#ab62b56575e85ed3f0fb7dc81f779a1f0">app_</a>.<a class="code" href="classripple_1_1Application.html#a57929fa83c551514e364fe6981b0c104">getLedgerMaster</a>().<a class="code" href="classripple_1_1LedgerMaster.html#a4f59228c74d5491f68333ef250431cdb">getHashBySeq</a>(seq), seq);</div>
<div class="line"><a name="l00086"></a><span class="lineno"> 86</span>&#160; </div>
<div class="line"><a name="l00087"></a><span class="lineno"> 87</span>&#160; lock.lock();</div>
<div class="line"><a name="l00088"></a><span class="lineno"> 88</span>&#160; } <span class="keywordflow">while</span> (<a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> != seq);</div>
<div class="line"><a name="l00089"></a><span class="lineno"> 89</span>&#160; }</div>
<div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160; <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> &lt; seq)</div>
<div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160; {</div>
<div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160; <span class="comment">// We found a more recent ledger with a missing node</span></div>
<div class="line"><a name="l00093"></a><span class="lineno"> 93</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">maxSeq_</a> = seq;</div>
<div class="line"><a name="l00094"></a><span class="lineno"> 94</span>&#160; }</div>
<div class="line"><a name="l00095"></a><span class="lineno"> 95</span>&#160;}</div>
<div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160; </div>
<div class="line"><a name="l00097"></a><span class="lineno"> 97</span>&#160;<span class="keywordtype">void</span></div>
<div class="line"><a name="l00098"></a><span class="lineno"><a class="line" href="classripple_1_1NodeFamily.html#a7599daa25d6d2fd8ee537e8396f381c4"> 98</a></span>&#160;<a class="code" href="classripple_1_1NodeFamily.html#a7599daa25d6d2fd8ee537e8396f381c4">NodeFamily::acquire</a>(<a class="code" href="classripple_1_1base__uint.html">uint256</a> <span class="keyword">const</span>&amp; hash, <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">std::uint32_t</a> seq)</div>
<div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160;{</div>
<div class="line"><a name="l00100"></a><span class="lineno"> 100</span>&#160; <span class="keywordflow">if</span> (hash.<a class="code" href="classripple_1_1base__uint.html#ad2bffc75e554b89befbb9388e07392c0">isNonZero</a>())</div>
<div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160; {</div>
<div class="line"><a name="l00102"></a><span class="lineno"> 102</span>&#160; JLOG(<a class="code" href="classripple_1_1NodeFamily.html#ac5217d806641ec88676fd00cbca56386">j_</a>.<a class="code" href="classbeast_1_1Journal.html#a49b0713e65bb8e2c51b76fbf16252afe">error</a>()) &lt;&lt; <span class="stringliteral">&quot;Missing node in &quot;</span> &lt;&lt; <a class="code" href="namespaceripple.html#af9776f187d3686a7fba4c2d2fbeebdf4">to_string</a>(hash);</div>
<div class="line"><a name="l00103"></a><span class="lineno"> 103</span>&#160; </div>
<div class="line"><a name="l00104"></a><span class="lineno"> 104</span>&#160; <a class="code" href="classripple_1_1NodeFamily.html#ab62b56575e85ed3f0fb7dc81f779a1f0">app_</a>.<a class="code" href="classripple_1_1Application.html#a6d349a4ada03689eae062c0399762dad">getInboundLedgers</a>().<a class="code" href="classripple_1_1InboundLedgers.html#ad346b5eb8ce7d749218ad3fb1ef45530">acquire</a>(</div>
<div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160; hash, seq, <a class="code" href="classripple_1_1InboundLedger.html#a3e8d7f8b5fa089a184dcc9b00b6e0da7ac942dc2a9f958acddc67e11472d3ca0b">InboundLedger::Reason::GENERIC</a>);</div>
<div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160; }</div>
<div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160;}</div>
<div class="line"><a name="l00108"></a><span class="lineno"> 108</span>&#160; </div>
<div class="line"><a name="l00109"></a><span class="lineno"> 109</span>&#160;} <span class="comment">// namespace ripple</span></div>
</div><!-- fragment --></div><!-- contents -->
<div class="ttc" id="aclassripple_1_1Application_html"><div class="ttname"><a href="classripple_1_1Application.html">ripple::Application</a></div><div class="ttdef"><b>Definition:</b> <a href="Application_8h_source.html#l00103">Application.h:103</a></div></div>
<div class="ttc" id="aclassripple_1_1Application_html"><div class="ttname"><a href="classripple_1_1Application.html">ripple::Application</a></div><div class="ttdef"><b>Definition:</b> <a href="Application_8h_source.html#l00115">Application.h:115</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_ab62b56575e85ed3f0fb7dc81f779a1f0"><div class="ttname"><a href="classripple_1_1NodeFamily.html#ab62b56575e85ed3f0fb7dc81f779a1f0">ripple::NodeFamily::app_</a></div><div class="ttdeci">Application &amp; app_</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8h_source.html#l00095">NodeFamily.h:95</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_a656e8cb2fa08a2f5549c9b42228b5d57"><div class="ttname"><a href="classripple_1_1NodeFamily.html#a656e8cb2fa08a2f5549c9b42228b5d57">ripple::NodeFamily::sweep</a></div><div class="ttdeci">void sweep() override</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8cpp_source.html#l00048">NodeFamily.cpp:48</a></div></div>
<div class="ttc" id="aclassripple_1_1TaggedCache_html"><div class="ttname"><a href="classripple_1_1TaggedCache.html">ripple::TaggedCache</a></div><div class="ttdoc">Map/cache combination.</div><div class="ttdef"><b>Definition:</b> <a href="TaggedCache_8h_source.html#l00052">TaggedCache.h:52</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_a656e8cb2fa08a2f5549c9b42228b5d57"><div class="ttname"><a href="classripple_1_1NodeFamily.html#a656e8cb2fa08a2f5549c9b42228b5d57">ripple::NodeFamily::sweep</a></div><div class="ttdeci">void sweep() override</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8cpp_source.html#l00049">NodeFamily.cpp:49</a></div></div>
<div class="ttc" id="aclassripple_1_1TaggedCache_html"><div class="ttname"><a href="classripple_1_1TaggedCache.html">ripple::TaggedCache</a></div><div class="ttdoc">Map/cache combination.</div><div class="ttdef"><b>Definition:</b> <a href="Application_8h_source.html#l00063">Application.h:63</a></div></div>
<div class="ttc" id="anamespaceripple_html_a1b38e742ac7fe4c3a80a397e06b83dcb"><div class="ttname"><a href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcb">ripple::SizedItem</a></div><div class="ttdeci">SizedItem</div><div class="ttdef"><b>Definition:</b> <a href="Config_8h_source.html#l00048">Config.h:48</a></div></div>
<div class="ttc" id="aclassripple_1_1base__uint_html_ad2bffc75e554b89befbb9388e07392c0"><div class="ttname"><a href="classripple_1_1base__uint.html#ad2bffc75e554b89befbb9388e07392c0">ripple::base_uint::isNonZero</a></div><div class="ttdeci">bool isNonZero() const</div><div class="ttdef"><b>Definition:</b> <a href="base__uint_8h_source.html#l00516">base_uint.h:516</a></div></div>
<div class="ttc" id="aclassripple_1_1detail_1_1BasicFullBelowCache_html"><div class="ttname"><a href="classripple_1_1detail_1_1BasicFullBelowCache.html">ripple::detail::BasicFullBelowCache</a></div><div class="ttdoc">Remembers which tree keys have all descendants resident.</div><div class="ttdef"><b>Definition:</b> <a href="FullBelowCache_8h_source.html#l00037">FullBelowCache.h:37</a></div></div>
<div class="ttc" id="aclassripple_1_1detail_1_1BasicFullBelowCache_html"><div class="ttname"><a href="classripple_1_1detail_1_1BasicFullBelowCache.html">ripple::detail::BasicFullBelowCache</a></div><div class="ttdoc">Remembers which tree keys have all descendants resident.</div><div class="ttdef"><b>Definition:</b> <a href="FullBelowCache_8h_source.html#l00038">FullBelowCache.h:38</a></div></div>
<div class="ttc" id="aclassripple_1_1InboundLedger_html_a3e8d7f8b5fa089a184dcc9b00b6e0da7ac942dc2a9f958acddc67e11472d3ca0b"><div class="ttname"><a href="classripple_1_1InboundLedger.html#a3e8d7f8b5fa089a184dcc9b00b6e0da7ac942dc2a9f958acddc67e11472d3ca0b">ripple::InboundLedger::Reason::GENERIC</a></div><div class="ttdeci">@ GENERIC</div></div>
<div class="ttc" id="aclassripple_1_1CollectorManager_html"><div class="ttname"><a href="classripple_1_1CollectorManager.html">ripple::CollectorManager</a></div><div class="ttdoc">Provides the beast::insight::Collector service.</div><div class="ttdef"><b>Definition:</b> <a href="CollectorManager_8h_source.html#l00029">CollectorManager.h:29</a></div></div>
<div class="ttc" id="anamespaceripple_html_a1b38e742ac7fe4c3a80a397e06b83dcbab4f2ec48d846301c36ab8824e62fde66"><div class="ttname"><a href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcbab4f2ec48d846301c36ab8824e62fde66">ripple::SizedItem::treeCacheAge</a></div><div class="ttdeci">@ treeCacheAge</div></div>
<div class="ttc" id="alock_guard_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/thread/lock_guard.html">std::lock_guard</a></div><div class="ttdoc">STL class.</div></div>
<div class="ttc" id="anamespaceripple_html_ac70521ab6e1277870a9e400e7a08e937"><div class="ttname"><a href="namespaceripple.html#ac70521ab6e1277870a9e400e7a08e937">ripple::stopwatch</a></div><div class="ttdeci">Stopwatch &amp; stopwatch()</div><div class="ttdoc">Returns an instance of a wall clock.</div><div class="ttdef"><b>Definition:</b> <a href="chrono_8h_source.html#l00088">chrono.h:88</a></div></div>
<div class="ttc" id="anamespaceripple_html_a5c370593e8a1e99cb6e68c961339143d"><div class="ttname"><a href="namespaceripple.html#a5c370593e8a1e99cb6e68c961339143d">ripple::fullBelowExpiration</a></div><div class="ttdeci">constexpr std::chrono::seconds fullBelowExpiration</div><div class="ttdef"><b>Definition:</b> <a href="app_2main_2Tuning_8h_source.html#l00026">app/main/Tuning.h:26</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_acd15a63c12f9d7bfd363ef35707171da"><div class="ttname"><a href="classripple_1_1NodeFamily.html#acd15a63c12f9d7bfd363ef35707171da">ripple::NodeFamily::reset</a></div><div class="ttdeci">void reset() override</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8cpp_source.html#l00055">NodeFamily.cpp:55</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_acd15a63c12f9d7bfd363ef35707171da"><div class="ttname"><a href="classripple_1_1NodeFamily.html#acd15a63c12f9d7bfd363ef35707171da">ripple::NodeFamily::reset</a></div><div class="ttdeci">void reset() override</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8cpp_source.html#l00056">NodeFamily.cpp:56</a></div></div>
<div class="ttc" id="aclassripple_1_1Application_html_a6d349a4ada03689eae062c0399762dad"><div class="ttname"><a href="classripple_1_1Application.html#a6d349a4ada03689eae062c0399762dad">ripple::Application::getInboundLedgers</a></div><div class="ttdeci">virtual InboundLedgers &amp; getInboundLedgers()=0</div></div>
<div class="ttc" id="aclassripple_1_1base__uint_html"><div class="ttname"><a href="classripple_1_1base__uint.html">ripple::base_uint&lt; 256 &gt;</a></div></div>
<div class="ttc" id="aclassripple_1_1Application_html_a57929fa83c551514e364fe6981b0c104"><div class="ttname"><a href="classripple_1_1Application.html#a57929fa83c551514e364fe6981b0c104">ripple::Application::getLedgerMaster</a></div><div class="ttdeci">virtual LedgerMaster &amp; getLedgerMaster()=0</div></div>
@@ -200,10 +201,10 @@ $(function() {
<div class="ttc" id="aclassripple_1_1NodeFamily_html_a0b893d398048e7ae9ff41d9887b9894b"><div class="ttname"><a href="classripple_1_1NodeFamily.html#a0b893d398048e7ae9ff41d9887b9894b">ripple::NodeFamily::maxSeq_</a></div><div class="ttdeci">LedgerIndex maxSeq_</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8h_source.html#l00103">NodeFamily.h:103</a></div></div>
<div class="ttc" id="aunique_lock_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/thread/unique_lock.html">std::unique_lock</a></div><div class="ttdoc">STL class.</div></div>
<div class="ttc" id="aclassbeast_1_1Journal_html_a49b0713e65bb8e2c51b76fbf16252afe"><div class="ttname"><a href="classbeast_1_1Journal.html#a49b0713e65bb8e2c51b76fbf16252afe">beast::Journal::error</a></div><div class="ttdeci">Stream error() const</div><div class="ttdef"><b>Definition:</b> <a href="Journal_8h_source.html#l00333">Journal.h:333</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_a7599daa25d6d2fd8ee537e8396f381c4"><div class="ttname"><a href="classripple_1_1NodeFamily.html#a7599daa25d6d2fd8ee537e8396f381c4">ripple::NodeFamily::acquire</a></div><div class="ttdeci">void acquire(uint256 const &amp;hash, std::uint32_t seq)</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8cpp_source.html#l00097">NodeFamily.cpp:97</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_a7599daa25d6d2fd8ee537e8396f381c4"><div class="ttname"><a href="classripple_1_1NodeFamily.html#a7599daa25d6d2fd8ee537e8396f381c4">ripple::NodeFamily::acquire</a></div><div class="ttdeci">void acquire(uint256 const &amp;hash, std::uint32_t seq)</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8cpp_source.html#l00098">NodeFamily.cpp:98</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_aa8b9b76dbe944c6c22b9f28577c73e22"><div class="ttname"><a href="classripple_1_1NodeFamily.html#aa8b9b76dbe944c6c22b9f28577c73e22">ripple::NodeFamily::NodeFamily</a></div><div class="ttdeci">NodeFamily()=delete</div></div>
<div class="ttc" id="ainteger_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/types/integer.html">std::uint32_t</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_ae28638a42e0a37921b85da75d6d73ba3"><div class="ttname"><a href="classripple_1_1NodeFamily.html#ae28638a42e0a37921b85da75d6d73ba3">ripple::NodeFamily::missingNode</a></div><div class="ttdeci">void missingNode(std::uint32_t seq) override</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8cpp_source.html#l00067">NodeFamily.cpp:67</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_ae28638a42e0a37921b85da75d6d73ba3"><div class="ttname"><a href="classripple_1_1NodeFamily.html#ae28638a42e0a37921b85da75d6d73ba3">ripple::NodeFamily::missingNode</a></div><div class="ttdeci">void missingNode(std::uint32_t seq) override</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8cpp_source.html#l00068">NodeFamily.cpp:68</a></div></div>
<div class="ttc" id="anamespaceripple_html_aef07fa1142a7973847f45894ad5f9ebf"><div class="ttname"><a href="namespaceripple.html#aef07fa1142a7973847f45894ad5f9ebf">ripple::fullBelowTargetSize</a></div><div class="ttdeci">constexpr std::size_t fullBelowTargetSize</div><div class="ttdef"><b>Definition:</b> <a href="app_2main_2Tuning_8h_source.html#l00025">app/main/Tuning.h:25</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeFamily_html_acc158cf12dc02f60d4207fba066152e9"><div class="ttname"><a href="classripple_1_1NodeFamily.html#acc158cf12dc02f60d4207fba066152e9">ripple::NodeFamily::maxSeqMutex_</a></div><div class="ttdeci">std::mutex maxSeqMutex_</div><div class="ttdef"><b>Definition:</b> <a href="NodeFamily_8h_source.html#l00104">NodeFamily.h:104</a></div></div>
<div class="ttc" id="anamespaceripple_html"><div class="ttname"><a href="namespaceripple.html">ripple</a></div><div class="ttdoc">Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.</div><div class="ttdef"><b>Definition:</b> <a href="RCLCensorshipDetector_8h_source.html#l00029">RCLCensorshipDetector.h:29</a></div></div>