This commit is contained in:
bthomee
2025-03-11 18:21:06 +00:00
parent 95e4a9d650
commit 4ba075f689
2527 changed files with 275798 additions and 275583 deletions

View File

@@ -96,74 +96,73 @@ $(function() {
<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="comment">//==============================================================================</span></div>
<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span> </div>
<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span><span class="preprocessor">#include &lt;xrpld/app/main/NodeStoreScheduler.h&gt;</span></div>
<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;xrpl/beast/utility/instrumentation.h&gt;</span></div>
<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div>
<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="keyword">namespace </span><a class="code hl_namespace" href="namespaceripple.html">ripple</a> {</div>
<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span> </div>
<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"><a class="line" href="classripple_1_1NodeStoreScheduler.html#a92e3efe8d2011f9095a1e9c76628dc2e"> 25</a></span><a class="code hl_function" href="classripple_1_1NodeStoreScheduler.html#a92e3efe8d2011f9095a1e9c76628dc2e">NodeStoreScheduler::NodeStoreScheduler</a>(<a class="code hl_class" href="classripple_1_1JobQueue.html">JobQueue</a>&amp; jobQueue) : jobQueue_(jobQueue)</div>
<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span>{</div>
<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span>}</div>
<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span> </div>
<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span><span class="keywordtype">void</span></div>
<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="classripple_1_1NodeStoreScheduler.html#a0b1c3260477e401b7e57493b0aaf9a3a"> 30</a></span><a class="code hl_function" href="classripple_1_1NodeStoreScheduler.html#a0b1c3260477e401b7e57493b0aaf9a3a">NodeStoreScheduler::scheduleTask</a>(<a class="code hl_struct" href="structripple_1_1NodeStore_1_1Task.html">NodeStore::Task</a>&amp; task)</div>
<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span>{</div>
<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span> <span class="keywordflow">if</span> (<a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#a540fcd3211d86c0194bf5c154ab98541">isStopped</a>())</div>
<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> <span class="keywordflow">return</span>;</div>
<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span> </div>
<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> <span class="keywordflow">if</span> (!<a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#af5e34187d55aa58e551dc196aaf1ec25">addJob</a>(<a class="code hl_enumvalue" href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aaf5964ac101121f8e08de3603c12943e0">jtWRITE</a>, <span class="stringliteral">&quot;NodeObject::store&quot;</span>, [&amp;task]() {</div>
<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> task.performScheduledTask();</div>
<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span> }))</div>
<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> {</div>
<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span> <span class="comment">// Job not added, presumably because we&#39;re shutting down.</span></div>
<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span> <span class="comment">// Recover by executing the task synchronously.</span></div>
<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span> task.<a class="code hl_function" href="structripple_1_1NodeStore_1_1Task.html#a1ed44e570fe3bd98407aae13a554ec2b">performScheduledTask</a>();</div>
<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span> }</div>
<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span>}</div>
<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span> </div>
<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span><span class="keywordtype">void</span></div>
<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="classripple_1_1NodeStoreScheduler.html#a042848ff97f97cff8a602ffec6b9f807"> 46</a></span><a class="code hl_function" href="classripple_1_1NodeStoreScheduler.html#a042848ff97f97cff8a602ffec6b9f807">NodeStoreScheduler::onFetch</a>(<a class="code hl_struct" href="structripple_1_1NodeStore_1_1FetchReport.html">NodeStore::FetchReport</a> <span class="keyword">const</span>&amp; report)</div>
<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span>{</div>
<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span> <span class="keywordflow">if</span> (<a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#a540fcd3211d86c0194bf5c154ab98541">isStopped</a>())</div>
<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span> <span class="keywordflow">return</span>;</div>
<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span> </div>
<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span> <a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#a719a330a06633559303d6ebcd5945b07">addLoadEvents</a>(</div>
<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span> report.<a class="code hl_variable" href="structripple_1_1NodeStore_1_1FetchReport.html#af6500354fd85b9299fd658e66400b28b">fetchType</a> == <a class="code hl_enumvalue" href="namespaceripple_1_1NodeStore.html#a6334ed426a8dbe335761b9d81ab6f19fa0df93e34273b367bb63bad28c94c78d5">NodeStore::FetchType::async</a> ? <a class="code hl_enumvalue" href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aac573ff0fe885e62083387ad1823b4f84">jtNS_ASYNC_READ</a></div>
<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span> : <a class="code hl_enumvalue" href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aab724b0c38f524c70378ef010fe8b7e2c">jtNS_SYNC_READ</a>,</div>
<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span> 1,</div>
<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span> report.<a class="code hl_variable" href="structripple_1_1NodeStore_1_1FetchReport.html#ad28c626873890debb451674b62037f57">elapsed</a>);</div>
<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span>}</div>
<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span> </div>
<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span><span class="keywordtype">void</span></div>
<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="classripple_1_1NodeStoreScheduler.html#a0b9464b915021b488e3d2e22b840a62f"> 59</a></span><a class="code hl_function" href="classripple_1_1NodeStoreScheduler.html#a0b9464b915021b488e3d2e22b840a62f">NodeStoreScheduler::onBatchWrite</a>(<a class="code hl_struct" href="structripple_1_1NodeStore_1_1BatchWriteReport.html">NodeStore::BatchWriteReport</a> <span class="keyword">const</span>&amp; report)</div>
<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span>{</div>
<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span> <span class="keywordflow">if</span> (<a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#a540fcd3211d86c0194bf5c154ab98541">isStopped</a>())</div>
<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span> <span class="keywordflow">return</span>;</div>
<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span> </div>
<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span> <a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#a719a330a06633559303d6ebcd5945b07">addLoadEvents</a>(<a class="code hl_enumvalue" href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aaa94b630431b8f365820cf3a29ed67f3e">jtNS_WRITE</a>, report.<a class="code hl_variable" href="structripple_1_1NodeStore_1_1BatchWriteReport.html#a357c5cc140aa8da903855175e07b4d0b">writeCount</a>, report.<a class="code hl_variable" href="structripple_1_1NodeStore_1_1BatchWriteReport.html#a183bf74eb142fef4d3dd5d18905d9a22">elapsed</a>);</div>
<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span>}</div>
<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span> </div>
<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span>} <span class="comment">// namespace ripple</span></div>
<div class="ttc" id="aclassripple_1_1JobQueue_html"><div class="ttname"><a href="classripple_1_1JobQueue.html">ripple::JobQueue</a></div><div class="ttdoc">A pool of threads to perform work.</div><div class="ttdef"><b>Definition:</b> <a href="JobQueue_8h_source.html#l00055">JobQueue.h:56</a></div></div>
<div class="ttc" id="aclassripple_1_1JobQueue_html_a540fcd3211d86c0194bf5c154ab98541"><div class="ttname"><a href="classripple_1_1JobQueue.html#a540fcd3211d86c0194bf5c154ab98541">ripple::JobQueue::isStopped</a></div><div class="ttdeci">bool isStopped() const</div><div class="ttdef"><b>Definition:</b> <a href="JobQueue_8cpp_source.html#l00320">JobQueue.cpp:320</a></div></div>
<div class="ttc" id="aclassripple_1_1JobQueue_html_a719a330a06633559303d6ebcd5945b07"><div class="ttname"><a href="classripple_1_1JobQueue.html#a719a330a06633559303d6ebcd5945b07">ripple::JobQueue::addLoadEvents</a></div><div class="ttdeci">void addLoadEvents(JobType t, int count, std::chrono::milliseconds elapsed)</div><div class="ttdoc">Add multiple load events.</div><div class="ttdef"><b>Definition:</b> <a href="JobQueue_8cpp_source.html#l00191">JobQueue.cpp:191</a></div></div>
<div class="ttc" id="aclassripple_1_1JobQueue_html_af5e34187d55aa58e551dc196aaf1ec25"><div class="ttname"><a href="classripple_1_1JobQueue.html#af5e34187d55aa58e551dc196aaf1ec25">ripple::JobQueue::addJob</a></div><div class="ttdeci">bool addJob(JobType type, std::string const &amp;name, JobHandler &amp;&amp;jobHandler)</div><div class="ttdoc">Adds a job to the JobQueue.</div><div class="ttdef"><b>Definition:</b> <a href="JobQueue_8h_source.html#l00166">JobQueue.h:166</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeStoreScheduler_html_a042848ff97f97cff8a602ffec6b9f807"><div class="ttname"><a href="classripple_1_1NodeStoreScheduler.html#a042848ff97f97cff8a602ffec6b9f807">ripple::NodeStoreScheduler::onFetch</a></div><div class="ttdeci">void onFetch(NodeStore::FetchReport const &amp;report) override</div><div class="ttdoc">Reports completion of a fetch Allows the scheduler to monitor the node store's performance.</div><div class="ttdef"><b>Definition:</b> <a href="NodeStoreScheduler_8cpp_source.html#l00046">NodeStoreScheduler.cpp:46</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeStoreScheduler_html_a0b1c3260477e401b7e57493b0aaf9a3a"><div class="ttname"><a href="classripple_1_1NodeStoreScheduler.html#a0b1c3260477e401b7e57493b0aaf9a3a">ripple::NodeStoreScheduler::scheduleTask</a></div><div class="ttdeci">void scheduleTask(NodeStore::Task &amp;task) override</div><div class="ttdoc">Schedules a task.</div><div class="ttdef"><b>Definition:</b> <a href="NodeStoreScheduler_8cpp_source.html#l00030">NodeStoreScheduler.cpp:30</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeStoreScheduler_html_a0b9464b915021b488e3d2e22b840a62f"><div class="ttname"><a href="classripple_1_1NodeStoreScheduler.html#a0b9464b915021b488e3d2e22b840a62f">ripple::NodeStoreScheduler::onBatchWrite</a></div><div class="ttdeci">void onBatchWrite(NodeStore::BatchWriteReport const &amp;report) override</div><div class="ttdoc">Reports the completion of a batch write Allows the scheduler to monitor the node store's performance.</div><div class="ttdef"><b>Definition:</b> <a href="NodeStoreScheduler_8cpp_source.html#l00059">NodeStoreScheduler.cpp:59</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeStoreScheduler_html_a92e3efe8d2011f9095a1e9c76628dc2e"><div class="ttname"><a href="classripple_1_1NodeStoreScheduler.html#a92e3efe8d2011f9095a1e9c76628dc2e">ripple::NodeStoreScheduler::NodeStoreScheduler</a></div><div class="ttdeci">NodeStoreScheduler(JobQueue &amp;jobQueue)</div><div class="ttdef"><b>Definition:</b> <a href="NodeStoreScheduler_8cpp_source.html#l00025">NodeStoreScheduler.cpp:25</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeStoreScheduler_html_aa0fbc996243ce5b4d1b5eb2a2cabc2fa"><div class="ttname"><a href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">ripple::NodeStoreScheduler::jobQueue_</a></div><div class="ttdeci">JobQueue &amp; jobQueue_</div><div class="ttdef"><b>Definition:</b> <a href="NodeStoreScheduler_8h_source.html#l00043">NodeStoreScheduler.h:43</a></div></div>
<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div>
<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="keyword">namespace </span><a class="code hl_namespace" href="namespaceripple.html">ripple</a> {</div>
<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div>
<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"><a class="line" href="classripple_1_1NodeStoreScheduler.html#a92e3efe8d2011f9095a1e9c76628dc2e"> 24</a></span><a class="code hl_function" href="classripple_1_1NodeStoreScheduler.html#a92e3efe8d2011f9095a1e9c76628dc2e">NodeStoreScheduler::NodeStoreScheduler</a>(<a class="code hl_class" href="classripple_1_1JobQueue.html">JobQueue</a>&amp; jobQueue) : jobQueue_(jobQueue)</div>
<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span>{</div>
<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span>}</div>
<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span> </div>
<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span><span class="keywordtype">void</span></div>
<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="classripple_1_1NodeStoreScheduler.html#a0b1c3260477e401b7e57493b0aaf9a3a"> 29</a></span><a class="code hl_function" href="classripple_1_1NodeStoreScheduler.html#a0b1c3260477e401b7e57493b0aaf9a3a">NodeStoreScheduler::scheduleTask</a>(<a class="code hl_struct" href="structripple_1_1NodeStore_1_1Task.html">NodeStore::Task</a>&amp; task)</div>
<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span>{</div>
<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span> <span class="keywordflow">if</span> (<a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#a540fcd3211d86c0194bf5c154ab98541">isStopped</a>())</div>
<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span> <span class="keywordflow">return</span>;</div>
<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div>
<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span> <span class="keywordflow">if</span> (!<a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#af5e34187d55aa58e551dc196aaf1ec25">addJob</a>(<a class="code hl_enumvalue" href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aaf5964ac101121f8e08de3603c12943e0">jtWRITE</a>, <span class="stringliteral">&quot;NodeObject::store&quot;</span>, [&amp;task]() {</div>
<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> task.performScheduledTask();</div>
<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> }))</div>
<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span> {</div>
<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> <span class="comment">// Job not added, presumably because we&#39;re shutting down.</span></div>
<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span> <span class="comment">// Recover by executing the task synchronously.</span></div>
<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span> task.<a class="code hl_function" href="structripple_1_1NodeStore_1_1Task.html#a1ed44e570fe3bd98407aae13a554ec2b">performScheduledTask</a>();</div>
<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span> }</div>
<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span>}</div>
<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span> </div>
<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span><span class="keywordtype">void</span></div>
<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="classripple_1_1NodeStoreScheduler.html#a042848ff97f97cff8a602ffec6b9f807"> 45</a></span><a class="code hl_function" href="classripple_1_1NodeStoreScheduler.html#a042848ff97f97cff8a602ffec6b9f807">NodeStoreScheduler::onFetch</a>(<a class="code hl_struct" href="structripple_1_1NodeStore_1_1FetchReport.html">NodeStore::FetchReport</a> <span class="keyword">const</span>&amp; report)</div>
<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span>{</div>
<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span> <span class="keywordflow">if</span> (<a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#a540fcd3211d86c0194bf5c154ab98541">isStopped</a>())</div>
<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span> <span class="keywordflow">return</span>;</div>
<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span> </div>
<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span> <a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#a719a330a06633559303d6ebcd5945b07">addLoadEvents</a>(</div>
<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span> report.<a class="code hl_variable" href="structripple_1_1NodeStore_1_1FetchReport.html#af6500354fd85b9299fd658e66400b28b">fetchType</a> == <a class="code hl_enumvalue" href="namespaceripple_1_1NodeStore.html#a6334ed426a8dbe335761b9d81ab6f19fa0df93e34273b367bb63bad28c94c78d5">NodeStore::FetchType::async</a> ? <a class="code hl_enumvalue" href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aac573ff0fe885e62083387ad1823b4f84">jtNS_ASYNC_READ</a></div>
<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span> : <a class="code hl_enumvalue" href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aab724b0c38f524c70378ef010fe8b7e2c">jtNS_SYNC_READ</a>,</div>
<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span> 1,</div>
<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span> report.<a class="code hl_variable" href="structripple_1_1NodeStore_1_1FetchReport.html#ad28c626873890debb451674b62037f57">elapsed</a>);</div>
<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span>}</div>
<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span> </div>
<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span><span class="keywordtype">void</span></div>
<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="classripple_1_1NodeStoreScheduler.html#a0b9464b915021b488e3d2e22b840a62f"> 58</a></span><a class="code hl_function" href="classripple_1_1NodeStoreScheduler.html#a0b9464b915021b488e3d2e22b840a62f">NodeStoreScheduler::onBatchWrite</a>(<a class="code hl_struct" href="structripple_1_1NodeStore_1_1BatchWriteReport.html">NodeStore::BatchWriteReport</a> <span class="keyword">const</span>&amp; report)</div>
<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span>{</div>
<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span> <span class="keywordflow">if</span> (<a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#a540fcd3211d86c0194bf5c154ab98541">isStopped</a>())</div>
<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span> <span class="keywordflow">return</span>;</div>
<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span> </div>
<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span> <a class="code hl_variable" href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">jobQueue_</a>.<a class="code hl_function" href="classripple_1_1JobQueue.html#a719a330a06633559303d6ebcd5945b07">addLoadEvents</a>(<a class="code hl_enumvalue" href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aaa94b630431b8f365820cf3a29ed67f3e">jtNS_WRITE</a>, report.<a class="code hl_variable" href="structripple_1_1NodeStore_1_1BatchWriteReport.html#a357c5cc140aa8da903855175e07b4d0b">writeCount</a>, report.<a class="code hl_variable" href="structripple_1_1NodeStore_1_1BatchWriteReport.html#a183bf74eb142fef4d3dd5d18905d9a22">elapsed</a>);</div>
<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span>}</div>
<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span> </div>
<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span>} <span class="comment">// namespace ripple</span></div>
<div class="ttc" id="aclassripple_1_1JobQueue_html"><div class="ttname"><a href="classripple_1_1JobQueue.html">ripple::JobQueue</a></div><div class="ttdoc">A pool of threads to perform work.</div><div class="ttdef"><b>Definition:</b> <a href="JobQueue_8h_source.html#l00054">JobQueue.h:55</a></div></div>
<div class="ttc" id="aclassripple_1_1JobQueue_html_a540fcd3211d86c0194bf5c154ab98541"><div class="ttname"><a href="classripple_1_1JobQueue.html#a540fcd3211d86c0194bf5c154ab98541">ripple::JobQueue::isStopped</a></div><div class="ttdeci">bool isStopped() const</div><div class="ttdef"><b>Definition:</b> <a href="JobQueue_8cpp_source.html#l00321">JobQueue.cpp:321</a></div></div>
<div class="ttc" id="aclassripple_1_1JobQueue_html_a719a330a06633559303d6ebcd5945b07"><div class="ttname"><a href="classripple_1_1JobQueue.html#a719a330a06633559303d6ebcd5945b07">ripple::JobQueue::addLoadEvents</a></div><div class="ttdeci">void addLoadEvents(JobType t, int count, std::chrono::milliseconds elapsed)</div><div class="ttdoc">Add multiple load events.</div><div class="ttdef"><b>Definition:</b> <a href="JobQueue_8cpp_source.html#l00192">JobQueue.cpp:192</a></div></div>
<div class="ttc" id="aclassripple_1_1JobQueue_html_af5e34187d55aa58e551dc196aaf1ec25"><div class="ttname"><a href="classripple_1_1JobQueue.html#af5e34187d55aa58e551dc196aaf1ec25">ripple::JobQueue::addJob</a></div><div class="ttdeci">bool addJob(JobType type, std::string const &amp;name, JobHandler &amp;&amp;jobHandler)</div><div class="ttdoc">Adds a job to the JobQueue.</div><div class="ttdef"><b>Definition:</b> <a href="JobQueue_8h_source.html#l00165">JobQueue.h:165</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeStoreScheduler_html_a042848ff97f97cff8a602ffec6b9f807"><div class="ttname"><a href="classripple_1_1NodeStoreScheduler.html#a042848ff97f97cff8a602ffec6b9f807">ripple::NodeStoreScheduler::onFetch</a></div><div class="ttdeci">void onFetch(NodeStore::FetchReport const &amp;report) override</div><div class="ttdoc">Reports completion of a fetch Allows the scheduler to monitor the node store's performance.</div><div class="ttdef"><b>Definition:</b> <a href="NodeStoreScheduler_8cpp_source.html#l00045">NodeStoreScheduler.cpp:45</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeStoreScheduler_html_a0b1c3260477e401b7e57493b0aaf9a3a"><div class="ttname"><a href="classripple_1_1NodeStoreScheduler.html#a0b1c3260477e401b7e57493b0aaf9a3a">ripple::NodeStoreScheduler::scheduleTask</a></div><div class="ttdeci">void scheduleTask(NodeStore::Task &amp;task) override</div><div class="ttdoc">Schedules a task.</div><div class="ttdef"><b>Definition:</b> <a href="NodeStoreScheduler_8cpp_source.html#l00029">NodeStoreScheduler.cpp:29</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeStoreScheduler_html_a0b9464b915021b488e3d2e22b840a62f"><div class="ttname"><a href="classripple_1_1NodeStoreScheduler.html#a0b9464b915021b488e3d2e22b840a62f">ripple::NodeStoreScheduler::onBatchWrite</a></div><div class="ttdeci">void onBatchWrite(NodeStore::BatchWriteReport const &amp;report) override</div><div class="ttdoc">Reports the completion of a batch write Allows the scheduler to monitor the node store's performance.</div><div class="ttdef"><b>Definition:</b> <a href="NodeStoreScheduler_8cpp_source.html#l00058">NodeStoreScheduler.cpp:58</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeStoreScheduler_html_a92e3efe8d2011f9095a1e9c76628dc2e"><div class="ttname"><a href="classripple_1_1NodeStoreScheduler.html#a92e3efe8d2011f9095a1e9c76628dc2e">ripple::NodeStoreScheduler::NodeStoreScheduler</a></div><div class="ttdeci">NodeStoreScheduler(JobQueue &amp;jobQueue)</div><div class="ttdef"><b>Definition:</b> <a href="NodeStoreScheduler_8cpp_source.html#l00024">NodeStoreScheduler.cpp:24</a></div></div>
<div class="ttc" id="aclassripple_1_1NodeStoreScheduler_html_aa0fbc996243ce5b4d1b5eb2a2cabc2fa"><div class="ttname"><a href="classripple_1_1NodeStoreScheduler.html#aa0fbc996243ce5b4d1b5eb2a2cabc2fa">ripple::NodeStoreScheduler::jobQueue_</a></div><div class="ttdeci">JobQueue &amp; jobQueue_</div><div class="ttdef"><b>Definition:</b> <a href="NodeStoreScheduler_8h_source.html#l00042">NodeStoreScheduler.h:42</a></div></div>
<div class="ttc" id="anamespaceripple_1_1NodeStore_html_a6334ed426a8dbe335761b9d81ab6f19fa0df93e34273b367bb63bad28c94c78d5"><div class="ttname"><a href="namespaceripple_1_1NodeStore.html#a6334ed426a8dbe335761b9d81ab6f19fa0df93e34273b367bb63bad28c94c78d5">ripple::NodeStore::FetchType::async</a></div><div class="ttdeci">@ async</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="algorithm_8h_source.html#l00026">algorithm.h:26</a></div></div>
<div class="ttc" id="anamespaceripple_html_ae0f54f8ce649d639bf3e2b295347e17aaa94b630431b8f365820cf3a29ed67f3e"><div class="ttname"><a href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aaa94b630431b8f365820cf3a29ed67f3e">ripple::jtNS_WRITE</a></div><div class="ttdeci">@ jtNS_WRITE</div><div class="ttdef"><b>Definition:</b> <a href="Job_8h_source.html#l00092">Job.h:92</a></div></div>
<div class="ttc" id="anamespaceripple_html_ae0f54f8ce649d639bf3e2b295347e17aab724b0c38f524c70378ef010fe8b7e2c"><div class="ttname"><a href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aab724b0c38f524c70378ef010fe8b7e2c">ripple::jtNS_SYNC_READ</a></div><div class="ttdeci">@ jtNS_SYNC_READ</div><div class="ttdef"><b>Definition:</b> <a href="Job_8h_source.html#l00090">Job.h:90</a></div></div>
<div class="ttc" id="anamespaceripple_html_ae0f54f8ce649d639bf3e2b295347e17aac573ff0fe885e62083387ad1823b4f84"><div class="ttname"><a href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aac573ff0fe885e62083387ad1823b4f84">ripple::jtNS_ASYNC_READ</a></div><div class="ttdeci">@ jtNS_ASYNC_READ</div><div class="ttdef"><b>Definition:</b> <a href="Job_8h_source.html#l00091">Job.h:91</a></div></div>
<div class="ttc" id="anamespaceripple_html_ae0f54f8ce649d639bf3e2b295347e17aaf5964ac101121f8e08de3603c12943e0"><div class="ttname"><a href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aaf5964ac101121f8e08de3603c12943e0">ripple::jtWRITE</a></div><div class="ttdeci">@ jtWRITE</div><div class="ttdef"><b>Definition:</b> <a href="Job_8h_source.html#l00072">Job.h:72</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1BatchWriteReport_html"><div class="ttname"><a href="structripple_1_1NodeStore_1_1BatchWriteReport.html">ripple::NodeStore::BatchWriteReport</a></div><div class="ttdoc">Contains information about a batch write operation.</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00044">xrpld/nodestore/Scheduler.h:45</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1BatchWriteReport_html_a183bf74eb142fef4d3dd5d18905d9a22"><div class="ttname"><a href="structripple_1_1NodeStore_1_1BatchWriteReport.html#a183bf74eb142fef4d3dd5d18905d9a22">ripple::NodeStore::BatchWriteReport::elapsed</a></div><div class="ttdeci">std::chrono::milliseconds elapsed</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00048">xrpld/nodestore/Scheduler.h:48</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1BatchWriteReport_html_a357c5cc140aa8da903855175e07b4d0b"><div class="ttname"><a href="structripple_1_1NodeStore_1_1BatchWriteReport.html#a357c5cc140aa8da903855175e07b4d0b">ripple::NodeStore::BatchWriteReport::writeCount</a></div><div class="ttdeci">int writeCount</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00049">xrpld/nodestore/Scheduler.h:49</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1FetchReport_html"><div class="ttname"><a href="structripple_1_1NodeStore_1_1FetchReport.html">ripple::NodeStore::FetchReport</a></div><div class="ttdoc">Contains information about a fetch operation.</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00032">xrpld/nodestore/Scheduler.h:33</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1FetchReport_html_ad28c626873890debb451674b62037f57"><div class="ttname"><a href="structripple_1_1NodeStore_1_1FetchReport.html#ad28c626873890debb451674b62037f57">ripple::NodeStore::FetchReport::elapsed</a></div><div class="ttdeci">std::chrono::milliseconds elapsed</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00038">xrpld/nodestore/Scheduler.h:38</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1FetchReport_html_af6500354fd85b9299fd658e66400b28b"><div class="ttname"><a href="structripple_1_1NodeStore_1_1FetchReport.html#af6500354fd85b9299fd658e66400b28b">ripple::NodeStore::FetchReport::fetchType</a></div><div class="ttdeci">FetchType const fetchType</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00039">xrpld/nodestore/Scheduler.h:39</a></div></div>
<div class="ttc" id="anamespaceripple_html_ae0f54f8ce649d639bf3e2b295347e17aaa94b630431b8f365820cf3a29ed67f3e"><div class="ttname"><a href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aaa94b630431b8f365820cf3a29ed67f3e">ripple::jtNS_WRITE</a></div><div class="ttdeci">@ jtNS_WRITE</div><div class="ttdef"><b>Definition:</b> <a href="Job_8h_source.html#l00091">Job.h:91</a></div></div>
<div class="ttc" id="anamespaceripple_html_ae0f54f8ce649d639bf3e2b295347e17aab724b0c38f524c70378ef010fe8b7e2c"><div class="ttname"><a href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aab724b0c38f524c70378ef010fe8b7e2c">ripple::jtNS_SYNC_READ</a></div><div class="ttdeci">@ jtNS_SYNC_READ</div><div class="ttdef"><b>Definition:</b> <a href="Job_8h_source.html#l00089">Job.h:89</a></div></div>
<div class="ttc" id="anamespaceripple_html_ae0f54f8ce649d639bf3e2b295347e17aac573ff0fe885e62083387ad1823b4f84"><div class="ttname"><a href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aac573ff0fe885e62083387ad1823b4f84">ripple::jtNS_ASYNC_READ</a></div><div class="ttdeci">@ jtNS_ASYNC_READ</div><div class="ttdef"><b>Definition:</b> <a href="Job_8h_source.html#l00090">Job.h:90</a></div></div>
<div class="ttc" id="anamespaceripple_html_ae0f54f8ce649d639bf3e2b295347e17aaf5964ac101121f8e08de3603c12943e0"><div class="ttname"><a href="namespaceripple.html#ae0f54f8ce649d639bf3e2b295347e17aaf5964ac101121f8e08de3603c12943e0">ripple::jtWRITE</a></div><div class="ttdeci">@ jtWRITE</div><div class="ttdef"><b>Definition:</b> <a href="Job_8h_source.html#l00071">Job.h:71</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1BatchWriteReport_html"><div class="ttname"><a href="structripple_1_1NodeStore_1_1BatchWriteReport.html">ripple::NodeStore::BatchWriteReport</a></div><div class="ttdoc">Contains information about a batch write operation.</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00045">xrpld/nodestore/Scheduler.h:46</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1BatchWriteReport_html_a183bf74eb142fef4d3dd5d18905d9a22"><div class="ttname"><a href="structripple_1_1NodeStore_1_1BatchWriteReport.html#a183bf74eb142fef4d3dd5d18905d9a22">ripple::NodeStore::BatchWriteReport::elapsed</a></div><div class="ttdeci">std::chrono::milliseconds elapsed</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00049">xrpld/nodestore/Scheduler.h:49</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1BatchWriteReport_html_a357c5cc140aa8da903855175e07b4d0b"><div class="ttname"><a href="structripple_1_1NodeStore_1_1BatchWriteReport.html#a357c5cc140aa8da903855175e07b4d0b">ripple::NodeStore::BatchWriteReport::writeCount</a></div><div class="ttdeci">int writeCount</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00050">xrpld/nodestore/Scheduler.h:50</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1FetchReport_html"><div class="ttname"><a href="structripple_1_1NodeStore_1_1FetchReport.html">ripple::NodeStore::FetchReport</a></div><div class="ttdoc">Contains information about a fetch operation.</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00033">xrpld/nodestore/Scheduler.h:34</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1FetchReport_html_ad28c626873890debb451674b62037f57"><div class="ttname"><a href="structripple_1_1NodeStore_1_1FetchReport.html#ad28c626873890debb451674b62037f57">ripple::NodeStore::FetchReport::elapsed</a></div><div class="ttdeci">std::chrono::milliseconds elapsed</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00039">xrpld/nodestore/Scheduler.h:39</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1FetchReport_html_af6500354fd85b9299fd658e66400b28b"><div class="ttname"><a href="structripple_1_1NodeStore_1_1FetchReport.html#af6500354fd85b9299fd658e66400b28b">ripple::NodeStore::FetchReport::fetchType</a></div><div class="ttdeci">FetchType const fetchType</div><div class="ttdef"><b>Definition:</b> <a href="xrpld_2nodestore_2Scheduler_8h_source.html#l00040">xrpld/nodestore/Scheduler.h:40</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1Task_html"><div class="ttname"><a href="structripple_1_1NodeStore_1_1Task.html">ripple::NodeStore::Task</a></div><div class="ttdoc">Derived classes perform scheduled tasks.</div><div class="ttdef"><b>Definition:</b> <a href="Task_8h_source.html#l00027">Task.h:28</a></div></div>
<div class="ttc" id="astructripple_1_1NodeStore_1_1Task_html_a1ed44e570fe3bd98407aae13a554ec2b"><div class="ttname"><a href="structripple_1_1NodeStore_1_1Task.html#a1ed44e570fe3bd98407aae13a554ec2b">ripple::NodeStore::Task::performScheduledTask</a></div><div class="ttdeci">virtual void performScheduledTask()=0</div><div class="ttdoc">Performs the task.</div></div>
</div><!-- fragment --></div><!-- contents -->