|
|
|
|
@@ -414,469 +414,473 @@ $(function() {
|
|
|
|
|
<div class="line"><a name="l00343"></a><span class="lineno"> 343</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a> = &<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a57929fa83c551514e364fe6981b0c104">getLedgerMaster</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00344"></a><span class="lineno"> 344</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#aa652318bb0714902d2cc90903878843f">fullBelowCache_</a> = &(*<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a26ccdf06f25ceadec7894dd5f8da7eab">getNodeFamily</a>().<a class="code" href="classripple_1_1Family.html#ac16fa71cf792d5716da74e9164707769">getFullBelowCache</a>(0));</div>
|
|
|
|
|
<div class="line"><a name="l00345"></a><span class="lineno"> 345</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a35ca5214c1ef881ac91ac078f6e3df1c">treeNodeCache_</a> = &(*<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a26ccdf06f25ceadec7894dd5f8da7eab">getNodeFamily</a>().<a class="code" href="classripple_1_1Family.html#a794019ebd9859fb37a7a65b80e8d6df7">getTreeNodeCache</a>(0));</div>
|
|
|
|
|
<div class="line"><a name="l00346"></a><span class="lineno"> 346</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a30713fb55aeab5955e349a6386f59780">transactionDb_</a> = &<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a159af81c8290f27ae01e168236f1061c">getTxnDB</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00347"></a><span class="lineno"> 347</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#adee10cb6db30fd4c3f8e5597277968c0">ledgerDb_</a> = &<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#ae8c3bf5a8d7de3a98166670fde4056f7">getLedgerDB</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00348"></a><span class="lineno"> 348</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#ad3565edc1837d5c52c0df48387bfebad">advisoryDelete_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00349"></a><span class="lineno"> 349</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a2ccbaf612bcdd9b53b25453f50d3e298">canDelete_</a> = <a class="code" href="classripple_1_1SHAMapStoreImp.html#afd5c226c4b32f9bd93a16e1e15fcc015">state_db_</a>.<a class="code" href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#ad21f55aa2b33bc3f8c700a8c3f201a4b">getCanDelete</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00350"></a><span class="lineno"> 350</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00351"></a><span class="lineno"> 351</span>  <span class="keywordflow">while</span> (<span class="keyword">true</span>)</div>
|
|
|
|
|
<div class="line"><a name="l00352"></a><span class="lineno"> 352</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00353"></a><span class="lineno"> 353</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae3bbfded16bd305dd1ca60de09af1d97">healthy_</a> = <span class="keyword">true</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00354"></a><span class="lineno"> 354</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/memory/shared_ptr.html">std::shared_ptr<Ledger const></a> validatedLedger;</div>
|
|
|
|
|
<div class="line"><a name="l00355"></a><span class="lineno"> 355</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00356"></a><span class="lineno"> 356</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00357"></a><span class="lineno"> 357</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/unique_lock.html">std::unique_lock<std::mutex></a> lock(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a13915b042341ae4fe6232c5fd956ef57">mutex_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00358"></a><span class="lineno"> 358</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#aa45f27d51fbb9cf096b5a5d4d98284af">working_</a> = <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00359"></a><span class="lineno"> 359</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a048b5033b67fd76be2c12b86c2a6126e">rendezvous_</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/condition_variable/notify_all.html">notify_all</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00360"></a><span class="lineno"> 360</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3091814df4b2c4fbee9060bbd3bb7e40">stop_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00361"></a><span class="lineno"> 361</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00362"></a><span class="lineno"> 362</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00363"></a><span class="lineno"> 363</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00364"></a><span class="lineno"> 364</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00365"></a><span class="lineno"> 365</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a04d7e2ffe07292626a4f7a932ac93ab1">cond_</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/condition_variable/wait.html">wait</a>(lock);</div>
|
|
|
|
|
<div class="line"><a name="l00366"></a><span class="lineno"> 366</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#ae119e2119d3befba0d1388413ed47e5a">newLedger_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00367"></a><span class="lineno"> 367</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00368"></a><span class="lineno"> 368</span>  validatedLedger = std::move(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ae119e2119d3befba0d1388413ed47e5a">newLedger_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00369"></a><span class="lineno"> 369</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00370"></a><span class="lineno"> 370</span>  <span class="keywordflow">else</span></div>
|
|
|
|
|
<div class="line"><a name="l00371"></a><span class="lineno"> 371</span>  <span class="keywordflow">continue</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00372"></a><span class="lineno"> 372</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00373"></a><span class="lineno"> 373</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00374"></a><span class="lineno"> 374</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">LedgerIndex</a> <span class="keyword">const</span> validatedSeq = validatedLedger->info().seq;</div>
|
|
|
|
|
<div class="line"><a name="l00375"></a><span class="lineno"> 375</span>  <span class="keywordflow">if</span> (!lastRotated)</div>
|
|
|
|
|
<div class="line"><a name="l00376"></a><span class="lineno"> 376</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00377"></a><span class="lineno"> 377</span>  lastRotated = validatedSeq;</div>
|
|
|
|
|
<div class="line"><a name="l00378"></a><span class="lineno"> 378</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#afd5c226c4b32f9bd93a16e1e15fcc015">state_db_</a>.<a class="code" href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#ad08732c80f7c72199b1853d0516e1e0c">setLastRotated</a>(lastRotated);</div>
|
|
|
|
|
<div class="line"><a name="l00379"></a><span class="lineno"> 379</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00380"></a><span class="lineno"> 380</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00381"></a><span class="lineno"> 381</span>  <span class="comment">// will delete up to (not including) lastRotated</span></div>
|
|
|
|
|
<div class="line"><a name="l00382"></a><span class="lineno"> 382</span>  <span class="keywordflow">if</span> (validatedSeq >= lastRotated + <a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a> &&</div>
|
|
|
|
|
<div class="line"><a name="l00383"></a><span class="lineno"> 383</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a2ccbaf612bcdd9b53b25453f50d3e298">canDelete_</a> >= lastRotated - 1 && !<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00384"></a><span class="lineno"> 384</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00385"></a><span class="lineno"> 385</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#ad8fefe3e8ad583e1ed1bf02094ac3d8f">warn</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00386"></a><span class="lineno"> 386</span>  << <span class="stringliteral">"rotating validatedSeq "</span> << validatedSeq << <span class="stringliteral">" lastRotated "</span></div>
|
|
|
|
|
<div class="line"><a name="l00387"></a><span class="lineno"> 387</span>  << lastRotated << <span class="stringliteral">" deleteInterval "</span> << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a></div>
|
|
|
|
|
<div class="line"><a name="l00388"></a><span class="lineno"> 388</span>  << <span class="stringliteral">" canDelete_ "</span> << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a2ccbaf612bcdd9b53b25453f50d3e298">canDelete_</a> << <span class="stringliteral">" state "</span></div>
|
|
|
|
|
<div class="line"><a name="l00389"></a><span class="lineno"> 389</span>  << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a7c963aa5c47180b24897ff6b5622e5bc">getOPs</a>().<a class="code" href="classripple_1_1NetworkOPs.html#ad4c27eb535691555917e3b1ae5ab2637">strOperatingMode</a>(<span class="keyword">false</span>) << <span class="stringliteral">" age "</span></div>
|
|
|
|
|
<div class="line"><a name="l00390"></a><span class="lineno"> 390</span>  << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a>-><a class="code" href="classripple_1_1LedgerMaster.html#af6aa770a3d98a0a49d5091163fb675c9">getValidatedLedgerAge</a>().<a class="codeRef" href="http://en.cppreference.com/w/cpp/chrono/duration/count.html">count</a>() << <span class="charliteral">'s'</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00391"></a><span class="lineno"> 391</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00392"></a><span class="lineno"> 392</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a2b3b5566e7e19153f06459fced983932">clearPrior</a>(lastRotated);</div>
|
|
|
|
|
<div class="line"><a name="l00393"></a><span class="lineno"> 393</span>  <span class="keywordflow">switch</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00394"></a><span class="lineno"> 394</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00395"></a><span class="lineno"> 395</span>  <span class="keywordflow">case</span> Health::stopping:</div>
|
|
|
|
|
<div class="line"><a name="l00396"></a><span class="lineno"> 396</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00397"></a><span class="lineno"> 397</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00398"></a><span class="lineno"> 398</span>  <span class="keywordflow">case</span> Health::unhealthy:</div>
|
|
|
|
|
<div class="line"><a name="l00399"></a><span class="lineno"> 399</span>  <span class="keywordflow">continue</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00400"></a><span class="lineno"> 400</span>  <span class="keywordflow">case</span> Health::ok:</div>
|
|
|
|
|
<div class="line"><a name="l00401"></a><span class="lineno"> 401</span>  <span class="keywordflow">default</span>:;</div>
|
|
|
|
|
<div class="line"><a name="l00402"></a><span class="lineno"> 402</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00403"></a><span class="lineno"> 403</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00404"></a><span class="lineno"> 404</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << <span class="stringliteral">"copying ledger "</span> << validatedSeq;</div>
|
|
|
|
|
<div class="line"><a name="l00405"></a><span class="lineno"> 405</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">std::uint64_t</a> nodeCount = 0;</div>
|
|
|
|
|
<div class="line"><a name="l00406"></a><span class="lineno"> 406</span>  validatedLedger->stateMap().snapShot(<span class="keyword">false</span>)->visitNodes(<a class="codeRef" href="http://en.cppreference.com/w/cpp/utility/functional/bind.html">std::bind</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00407"></a><span class="lineno"> 407</span>  &<a class="code" href="classripple_1_1SHAMapStoreImp.html#ad702a7e0ba143504fd7fe4bab9952657">SHAMapStoreImp::copyNode</a>,</div>
|
|
|
|
|
<div class="line"><a name="l00408"></a><span class="lineno"> 408</span>  <span class="keyword">this</span>,</div>
|
|
|
|
|
<div class="line"><a name="l00409"></a><span class="lineno"> 409</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/utility/functional/ref.html">std::ref</a>(nodeCount),</div>
|
|
|
|
|
<div class="line"><a name="l00410"></a><span class="lineno"> 410</span>  std::placeholders::_1));</div>
|
|
|
|
|
<div class="line"><a name="l00411"></a><span class="lineno"> 411</span>  <span class="keywordflow">switch</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00412"></a><span class="lineno"> 412</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00413"></a><span class="lineno"> 413</span>  <span class="keywordflow">case</span> Health::stopping:</div>
|
|
|
|
|
<div class="line"><a name="l00414"></a><span class="lineno"> 414</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00415"></a><span class="lineno"> 415</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00416"></a><span class="lineno"> 416</span>  <span class="keywordflow">case</span> Health::unhealthy:</div>
|
|
|
|
|
<div class="line"><a name="l00417"></a><span class="lineno"> 417</span>  <span class="keywordflow">continue</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00418"></a><span class="lineno"> 418</span>  <span class="keywordflow">case</span> Health::ok:</div>
|
|
|
|
|
<div class="line"><a name="l00419"></a><span class="lineno"> 419</span>  <span class="keywordflow">default</span>:;</div>
|
|
|
|
|
<div class="line"><a name="l00420"></a><span class="lineno"> 420</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00421"></a><span class="lineno"> 421</span>  <span class="comment">// Only log if we completed without a "health" abort</span></div>
|
|
|
|
|
<div class="line"><a name="l00422"></a><span class="lineno"> 422</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << <span class="stringliteral">"copied ledger "</span> << validatedSeq</div>
|
|
|
|
|
<div class="line"><a name="l00423"></a><span class="lineno"> 423</span>  << <span class="stringliteral">" nodecount "</span> << nodeCount;</div>
|
|
|
|
|
<div class="line"><a name="l00424"></a><span class="lineno"> 424</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00425"></a><span class="lineno"> 425</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << <span class="stringliteral">"freshening caches"</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00426"></a><span class="lineno"> 426</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ad486e43fe6ea6c304d7cf119fb009894">freshenCaches</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00427"></a><span class="lineno"> 427</span>  <span class="keywordflow">switch</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00428"></a><span class="lineno"> 428</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00429"></a><span class="lineno"> 429</span>  <span class="keywordflow">case</span> Health::stopping:</div>
|
|
|
|
|
<div class="line"><a name="l00430"></a><span class="lineno"> 430</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00431"></a><span class="lineno"> 431</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00432"></a><span class="lineno"> 432</span>  <span class="keywordflow">case</span> Health::unhealthy:</div>
|
|
|
|
|
<div class="line"><a name="l00433"></a><span class="lineno"> 433</span>  <span class="keywordflow">continue</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00434"></a><span class="lineno"> 434</span>  <span class="keywordflow">case</span> Health::ok:</div>
|
|
|
|
|
<div class="line"><a name="l00435"></a><span class="lineno"> 435</span>  <span class="keywordflow">default</span>:;</div>
|
|
|
|
|
<div class="line"><a name="l00436"></a><span class="lineno"> 436</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00437"></a><span class="lineno"> 437</span>  <span class="comment">// Only log if we completed without a "health" abort</span></div>
|
|
|
|
|
<div class="line"><a name="l00438"></a><span class="lineno"> 438</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << validatedSeq << <span class="stringliteral">" freshened caches"</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00439"></a><span class="lineno"> 439</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00440"></a><span class="lineno"> 440</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"Making a new backend"</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00441"></a><span class="lineno"> 441</span>  <span class="keyword">auto</span> newBackend = <a class="code" href="classripple_1_1SHAMapStoreImp.html#a347e8e8ba053b93c6b924f277f535a94">makeBackendRotating</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00442"></a><span class="lineno"> 442</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00443"></a><span class="lineno"> 443</span>  << validatedSeq << <span class="stringliteral">" new backend "</span> << newBackend->getName();</div>
|
|
|
|
|
<div class="line"><a name="l00444"></a><span class="lineno"> 444</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00445"></a><span class="lineno"> 445</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#af823965870aa9d05f14c8591c771a74a">clearCaches</a>(validatedSeq);</div>
|
|
|
|
|
<div class="line"><a name="l00446"></a><span class="lineno"> 446</span>  <span class="keywordflow">switch</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00447"></a><span class="lineno"> 447</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00448"></a><span class="lineno"> 448</span>  <span class="keywordflow">case</span> Health::stopping:</div>
|
|
|
|
|
<div class="line"><a name="l00449"></a><span class="lineno"> 449</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00450"></a><span class="lineno"> 450</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00451"></a><span class="lineno"> 451</span>  <span class="keywordflow">case</span> Health::unhealthy:</div>
|
|
|
|
|
<div class="line"><a name="l00452"></a><span class="lineno"> 452</span>  <span class="keywordflow">continue</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00453"></a><span class="lineno"> 453</span>  <span class="keywordflow">case</span> Health::ok:</div>
|
|
|
|
|
<div class="line"><a name="l00454"></a><span class="lineno"> 454</span>  <span class="keywordflow">default</span>:;</div>
|
|
|
|
|
<div class="line"><a name="l00455"></a><span class="lineno"> 455</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00456"></a><span class="lineno"> 456</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00457"></a><span class="lineno"> 457</span>  lastRotated = validatedSeq;</div>
|
|
|
|
|
<div class="line"><a name="l00458"></a><span class="lineno"> 458</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00459"></a><span class="lineno"> 459</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a16657ed3d270e84f7147dc53ba937ffc">dbRotating_</a>-><a class="code" href="classripple_1_1NodeStore_1_1DatabaseRotating.html#ae436a072e5a6068e819776a53fc0ab25">rotateWithLock</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00460"></a><span class="lineno"> 460</span>  [&](<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string.html">std::string</a> <span class="keyword">const</span>& writableBackendName) {</div>
|
|
|
|
|
<div class="line"><a name="l00461"></a><span class="lineno"> 461</span>  <a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html">SavedState</a> savedState;</div>
|
|
|
|
|
<div class="line"><a name="l00462"></a><span class="lineno"> 462</span>  savedState.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a> = newBackend->getName();</div>
|
|
|
|
|
<div class="line"><a name="l00463"></a><span class="lineno"> 463</span>  savedState.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a> = writableBackendName;</div>
|
|
|
|
|
<div class="line"><a name="l00464"></a><span class="lineno"> 464</span>  savedState.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#ac7e9c511cbe5a6282e214f755f359152">lastRotated</a> = lastRotated;</div>
|
|
|
|
|
<div class="line"><a name="l00465"></a><span class="lineno"> 465</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#afd5c226c4b32f9bd93a16e1e15fcc015">state_db_</a>.<a class="code" href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#a2ff3adb29b03343ad89a6d9e6a7e82aa">setState</a>(savedState);</div>
|
|
|
|
|
<div class="line"><a name="l00466"></a><span class="lineno"> 466</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00467"></a><span class="lineno"> 467</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#af823965870aa9d05f14c8591c771a74a">clearCaches</a>(validatedSeq);</div>
|
|
|
|
|
<div class="line"><a name="l00468"></a><span class="lineno"> 468</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00469"></a><span class="lineno"> 469</span>  <span class="keywordflow">return</span> std::move(newBackend);</div>
|
|
|
|
|
<div class="line"><a name="l00470"></a><span class="lineno"> 470</span>  });</div>
|
|
|
|
|
<div class="line"><a name="l00471"></a><span class="lineno"> 471</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00472"></a><span class="lineno"> 472</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#ad8fefe3e8ad583e1ed1bf02094ac3d8f">warn</a>()) << <span class="stringliteral">"finished rotation "</span> << validatedSeq;</div>
|
|
|
|
|
<div class="line"><a name="l00473"></a><span class="lineno"> 473</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00346"></a><span class="lineno"> 346</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1Config.html#aa09be5266eca22f68f27e60169291ec5">useTxTables</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00347"></a><span class="lineno"> 347</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a30713fb55aeab5955e349a6386f59780">transactionDb_</a> = &<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a159af81c8290f27ae01e168236f1061c">getTxnDB</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00348"></a><span class="lineno"> 348</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#adee10cb6db30fd4c3f8e5597277968c0">ledgerDb_</a> = &<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#ae8c3bf5a8d7de3a98166670fde4056f7">getLedgerDB</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00349"></a><span class="lineno"> 349</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#ad3565edc1837d5c52c0df48387bfebad">advisoryDelete_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00350"></a><span class="lineno"> 350</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a2ccbaf612bcdd9b53b25453f50d3e298">canDelete_</a> = <a class="code" href="classripple_1_1SHAMapStoreImp.html#afd5c226c4b32f9bd93a16e1e15fcc015">state_db_</a>.<a class="code" href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#ad21f55aa2b33bc3f8c700a8c3f201a4b">getCanDelete</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00351"></a><span class="lineno"> 351</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00352"></a><span class="lineno"> 352</span>  <span class="keywordflow">while</span> (<span class="keyword">true</span>)</div>
|
|
|
|
|
<div class="line"><a name="l00353"></a><span class="lineno"> 353</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00354"></a><span class="lineno"> 354</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae3bbfded16bd305dd1ca60de09af1d97">healthy_</a> = <span class="keyword">true</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00355"></a><span class="lineno"> 355</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/memory/shared_ptr.html">std::shared_ptr<Ledger const></a> validatedLedger;</div>
|
|
|
|
|
<div class="line"><a name="l00356"></a><span class="lineno"> 356</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00357"></a><span class="lineno"> 357</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00358"></a><span class="lineno"> 358</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/unique_lock.html">std::unique_lock<std::mutex></a> lock(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a13915b042341ae4fe6232c5fd956ef57">mutex_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00359"></a><span class="lineno"> 359</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#aa45f27d51fbb9cf096b5a5d4d98284af">working_</a> = <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00360"></a><span class="lineno"> 360</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a048b5033b67fd76be2c12b86c2a6126e">rendezvous_</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/condition_variable/notify_all.html">notify_all</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00361"></a><span class="lineno"> 361</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3091814df4b2c4fbee9060bbd3bb7e40">stop_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00362"></a><span class="lineno"> 362</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00363"></a><span class="lineno"> 363</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00364"></a><span class="lineno"> 364</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00365"></a><span class="lineno"> 365</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00366"></a><span class="lineno"> 366</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a04d7e2ffe07292626a4f7a932ac93ab1">cond_</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/condition_variable/wait.html">wait</a>(lock);</div>
|
|
|
|
|
<div class="line"><a name="l00367"></a><span class="lineno"> 367</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#ae119e2119d3befba0d1388413ed47e5a">newLedger_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00368"></a><span class="lineno"> 368</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00369"></a><span class="lineno"> 369</span>  validatedLedger = std::move(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ae119e2119d3befba0d1388413ed47e5a">newLedger_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00370"></a><span class="lineno"> 370</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00371"></a><span class="lineno"> 371</span>  <span class="keywordflow">else</span></div>
|
|
|
|
|
<div class="line"><a name="l00372"></a><span class="lineno"> 372</span>  <span class="keywordflow">continue</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00373"></a><span class="lineno"> 373</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00374"></a><span class="lineno"> 374</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00375"></a><span class="lineno"> 375</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">LedgerIndex</a> <span class="keyword">const</span> validatedSeq = validatedLedger->info().seq;</div>
|
|
|
|
|
<div class="line"><a name="l00376"></a><span class="lineno"> 376</span>  <span class="keywordflow">if</span> (!lastRotated)</div>
|
|
|
|
|
<div class="line"><a name="l00377"></a><span class="lineno"> 377</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00378"></a><span class="lineno"> 378</span>  lastRotated = validatedSeq;</div>
|
|
|
|
|
<div class="line"><a name="l00379"></a><span class="lineno"> 379</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#afd5c226c4b32f9bd93a16e1e15fcc015">state_db_</a>.<a class="code" href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#ad08732c80f7c72199b1853d0516e1e0c">setLastRotated</a>(lastRotated);</div>
|
|
|
|
|
<div class="line"><a name="l00380"></a><span class="lineno"> 380</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00381"></a><span class="lineno"> 381</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00382"></a><span class="lineno"> 382</span>  <span class="comment">// will delete up to (not including) lastRotated</span></div>
|
|
|
|
|
<div class="line"><a name="l00383"></a><span class="lineno"> 383</span>  <span class="keywordflow">if</span> (validatedSeq >= lastRotated + <a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a> &&</div>
|
|
|
|
|
<div class="line"><a name="l00384"></a><span class="lineno"> 384</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a2ccbaf612bcdd9b53b25453f50d3e298">canDelete_</a> >= lastRotated - 1 && !<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00385"></a><span class="lineno"> 385</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00386"></a><span class="lineno"> 386</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#ad8fefe3e8ad583e1ed1bf02094ac3d8f">warn</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00387"></a><span class="lineno"> 387</span>  << <span class="stringliteral">"rotating validatedSeq "</span> << validatedSeq << <span class="stringliteral">" lastRotated "</span></div>
|
|
|
|
|
<div class="line"><a name="l00388"></a><span class="lineno"> 388</span>  << lastRotated << <span class="stringliteral">" deleteInterval "</span> << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a></div>
|
|
|
|
|
<div class="line"><a name="l00389"></a><span class="lineno"> 389</span>  << <span class="stringliteral">" canDelete_ "</span> << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a2ccbaf612bcdd9b53b25453f50d3e298">canDelete_</a> << <span class="stringliteral">" state "</span></div>
|
|
|
|
|
<div class="line"><a name="l00390"></a><span class="lineno"> 390</span>  << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a7c963aa5c47180b24897ff6b5622e5bc">getOPs</a>().<a class="code" href="classripple_1_1NetworkOPs.html#ad4c27eb535691555917e3b1ae5ab2637">strOperatingMode</a>(<span class="keyword">false</span>) << <span class="stringliteral">" age "</span></div>
|
|
|
|
|
<div class="line"><a name="l00391"></a><span class="lineno"> 391</span>  << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a>-><a class="code" href="classripple_1_1LedgerMaster.html#af6aa770a3d98a0a49d5091163fb675c9">getValidatedLedgerAge</a>().<a class="codeRef" href="http://en.cppreference.com/w/cpp/chrono/duration/count.html">count</a>() << <span class="charliteral">'s'</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00392"></a><span class="lineno"> 392</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00393"></a><span class="lineno"> 393</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a2b3b5566e7e19153f06459fced983932">clearPrior</a>(lastRotated);</div>
|
|
|
|
|
<div class="line"><a name="l00394"></a><span class="lineno"> 394</span>  <span class="keywordflow">switch</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00395"></a><span class="lineno"> 395</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00396"></a><span class="lineno"> 396</span>  <span class="keywordflow">case</span> Health::stopping:</div>
|
|
|
|
|
<div class="line"><a name="l00397"></a><span class="lineno"> 397</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00398"></a><span class="lineno"> 398</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00399"></a><span class="lineno"> 399</span>  <span class="keywordflow">case</span> Health::unhealthy:</div>
|
|
|
|
|
<div class="line"><a name="l00400"></a><span class="lineno"> 400</span>  <span class="keywordflow">continue</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00401"></a><span class="lineno"> 401</span>  <span class="keywordflow">case</span> Health::ok:</div>
|
|
|
|
|
<div class="line"><a name="l00402"></a><span class="lineno"> 402</span>  <span class="keywordflow">default</span>:;</div>
|
|
|
|
|
<div class="line"><a name="l00403"></a><span class="lineno"> 403</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00404"></a><span class="lineno"> 404</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00405"></a><span class="lineno"> 405</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << <span class="stringliteral">"copying ledger "</span> << validatedSeq;</div>
|
|
|
|
|
<div class="line"><a name="l00406"></a><span class="lineno"> 406</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">std::uint64_t</a> nodeCount = 0;</div>
|
|
|
|
|
<div class="line"><a name="l00407"></a><span class="lineno"> 407</span>  validatedLedger->stateMap().snapShot(<span class="keyword">false</span>)->visitNodes(<a class="codeRef" href="http://en.cppreference.com/w/cpp/utility/functional/bind.html">std::bind</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00408"></a><span class="lineno"> 408</span>  &<a class="code" href="classripple_1_1SHAMapStoreImp.html#ad702a7e0ba143504fd7fe4bab9952657">SHAMapStoreImp::copyNode</a>,</div>
|
|
|
|
|
<div class="line"><a name="l00409"></a><span class="lineno"> 409</span>  <span class="keyword">this</span>,</div>
|
|
|
|
|
<div class="line"><a name="l00410"></a><span class="lineno"> 410</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/utility/functional/ref.html">std::ref</a>(nodeCount),</div>
|
|
|
|
|
<div class="line"><a name="l00411"></a><span class="lineno"> 411</span>  std::placeholders::_1));</div>
|
|
|
|
|
<div class="line"><a name="l00412"></a><span class="lineno"> 412</span>  <span class="keywordflow">switch</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00413"></a><span class="lineno"> 413</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00414"></a><span class="lineno"> 414</span>  <span class="keywordflow">case</span> Health::stopping:</div>
|
|
|
|
|
<div class="line"><a name="l00415"></a><span class="lineno"> 415</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00416"></a><span class="lineno"> 416</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00417"></a><span class="lineno"> 417</span>  <span class="keywordflow">case</span> Health::unhealthy:</div>
|
|
|
|
|
<div class="line"><a name="l00418"></a><span class="lineno"> 418</span>  <span class="keywordflow">continue</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00419"></a><span class="lineno"> 419</span>  <span class="keywordflow">case</span> Health::ok:</div>
|
|
|
|
|
<div class="line"><a name="l00420"></a><span class="lineno"> 420</span>  <span class="keywordflow">default</span>:;</div>
|
|
|
|
|
<div class="line"><a name="l00421"></a><span class="lineno"> 421</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00422"></a><span class="lineno"> 422</span>  <span class="comment">// Only log if we completed without a "health" abort</span></div>
|
|
|
|
|
<div class="line"><a name="l00423"></a><span class="lineno"> 423</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << <span class="stringliteral">"copied ledger "</span> << validatedSeq</div>
|
|
|
|
|
<div class="line"><a name="l00424"></a><span class="lineno"> 424</span>  << <span class="stringliteral">" nodecount "</span> << nodeCount;</div>
|
|
|
|
|
<div class="line"><a name="l00425"></a><span class="lineno"> 425</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00426"></a><span class="lineno"> 426</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << <span class="stringliteral">"freshening caches"</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00427"></a><span class="lineno"> 427</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ad486e43fe6ea6c304d7cf119fb009894">freshenCaches</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00428"></a><span class="lineno"> 428</span>  <span class="keywordflow">switch</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00429"></a><span class="lineno"> 429</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00430"></a><span class="lineno"> 430</span>  <span class="keywordflow">case</span> Health::stopping:</div>
|
|
|
|
|
<div class="line"><a name="l00431"></a><span class="lineno"> 431</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00432"></a><span class="lineno"> 432</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00433"></a><span class="lineno"> 433</span>  <span class="keywordflow">case</span> Health::unhealthy:</div>
|
|
|
|
|
<div class="line"><a name="l00434"></a><span class="lineno"> 434</span>  <span class="keywordflow">continue</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00435"></a><span class="lineno"> 435</span>  <span class="keywordflow">case</span> Health::ok:</div>
|
|
|
|
|
<div class="line"><a name="l00436"></a><span class="lineno"> 436</span>  <span class="keywordflow">default</span>:;</div>
|
|
|
|
|
<div class="line"><a name="l00437"></a><span class="lineno"> 437</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00438"></a><span class="lineno"> 438</span>  <span class="comment">// Only log if we completed without a "health" abort</span></div>
|
|
|
|
|
<div class="line"><a name="l00439"></a><span class="lineno"> 439</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << validatedSeq << <span class="stringliteral">" freshened caches"</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00440"></a><span class="lineno"> 440</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00441"></a><span class="lineno"> 441</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"Making a new backend"</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00442"></a><span class="lineno"> 442</span>  <span class="keyword">auto</span> newBackend = <a class="code" href="classripple_1_1SHAMapStoreImp.html#a347e8e8ba053b93c6b924f277f535a94">makeBackendRotating</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00443"></a><span class="lineno"> 443</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00444"></a><span class="lineno"> 444</span>  << validatedSeq << <span class="stringliteral">" new backend "</span> << newBackend->getName();</div>
|
|
|
|
|
<div class="line"><a name="l00445"></a><span class="lineno"> 445</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00446"></a><span class="lineno"> 446</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#af823965870aa9d05f14c8591c771a74a">clearCaches</a>(validatedSeq);</div>
|
|
|
|
|
<div class="line"><a name="l00447"></a><span class="lineno"> 447</span>  <span class="keywordflow">switch</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00448"></a><span class="lineno"> 448</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00449"></a><span class="lineno"> 449</span>  <span class="keywordflow">case</span> Health::stopping:</div>
|
|
|
|
|
<div class="line"><a name="l00450"></a><span class="lineno"> 450</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00451"></a><span class="lineno"> 451</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00452"></a><span class="lineno"> 452</span>  <span class="keywordflow">case</span> Health::unhealthy:</div>
|
|
|
|
|
<div class="line"><a name="l00453"></a><span class="lineno"> 453</span>  <span class="keywordflow">continue</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00454"></a><span class="lineno"> 454</span>  <span class="keywordflow">case</span> Health::ok:</div>
|
|
|
|
|
<div class="line"><a name="l00455"></a><span class="lineno"> 455</span>  <span class="keywordflow">default</span>:;</div>
|
|
|
|
|
<div class="line"><a name="l00456"></a><span class="lineno"> 456</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00457"></a><span class="lineno"> 457</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00458"></a><span class="lineno"> 458</span>  lastRotated = validatedSeq;</div>
|
|
|
|
|
<div class="line"><a name="l00459"></a><span class="lineno"> 459</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00460"></a><span class="lineno"> 460</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a16657ed3d270e84f7147dc53ba937ffc">dbRotating_</a>-><a class="code" href="classripple_1_1NodeStore_1_1DatabaseRotating.html#ae436a072e5a6068e819776a53fc0ab25">rotateWithLock</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00461"></a><span class="lineno"> 461</span>  [&](<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string.html">std::string</a> <span class="keyword">const</span>& writableBackendName) {</div>
|
|
|
|
|
<div class="line"><a name="l00462"></a><span class="lineno"> 462</span>  <a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html">SavedState</a> savedState;</div>
|
|
|
|
|
<div class="line"><a name="l00463"></a><span class="lineno"> 463</span>  savedState.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a> = newBackend->getName();</div>
|
|
|
|
|
<div class="line"><a name="l00464"></a><span class="lineno"> 464</span>  savedState.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a> = writableBackendName;</div>
|
|
|
|
|
<div class="line"><a name="l00465"></a><span class="lineno"> 465</span>  savedState.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#ac7e9c511cbe5a6282e214f755f359152">lastRotated</a> = lastRotated;</div>
|
|
|
|
|
<div class="line"><a name="l00466"></a><span class="lineno"> 466</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#afd5c226c4b32f9bd93a16e1e15fcc015">state_db_</a>.<a class="code" href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#a2ff3adb29b03343ad89a6d9e6a7e82aa">setState</a>(savedState);</div>
|
|
|
|
|
<div class="line"><a name="l00467"></a><span class="lineno"> 467</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00468"></a><span class="lineno"> 468</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#af823965870aa9d05f14c8591c771a74a">clearCaches</a>(validatedSeq);</div>
|
|
|
|
|
<div class="line"><a name="l00469"></a><span class="lineno"> 469</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00470"></a><span class="lineno"> 470</span>  <span class="keywordflow">return</span> std::move(newBackend);</div>
|
|
|
|
|
<div class="line"><a name="l00471"></a><span class="lineno"> 471</span>  });</div>
|
|
|
|
|
<div class="line"><a name="l00472"></a><span class="lineno"> 472</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00473"></a><span class="lineno"> 473</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#ad8fefe3e8ad583e1ed1bf02094ac3d8f">warn</a>()) << <span class="stringliteral">"finished rotation "</span> << validatedSeq;</div>
|
|
|
|
|
<div class="line"><a name="l00474"></a><span class="lineno"> 474</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00475"></a><span class="lineno"> 475</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00476"></a><span class="lineno"> 476</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00477"></a><span class="lineno"> 477</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00478"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#a08a9e9740aebfe570df764bc48d7d554"> 478</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a08a9e9740aebfe570df764bc48d7d554">SHAMapStoreImp::dbPaths</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00479"></a><span class="lineno"> 479</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00480"></a><span class="lineno"> 480</span>  <a class="code" href="classripple_1_1Section.html">Section</a> section{<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1BasicConfig.html#a60aca585d76b1121dd4f72b358729456">section</a>(<a class="code" href="structripple_1_1ConfigSection.html#a44ee859a6705ddcac4e318602f8fe6ac">ConfigSection::nodeDatabase</a>())};</div>
|
|
|
|
|
<div class="line"><a name="l00481"></a><span class="lineno"> 481</span>  boost::filesystem::path dbPath = get<std::string>(section, <span class="stringliteral">"path"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00482"></a><span class="lineno"> 482</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00483"></a><span class="lineno"> 483</span>  <span class="keywordflow">if</span> (boost::filesystem::exists(dbPath))</div>
|
|
|
|
|
<div class="line"><a name="l00484"></a><span class="lineno"> 484</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00485"></a><span class="lineno"> 485</span>  <span class="keywordflow">if</span> (!boost::filesystem::is_directory(dbPath))</div>
|
|
|
|
|
<div class="line"><a name="l00486"></a><span class="lineno"> 486</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00487"></a><span class="lineno"> 487</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a49b0713e65bb8e2c51b76fbf16252afe">error</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00488"></a><span class="lineno"> 488</span>  << <span class="stringliteral">"node db path must be a directory. "</span> << dbPath.string();</div>
|
|
|
|
|
<div class="line"><a name="l00489"></a><span class="lineno"> 489</span>  Throw<std::runtime_error>(<span class="stringliteral">"node db path must be a directory."</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00490"></a><span class="lineno"> 490</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00475"></a><span class="lineno"> 475</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00476"></a><span class="lineno"> 476</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00477"></a><span class="lineno"> 477</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00478"></a><span class="lineno"> 478</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00479"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#a08a9e9740aebfe570df764bc48d7d554"> 479</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a08a9e9740aebfe570df764bc48d7d554">SHAMapStoreImp::dbPaths</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00480"></a><span class="lineno"> 480</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00481"></a><span class="lineno"> 481</span>  <a class="code" href="classripple_1_1Section.html">Section</a> section{<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1BasicConfig.html#a60aca585d76b1121dd4f72b358729456">section</a>(<a class="code" href="structripple_1_1ConfigSection.html#a44ee859a6705ddcac4e318602f8fe6ac">ConfigSection::nodeDatabase</a>())};</div>
|
|
|
|
|
<div class="line"><a name="l00482"></a><span class="lineno"> 482</span>  boost::filesystem::path dbPath = get<std::string>(section, <span class="stringliteral">"path"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00483"></a><span class="lineno"> 483</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00484"></a><span class="lineno"> 484</span>  <span class="keywordflow">if</span> (boost::filesystem::exists(dbPath))</div>
|
|
|
|
|
<div class="line"><a name="l00485"></a><span class="lineno"> 485</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00486"></a><span class="lineno"> 486</span>  <span class="keywordflow">if</span> (!boost::filesystem::is_directory(dbPath))</div>
|
|
|
|
|
<div class="line"><a name="l00487"></a><span class="lineno"> 487</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00488"></a><span class="lineno"> 488</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a49b0713e65bb8e2c51b76fbf16252afe">error</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00489"></a><span class="lineno"> 489</span>  << <span class="stringliteral">"node db path must be a directory. "</span> << dbPath.string();</div>
|
|
|
|
|
<div class="line"><a name="l00490"></a><span class="lineno"> 490</span>  Throw<std::runtime_error>(<span class="stringliteral">"node db path must be a directory."</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00491"></a><span class="lineno"> 491</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00492"></a><span class="lineno"> 492</span>  <span class="keywordflow">else</span></div>
|
|
|
|
|
<div class="line"><a name="l00493"></a><span class="lineno"> 493</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00494"></a><span class="lineno"> 494</span>  boost::filesystem::create_directories(dbPath);</div>
|
|
|
|
|
<div class="line"><a name="l00495"></a><span class="lineno"> 495</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00496"></a><span class="lineno"> 496</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00497"></a><span class="lineno"> 497</span>  <a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html">SavedState</a> state = <a class="code" href="classripple_1_1SHAMapStoreImp.html#afd5c226c4b32f9bd93a16e1e15fcc015">state_db_</a>.<a class="code" href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#adb71d9af881fdbd4a49cddbe69d38e68">getState</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00498"></a><span class="lineno"> 498</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00499"></a><span class="lineno"> 499</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00500"></a><span class="lineno"> 500</span>  <span class="keyword">auto</span> update = [&dbPath](<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string.html">std::string</a>& sPath) {</div>
|
|
|
|
|
<div class="line"><a name="l00501"></a><span class="lineno"> 501</span>  <span class="keywordflow">if</span> (sPath.empty())</div>
|
|
|
|
|
<div class="line"><a name="l00502"></a><span class="lineno"> 502</span>  <span class="keywordflow">return</span> <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00503"></a><span class="lineno"> 503</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00504"></a><span class="lineno"> 504</span>  <span class="comment">// Check if configured "path" matches stored directory path</span></div>
|
|
|
|
|
<div class="line"><a name="l00505"></a><span class="lineno"> 505</span>  <span class="keyword">using namespace </span>boost::filesystem;</div>
|
|
|
|
|
<div class="line"><a name="l00506"></a><span class="lineno"> 506</span>  <span class="keyword">auto</span> <span class="keyword">const</span> stored{path(sPath)};</div>
|
|
|
|
|
<div class="line"><a name="l00507"></a><span class="lineno"> 507</span>  <span class="keywordflow">if</span> (stored.parent_path() == dbPath)</div>
|
|
|
|
|
<div class="line"><a name="l00508"></a><span class="lineno"> 508</span>  <span class="keywordflow">return</span> <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00509"></a><span class="lineno"> 509</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00510"></a><span class="lineno"> 510</span>  sPath = (dbPath / stored.filename()).<span class="keywordtype">string</span>();</div>
|
|
|
|
|
<div class="line"><a name="l00511"></a><span class="lineno"> 511</span>  <span class="keywordflow">return</span> <span class="keyword">true</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00512"></a><span class="lineno"> 512</span>  };</div>
|
|
|
|
|
<div class="line"><a name="l00513"></a><span class="lineno"> 513</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00514"></a><span class="lineno"> 514</span>  <span class="keywordflow">if</span> (update(state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a>))</div>
|
|
|
|
|
<div class="line"><a name="l00515"></a><span class="lineno"> 515</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00516"></a><span class="lineno"> 516</span>  update(state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00517"></a><span class="lineno"> 517</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#afd5c226c4b32f9bd93a16e1e15fcc015">state_db_</a>.<a class="code" href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#a2ff3adb29b03343ad89a6d9e6a7e82aa">setState</a>(state);</div>
|
|
|
|
|
<div class="line"><a name="l00518"></a><span class="lineno"> 518</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00492"></a><span class="lineno"> 492</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00493"></a><span class="lineno"> 493</span>  <span class="keywordflow">else</span></div>
|
|
|
|
|
<div class="line"><a name="l00494"></a><span class="lineno"> 494</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00495"></a><span class="lineno"> 495</span>  boost::filesystem::create_directories(dbPath);</div>
|
|
|
|
|
<div class="line"><a name="l00496"></a><span class="lineno"> 496</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00497"></a><span class="lineno"> 497</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00498"></a><span class="lineno"> 498</span>  <a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html">SavedState</a> state = <a class="code" href="classripple_1_1SHAMapStoreImp.html#afd5c226c4b32f9bd93a16e1e15fcc015">state_db_</a>.<a class="code" href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#adb71d9af881fdbd4a49cddbe69d38e68">getState</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00499"></a><span class="lineno"> 499</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00500"></a><span class="lineno"> 500</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00501"></a><span class="lineno"> 501</span>  <span class="keyword">auto</span> update = [&dbPath](<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string.html">std::string</a>& sPath) {</div>
|
|
|
|
|
<div class="line"><a name="l00502"></a><span class="lineno"> 502</span>  <span class="keywordflow">if</span> (sPath.empty())</div>
|
|
|
|
|
<div class="line"><a name="l00503"></a><span class="lineno"> 503</span>  <span class="keywordflow">return</span> <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00504"></a><span class="lineno"> 504</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00505"></a><span class="lineno"> 505</span>  <span class="comment">// Check if configured "path" matches stored directory path</span></div>
|
|
|
|
|
<div class="line"><a name="l00506"></a><span class="lineno"> 506</span>  <span class="keyword">using namespace </span>boost::filesystem;</div>
|
|
|
|
|
<div class="line"><a name="l00507"></a><span class="lineno"> 507</span>  <span class="keyword">auto</span> <span class="keyword">const</span> stored{path(sPath)};</div>
|
|
|
|
|
<div class="line"><a name="l00508"></a><span class="lineno"> 508</span>  <span class="keywordflow">if</span> (stored.parent_path() == dbPath)</div>
|
|
|
|
|
<div class="line"><a name="l00509"></a><span class="lineno"> 509</span>  <span class="keywordflow">return</span> <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00510"></a><span class="lineno"> 510</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00511"></a><span class="lineno"> 511</span>  sPath = (dbPath / stored.filename()).<span class="keywordtype">string</span>();</div>
|
|
|
|
|
<div class="line"><a name="l00512"></a><span class="lineno"> 512</span>  <span class="keywordflow">return</span> <span class="keyword">true</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00513"></a><span class="lineno"> 513</span>  };</div>
|
|
|
|
|
<div class="line"><a name="l00514"></a><span class="lineno"> 514</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00515"></a><span class="lineno"> 515</span>  <span class="keywordflow">if</span> (update(state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a>))</div>
|
|
|
|
|
<div class="line"><a name="l00516"></a><span class="lineno"> 516</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00517"></a><span class="lineno"> 517</span>  update(state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00518"></a><span class="lineno"> 518</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#afd5c226c4b32f9bd93a16e1e15fcc015">state_db_</a>.<a class="code" href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#a2ff3adb29b03343ad89a6d9e6a7e82aa">setState</a>(state);</div>
|
|
|
|
|
<div class="line"><a name="l00519"></a><span class="lineno"> 519</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00520"></a><span class="lineno"> 520</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00521"></a><span class="lineno"> 521</span>  <span class="keywordtype">bool</span> writableDbExists = <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00522"></a><span class="lineno"> 522</span>  <span class="keywordtype">bool</span> archiveDbExists = <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00523"></a><span class="lineno"> 523</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00524"></a><span class="lineno"> 524</span>  <span class="keywordflow">for</span> (boost::filesystem::directory_iterator it(dbPath);</div>
|
|
|
|
|
<div class="line"><a name="l00525"></a><span class="lineno"> 525</span>  it != boost::filesystem::directory_iterator();</div>
|
|
|
|
|
<div class="line"><a name="l00526"></a><span class="lineno"> 526</span>  ++it)</div>
|
|
|
|
|
<div class="line"><a name="l00527"></a><span class="lineno"> 527</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00528"></a><span class="lineno"> 528</span>  <span class="keywordflow">if</span> (!state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/compare.html">compare</a>(it->path().string()))</div>
|
|
|
|
|
<div class="line"><a name="l00529"></a><span class="lineno"> 529</span>  writableDbExists = <span class="keyword">true</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00530"></a><span class="lineno"> 530</span>  <span class="keywordflow">else</span> <span class="keywordflow">if</span> (!state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/compare.html">compare</a>(it->path().string()))</div>
|
|
|
|
|
<div class="line"><a name="l00531"></a><span class="lineno"> 531</span>  archiveDbExists = <span class="keyword">true</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00532"></a><span class="lineno"> 532</span>  <span class="keywordflow">else</span> <span class="keywordflow">if</span> (!<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3596d0251740f6199a9f561ded944a16">dbPrefix_</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/compare.html">compare</a>(it->path().stem().string()))</div>
|
|
|
|
|
<div class="line"><a name="l00533"></a><span class="lineno"> 533</span>  boost::filesystem::remove_all(it->path());</div>
|
|
|
|
|
<div class="line"><a name="l00534"></a><span class="lineno"> 534</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00535"></a><span class="lineno"> 535</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00536"></a><span class="lineno"> 536</span>  <span class="keywordflow">if</span> ((!writableDbExists && state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/size.html">size</a>()) ||</div>
|
|
|
|
|
<div class="line"><a name="l00537"></a><span class="lineno"> 537</span>  (!archiveDbExists && state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/size.html">size</a>()) ||</div>
|
|
|
|
|
<div class="line"><a name="l00538"></a><span class="lineno"> 538</span>  (writableDbExists != archiveDbExists) ||</div>
|
|
|
|
|
<div class="line"><a name="l00539"></a><span class="lineno"> 539</span>  state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/empty.html">empty</a>() != state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/empty.html">empty</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00540"></a><span class="lineno"> 540</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00541"></a><span class="lineno"> 541</span>  boost::filesystem::path stateDbPathName =</div>
|
|
|
|
|
<div class="line"><a name="l00542"></a><span class="lineno"> 542</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1BasicConfig.html#ae2c21d011e6424d4917db175ef9df301">legacy</a>(<span class="stringliteral">"database_path"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00543"></a><span class="lineno"> 543</span>  stateDbPathName /= <a class="code" href="classripple_1_1SHAMapStoreImp.html#ada1f2f842cafba373412841435061c5f">dbName_</a>;</div>
|
|
|
|
|
<div class="line"><a name="l00544"></a><span class="lineno"> 544</span>  stateDbPathName += <span class="stringliteral">"*"</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00545"></a><span class="lineno"> 545</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00546"></a><span class="lineno"> 546</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a49b0713e65bb8e2c51b76fbf16252afe">error</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00547"></a><span class="lineno"> 547</span>  << <span class="stringliteral">"state db error:\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00548"></a><span class="lineno"> 548</span>  << <span class="stringliteral">" writableDbExists "</span> << writableDbExists << <span class="stringliteral">" archiveDbExists "</span></div>
|
|
|
|
|
<div class="line"><a name="l00549"></a><span class="lineno"> 549</span>  << archiveDbExists << <span class="charliteral">'\n'</span></div>
|
|
|
|
|
<div class="line"><a name="l00550"></a><span class="lineno"> 550</span>  << <span class="stringliteral">" writableDb '"</span> << state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a> << <span class="stringliteral">"' archiveDb '"</span></div>
|
|
|
|
|
<div class="line"><a name="l00551"></a><span class="lineno"> 551</span>  << state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a> << <span class="stringliteral">"\n\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00552"></a><span class="lineno"> 552</span>  << <span class="stringliteral">"The existing data is in a corrupted state.\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00553"></a><span class="lineno"> 553</span>  << <span class="stringliteral">"To resume operation, remove the files matching "</span></div>
|
|
|
|
|
<div class="line"><a name="l00554"></a><span class="lineno"> 554</span>  << stateDbPathName.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/basic_string.html">string</a>() << <span class="stringliteral">" and contents of the directory "</span></div>
|
|
|
|
|
<div class="line"><a name="l00555"></a><span class="lineno"> 555</span>  << get<std::string>(section, <span class="stringliteral">"path"</span>) << <span class="charliteral">'\n'</span></div>
|
|
|
|
|
<div class="line"><a name="l00556"></a><span class="lineno"> 556</span>  << <span class="stringliteral">"Optionally, you can move those files to another\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00557"></a><span class="lineno"> 557</span>  << <span class="stringliteral">"location if you wish to analyze or back up the data.\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00558"></a><span class="lineno"> 558</span>  << <span class="stringliteral">"However, there is no guarantee that the data in its\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00559"></a><span class="lineno"> 559</span>  << <span class="stringliteral">"existing form is usable."</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00560"></a><span class="lineno"> 560</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00561"></a><span class="lineno"> 561</span>  Throw<std::runtime_error>(<span class="stringliteral">"state db error"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00562"></a><span class="lineno"> 562</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00563"></a><span class="lineno"> 563</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00564"></a><span class="lineno"> 564</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00565"></a><span class="lineno"> 565</span> <a class="codeRef" href="http://en.cppreference.com/w/cpp/memory/unique_ptr.html">std::unique_ptr<NodeStore::Backend></a></div>
|
|
|
|
|
<div class="line"><a name="l00566"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#a347e8e8ba053b93c6b924f277f535a94"> 566</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a347e8e8ba053b93c6b924f277f535a94">SHAMapStoreImp::makeBackendRotating</a>(<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string.html">std::string</a> path)</div>
|
|
|
|
|
<div class="line"><a name="l00567"></a><span class="lineno"> 567</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00568"></a><span class="lineno"> 568</span>  <a class="code" href="classripple_1_1Section.html">Section</a> section{<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1BasicConfig.html#a60aca585d76b1121dd4f72b358729456">section</a>(<a class="code" href="structripple_1_1ConfigSection.html#a44ee859a6705ddcac4e318602f8fe6ac">ConfigSection::nodeDatabase</a>())};</div>
|
|
|
|
|
<div class="line"><a name="l00569"></a><span class="lineno"> 569</span>  boost::filesystem::path newPath;</div>
|
|
|
|
|
<div class="line"><a name="l00570"></a><span class="lineno"> 570</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00571"></a><span class="lineno"> 571</span>  <span class="keywordflow">if</span> (path.size())</div>
|
|
|
|
|
<div class="line"><a name="l00572"></a><span class="lineno"> 572</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00573"></a><span class="lineno"> 573</span>  newPath = path;</div>
|
|
|
|
|
<div class="line"><a name="l00574"></a><span class="lineno"> 574</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00575"></a><span class="lineno"> 575</span>  <span class="keywordflow">else</span></div>
|
|
|
|
|
<div class="line"><a name="l00576"></a><span class="lineno"> 576</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00577"></a><span class="lineno"> 577</span>  boost::filesystem::path p = get<std::string>(section, <span class="stringliteral">"path"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00578"></a><span class="lineno"> 578</span>  p /= <a class="code" href="classripple_1_1SHAMapStoreImp.html#a3596d0251740f6199a9f561ded944a16">dbPrefix_</a>;</div>
|
|
|
|
|
<div class="line"><a name="l00579"></a><span class="lineno"> 579</span>  p += <span class="stringliteral">".%%%%"</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00580"></a><span class="lineno"> 580</span>  newPath = boost::filesystem::unique_path(p);</div>
|
|
|
|
|
<div class="line"><a name="l00581"></a><span class="lineno"> 581</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00582"></a><span class="lineno"> 582</span>  section.set(<span class="stringliteral">"path"</span>, newPath.string());</div>
|
|
|
|
|
<div class="line"><a name="l00583"></a><span class="lineno"> 583</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00584"></a><span class="lineno"> 584</span>  <span class="keyword">auto</span> backend{<a class="code" href="classripple_1_1NodeStore_1_1Manager.html#a59f9bcb7e6049d1b4c557891992f6cab">NodeStore::Manager::instance</a>().<a class="code" href="classripple_1_1NodeStore_1_1Manager.html#a81a6d60d5ccc13e9b0ad87dd6ea7aeca">make_Backend</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00585"></a><span class="lineno"> 585</span>  section,</div>
|
|
|
|
|
<div class="line"><a name="l00586"></a><span class="lineno"> 586</span>  <a class="code" href="namespaceripple.html#a13d7c6c34d30731bbc221f629e03f8db">megabytes</a>(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1Config.html#aaa6a41c4bde1f4a893ec927ecadea014">getValueFor</a>(<a class="code" href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcbaa62741f39e8a8d667ccccd0642c08746">SizedItem::burstSize</a>, boost::none)),</div>
|
|
|
|
|
<div class="line"><a name="l00587"></a><span class="lineno"> 587</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ac0b7612948a6c06b661d5b67a03280f6">scheduler_</a>,</div>
|
|
|
|
|
<div class="line"><a name="l00588"></a><span class="lineno"> 588</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a25782128c9548339beec993b748b0268">logs</a>().<a class="code" href="classripple_1_1Logs.html#a725d5db842b36c748bd9da3401da3128">journal</a>(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a271d68a9581c5f5a583d1f8f6b1b91aa">nodeStoreName_</a>))};</div>
|
|
|
|
|
<div class="line"><a name="l00589"></a><span class="lineno"> 589</span>  backend->open();</div>
|
|
|
|
|
<div class="line"><a name="l00590"></a><span class="lineno"> 590</span>  <span class="keywordflow">return</span> backend;</div>
|
|
|
|
|
<div class="line"><a name="l00591"></a><span class="lineno"> 591</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00592"></a><span class="lineno"> 592</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00593"></a><span class="lineno"> 593</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00594"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f"> 594</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f">SHAMapStoreImp::clearSql</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00595"></a><span class="lineno"> 595</span>  <a class="code" href="classripple_1_1DatabaseCon.html">DatabaseCon</a>& database,</div>
|
|
|
|
|
<div class="line"><a name="l00596"></a><span class="lineno"> 596</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">LedgerIndex</a> lastRotated,</div>
|
|
|
|
|
<div class="line"><a name="l00597"></a><span class="lineno"> 597</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string.html">std::string</a> <span class="keyword">const</span>& minQuery,</div>
|
|
|
|
|
<div class="line"><a name="l00598"></a><span class="lineno"> 598</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string.html">std::string</a> <span class="keyword">const</span>& deleteQuery)</div>
|
|
|
|
|
<div class="line"><a name="l00599"></a><span class="lineno"> 599</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00600"></a><span class="lineno"> 600</span>  assert(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00601"></a><span class="lineno"> 601</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">LedgerIndex</a> min = <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/numeric_limits/max.html">std::numeric_limits<LedgerIndex>::max</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00602"></a><span class="lineno"> 602</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00603"></a><span class="lineno"> 603</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00604"></a><span class="lineno"> 604</span>  boost::optional<std::uint64_t> m;</div>
|
|
|
|
|
<div class="line"><a name="l00605"></a><span class="lineno"> 605</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00606"></a><span class="lineno"> 606</span>  << <span class="stringliteral">"Begin: Look up lowest value of: "</span> << minQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00607"></a><span class="lineno"> 607</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00608"></a><span class="lineno"> 608</span>  <span class="keyword">auto</span> db = database.<a class="code" href="classripple_1_1DatabaseCon.html#a16c6f729c6462f6200b724543f5c67bc">checkoutDb</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00609"></a><span class="lineno"> 609</span>  *db << minQuery, soci::into(m);</div>
|
|
|
|
|
<div class="line"><a name="l00610"></a><span class="lineno"> 610</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00611"></a><span class="lineno"> 611</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"End: Look up lowest value of: "</span> << minQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00612"></a><span class="lineno"> 612</span>  <span class="keywordflow">if</span> (!m)</div>
|
|
|
|
|
<div class="line"><a name="l00613"></a><span class="lineno"> 613</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00614"></a><span class="lineno"> 614</span>  min = *m;</div>
|
|
|
|
|
<div class="line"><a name="l00615"></a><span class="lineno"> 615</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00616"></a><span class="lineno"> 616</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00617"></a><span class="lineno"> 617</span>  <span class="keywordflow">if</span> (min > lastRotated || <a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>() != Health::ok)</div>
|
|
|
|
|
<div class="line"><a name="l00618"></a><span class="lineno"> 618</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00619"></a><span class="lineno"> 619</span>  <span class="keywordflow">if</span> (min == lastRotated)</div>
|
|
|
|
|
<div class="line"><a name="l00620"></a><span class="lineno"> 620</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00621"></a><span class="lineno"> 621</span>  <span class="comment">// Micro-optimization mainly to clarify logs</span></div>
|
|
|
|
|
<div class="line"><a name="l00622"></a><span class="lineno"> 622</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"Nothing to delete from "</span> << deleteQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00623"></a><span class="lineno"> 623</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00624"></a><span class="lineno"> 624</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00625"></a><span class="lineno"> 625</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00626"></a><span class="lineno"> 626</span>  boost::format formattedDeleteQuery(deleteQuery);</div>
|
|
|
|
|
<div class="line"><a name="l00627"></a><span class="lineno"> 627</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00628"></a><span class="lineno"> 628</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << <span class="stringliteral">"start: "</span> << deleteQuery << <span class="stringliteral">" from "</span> << min</div>
|
|
|
|
|
<div class="line"><a name="l00629"></a><span class="lineno"> 629</span>  << <span class="stringliteral">" to "</span> << lastRotated;</div>
|
|
|
|
|
<div class="line"><a name="l00630"></a><span class="lineno"> 630</span>  <span class="keywordflow">while</span> (min < lastRotated)</div>
|
|
|
|
|
<div class="line"><a name="l00631"></a><span class="lineno"> 631</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00632"></a><span class="lineno"> 632</span>  min = <a class="codeRef" href="http://en.cppreference.com/w/cpp/algorithm/min.html">std::min</a>(lastRotated, min + <a class="code" href="classripple_1_1SHAMapStoreImp.html#a71fc064e474c3b0dd17a92bdbaebe60f">deleteBatch_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00633"></a><span class="lineno"> 633</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"Begin: Delete up to "</span> << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a71fc064e474c3b0dd17a92bdbaebe60f">deleteBatch_</a></div>
|
|
|
|
|
<div class="line"><a name="l00634"></a><span class="lineno"> 634</span>  << <span class="stringliteral">" rows with LedgerSeq < "</span> << min</div>
|
|
|
|
|
<div class="line"><a name="l00635"></a><span class="lineno"> 635</span>  << <span class="stringliteral">" using query: "</span> << deleteQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00636"></a><span class="lineno"> 636</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00637"></a><span class="lineno"> 637</span>  <span class="keyword">auto</span> db = database.<a class="code" href="classripple_1_1DatabaseCon.html#a16c6f729c6462f6200b724543f5c67bc">checkoutDb</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00638"></a><span class="lineno"> 638</span>  *db << boost::str(formattedDeleteQuery % min);</div>
|
|
|
|
|
<div class="line"><a name="l00639"></a><span class="lineno"> 639</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00640"></a><span class="lineno"> 640</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00641"></a><span class="lineno"> 641</span>  << <span class="stringliteral">"End: Delete up to "</span> << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a71fc064e474c3b0dd17a92bdbaebe60f">deleteBatch_</a> << <span class="stringliteral">" rows with LedgerSeq < "</span></div>
|
|
|
|
|
<div class="line"><a name="l00642"></a><span class="lineno"> 642</span>  << min << <span class="stringliteral">" using query: "</span> << deleteQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00643"></a><span class="lineno"> 643</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00644"></a><span class="lineno"> 644</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00645"></a><span class="lineno"> 645</span>  <span class="keywordflow">if</span> (min < lastRotated)</div>
|
|
|
|
|
<div class="line"><a name="l00646"></a><span class="lineno"> 646</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/sleep_for.html">std::this_thread::sleep_for</a>(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a183c24e323752e508bac99fb44e921f9">backOff_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00647"></a><span class="lineno"> 647</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00648"></a><span class="lineno"> 648</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00649"></a><span class="lineno"> 649</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00650"></a><span class="lineno"> 650</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << <span class="stringliteral">"finished: "</span> << deleteQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00651"></a><span class="lineno"> 651</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00652"></a><span class="lineno"> 652</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00653"></a><span class="lineno"> 653</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00654"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#af823965870aa9d05f14c8591c771a74a"> 654</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#af823965870aa9d05f14c8591c771a74a">SHAMapStoreImp::clearCaches</a>(<a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">LedgerIndex</a> validatedSeq)</div>
|
|
|
|
|
<div class="line"><a name="l00655"></a><span class="lineno"> 655</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00656"></a><span class="lineno"> 656</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a>-><a class="code" href="classripple_1_1LedgerMaster.html#a043c0ea4eb656f7838e145be8abefbc0">clearLedgerCachePrior</a>(validatedSeq);</div>
|
|
|
|
|
<div class="line"><a name="l00657"></a><span class="lineno"> 657</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#aa652318bb0714902d2cc90903878843f">fullBelowCache_</a>-><a class="code" href="classripple_1_1detail_1_1BasicFullBelowCache.html#ab848d9b7735bd22c13ce05478c322aca">clear</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00658"></a><span class="lineno"> 658</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00659"></a><span class="lineno"> 659</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00660"></a><span class="lineno"> 660</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00661"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#ad486e43fe6ea6c304d7cf119fb009894"> 661</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#ad486e43fe6ea6c304d7cf119fb009894">SHAMapStoreImp::freshenCaches</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00662"></a><span class="lineno"> 662</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00663"></a><span class="lineno"> 663</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a07149340d3c13d6f1a0caca63cc944c0">freshenCache</a>(*<a class="code" href="classripple_1_1SHAMapStoreImp.html#a35ca5214c1ef881ac91ac078f6e3df1c">treeNodeCache_</a>))</div>
|
|
|
|
|
<div class="line"><a name="l00664"></a><span class="lineno"> 664</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00665"></a><span class="lineno"> 665</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a07149340d3c13d6f1a0caca63cc944c0">freshenCache</a>(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aae949580d66cede10b0b392755858e32">getMasterTransaction</a>().<a class="code" href="classripple_1_1TransactionMaster.html#afc49cdcfe8a4b06993b76d0e803aeb19">getCache</a>()))</div>
|
|
|
|
|
<div class="line"><a name="l00666"></a><span class="lineno"> 666</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00667"></a><span class="lineno"> 667</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00668"></a><span class="lineno"> 668</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00669"></a><span class="lineno"> 669</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00670"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#a2b3b5566e7e19153f06459fced983932"> 670</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a2b3b5566e7e19153f06459fced983932">SHAMapStoreImp::clearPrior</a>(<a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">LedgerIndex</a> lastRotated)</div>
|
|
|
|
|
<div class="line"><a name="l00671"></a><span class="lineno"> 671</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00672"></a><span class="lineno"> 672</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1Config.html#a8fdf3fd3b2112759b3a0a7fa4d8afa05">reporting</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00673"></a><span class="lineno"> 673</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00674"></a><span class="lineno"> 674</span>  assert(<span class="keyword">false</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00675"></a><span class="lineno"> 675</span>  Throw<std::runtime_error>(</div>
|
|
|
|
|
<div class="line"><a name="l00676"></a><span class="lineno"> 676</span>  <span class="stringliteral">"Reporting does not support online_delete. Remove "</span></div>
|
|
|
|
|
<div class="line"><a name="l00677"></a><span class="lineno"> 677</span>  <span class="stringliteral">"online_delete info from config"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00678"></a><span class="lineno"> 678</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00679"></a><span class="lineno"> 679</span>  <span class="comment">// Do not allow ledgers to be acquired from the network</span></div>
|
|
|
|
|
<div class="line"><a name="l00680"></a><span class="lineno"> 680</span>  <span class="comment">// that are about to be deleted.</span></div>
|
|
|
|
|
<div class="line"><a name="l00681"></a><span class="lineno"> 681</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a8efdb3bebe1162a54fc87c08e55dcf44">minimumOnline_</a> = lastRotated + 1;</div>
|
|
|
|
|
<div class="line"><a name="l00682"></a><span class="lineno"> 682</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"Begin: Clear internal ledgers up to "</span></div>
|
|
|
|
|
<div class="line"><a name="l00683"></a><span class="lineno"> 683</span>  << lastRotated;</div>
|
|
|
|
|
<div class="line"><a name="l00684"></a><span class="lineno"> 684</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a>-><a class="code" href="classripple_1_1LedgerMaster.html#a38c5453afb527fe1ef65ba0f5b2b6517">clearPriorLedgers</a>(lastRotated);</div>
|
|
|
|
|
<div class="line"><a name="l00685"></a><span class="lineno"> 685</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"End: Clear internal ledgers up to "</span></div>
|
|
|
|
|
<div class="line"><a name="l00686"></a><span class="lineno"> 686</span>  << lastRotated;</div>
|
|
|
|
|
<div class="line"><a name="l00687"></a><span class="lineno"> 687</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00688"></a><span class="lineno"> 688</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00689"></a><span class="lineno"> 689</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00690"></a><span class="lineno"> 690</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f">clearSql</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00691"></a><span class="lineno"> 691</span>  *<a class="code" href="classripple_1_1SHAMapStoreImp.html#adee10cb6db30fd4c3f8e5597277968c0">ledgerDb_</a>,</div>
|
|
|
|
|
<div class="line"><a name="l00692"></a><span class="lineno"> 692</span>  lastRotated,</div>
|
|
|
|
|
<div class="line"><a name="l00693"></a><span class="lineno"> 693</span>  <span class="stringliteral">"SELECT MIN(LedgerSeq) FROM Ledgers;"</span>,</div>
|
|
|
|
|
<div class="line"><a name="l00694"></a><span class="lineno"> 694</span>  <span class="stringliteral">"DELETE FROM Ledgers WHERE LedgerSeq < %u;"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00695"></a><span class="lineno"> 695</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00696"></a><span class="lineno"> 696</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00697"></a><span class="lineno"> 697</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00698"></a><span class="lineno"> 698</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f">clearSql</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00699"></a><span class="lineno"> 699</span>  *<a class="code" href="classripple_1_1SHAMapStoreImp.html#a30713fb55aeab5955e349a6386f59780">transactionDb_</a>,</div>
|
|
|
|
|
<div class="line"><a name="l00700"></a><span class="lineno"> 700</span>  lastRotated,</div>
|
|
|
|
|
<div class="line"><a name="l00701"></a><span class="lineno"> 701</span>  <span class="stringliteral">"SELECT MIN(LedgerSeq) FROM Transactions;"</span>,</div>
|
|
|
|
|
<div class="line"><a name="l00702"></a><span class="lineno"> 702</span>  <span class="stringliteral">"DELETE FROM Transactions WHERE LedgerSeq < %u;"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00703"></a><span class="lineno"> 703</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00704"></a><span class="lineno"> 704</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00705"></a><span class="lineno"> 705</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00706"></a><span class="lineno"> 706</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f">clearSql</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00707"></a><span class="lineno"> 707</span>  *<a class="code" href="classripple_1_1SHAMapStoreImp.html#a30713fb55aeab5955e349a6386f59780">transactionDb_</a>,</div>
|
|
|
|
|
<div class="line"><a name="l00708"></a><span class="lineno"> 708</span>  lastRotated,</div>
|
|
|
|
|
<div class="line"><a name="l00709"></a><span class="lineno"> 709</span>  <span class="stringliteral">"SELECT MIN(LedgerSeq) FROM AccountTransactions;"</span>,</div>
|
|
|
|
|
<div class="line"><a name="l00710"></a><span class="lineno"> 710</span>  <span class="stringliteral">"DELETE FROM AccountTransactions WHERE LedgerSeq < %u;"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00711"></a><span class="lineno"> 711</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00712"></a><span class="lineno"> 712</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00713"></a><span class="lineno"> 713</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00714"></a><span class="lineno"> 714</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00715"></a><span class="lineno"> 715</span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#ada256179ba2ac337d7f4bb6c70d8fe8e">SHAMapStoreImp::Health</a></div>
|
|
|
|
|
<div class="line"><a name="l00716"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79"> 716</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">SHAMapStoreImp::health</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00717"></a><span class="lineno"> 717</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00718"></a><span class="lineno"> 718</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00719"></a><span class="lineno"> 719</span>  <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_1SHAMapStoreImp.html#a13915b042341ae4fe6232c5fd956ef57">mutex_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00720"></a><span class="lineno"> 720</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3091814df4b2c4fbee9060bbd3bb7e40">stop_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00721"></a><span class="lineno"> 721</span>  <span class="keywordflow">return</span> Health::stopping;</div>
|
|
|
|
|
<div class="line"><a name="l00722"></a><span class="lineno"> 722</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00723"></a><span class="lineno"> 723</span>  <span class="keywordflow">if</span> (!<a class="code" href="classripple_1_1SHAMapStoreImp.html#a14aaa8478db87f3e4769bc3b2a02e271">netOPs_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00724"></a><span class="lineno"> 724</span>  <span class="keywordflow">return</span> Health::ok;</div>
|
|
|
|
|
<div class="line"><a name="l00725"></a><span class="lineno"> 725</span>  assert(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00726"></a><span class="lineno"> 726</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00727"></a><span class="lineno"> 727</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#ae3bbfded16bd305dd1ca60de09af1d97">healthy_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00728"></a><span class="lineno"> 728</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00729"></a><span class="lineno"> 729</span>  <span class="keyword">auto</span> age = <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a>-><a class="code" href="classripple_1_1LedgerMaster.html#af6aa770a3d98a0a49d5091163fb675c9">getValidatedLedgerAge</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00730"></a><span class="lineno"> 730</span>  <a class="code" href="namespaceripple.html#a597325d7385ff9c19686e14e5bead510">OperatingMode</a> mode = <a class="code" href="classripple_1_1SHAMapStoreImp.html#a14aaa8478db87f3e4769bc3b2a02e271">netOPs_</a>-><a class="code" href="classripple_1_1NetworkOPs.html#a41818990c5329f7e3d025d52bcf569b5">getOperatingMode</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00731"></a><span class="lineno"> 731</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#ab19ee07adc5e52abea1353ee9d2f3048">recoveryWaitTime_</a> && mode == <a class="code" href="namespaceripple.html#a597325d7385ff9c19686e14e5bead510af0be1f77b2d12fe3d6424fbf9eecc109">OperatingMode::SYNCING</a> &&</div>
|
|
|
|
|
<div class="line"><a name="l00732"></a><span class="lineno"> 732</span>  age < <a class="code" href="classripple_1_1SHAMapStoreImp.html#a892c279b4ed512af158526307a8e32dc">ageThreshold_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00733"></a><span class="lineno"> 733</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00734"></a><span class="lineno"> 734</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#ad8fefe3e8ad583e1ed1bf02094ac3d8f">warn</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00735"></a><span class="lineno"> 735</span>  << <span class="stringliteral">"Waiting "</span> << <a class="code" href="classripple_1_1SHAMapStoreImp.html#ab19ee07adc5e52abea1353ee9d2f3048">recoveryWaitTime_</a>->count()</div>
|
|
|
|
|
<div class="line"><a name="l00736"></a><span class="lineno"> 736</span>  << <span class="stringliteral">"s for node to get back into sync with network. state: "</span></div>
|
|
|
|
|
<div class="line"><a name="l00737"></a><span class="lineno"> 737</span>  << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a7c963aa5c47180b24897ff6b5622e5bc">getOPs</a>().<a class="code" href="classripple_1_1NetworkOPs.html#ad4c27eb535691555917e3b1ae5ab2637">strOperatingMode</a>(mode, <span class="keyword">false</span>) << <span class="stringliteral">". age "</span></div>
|
|
|
|
|
<div class="line"><a name="l00738"></a><span class="lineno"> 738</span>  << age.count() << <span class="charliteral">'s'</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00739"></a><span class="lineno"> 739</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/sleep_for.html">std::this_thread::sleep_for</a>(*<a class="code" href="classripple_1_1SHAMapStoreImp.html#ab19ee07adc5e52abea1353ee9d2f3048">recoveryWaitTime_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00740"></a><span class="lineno"> 740</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00741"></a><span class="lineno"> 741</span>  age = <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a>-><a class="code" href="classripple_1_1LedgerMaster.html#af6aa770a3d98a0a49d5091163fb675c9">getValidatedLedgerAge</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00742"></a><span class="lineno"> 742</span>  mode = <a class="code" href="classripple_1_1SHAMapStoreImp.html#a14aaa8478db87f3e4769bc3b2a02e271">netOPs_</a>-><a class="code" href="classripple_1_1NetworkOPs.html#a41818990c5329f7e3d025d52bcf569b5">getOperatingMode</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00743"></a><span class="lineno"> 743</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00744"></a><span class="lineno"> 744</span>  <span class="keywordflow">if</span> (mode != <a class="code" href="namespaceripple.html#a597325d7385ff9c19686e14e5bead510aba7de5bc6888294e5884b024a4c894f1">OperatingMode::FULL</a> || age > <a class="code" href="classripple_1_1SHAMapStoreImp.html#a892c279b4ed512af158526307a8e32dc">ageThreshold_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00745"></a><span class="lineno"> 745</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00746"></a><span class="lineno"> 746</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#ad8fefe3e8ad583e1ed1bf02094ac3d8f">warn</a>()) << <span class="stringliteral">"Not deleting. state: "</span></div>
|
|
|
|
|
<div class="line"><a name="l00747"></a><span class="lineno"> 747</span>  << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a7c963aa5c47180b24897ff6b5622e5bc">getOPs</a>().<a class="code" href="classripple_1_1NetworkOPs.html#ad4c27eb535691555917e3b1ae5ab2637">strOperatingMode</a>(mode, <span class="keyword">false</span>)</div>
|
|
|
|
|
<div class="line"><a name="l00748"></a><span class="lineno"> 748</span>  << <span class="stringliteral">". age "</span> << age.count() << <span class="charliteral">'s'</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00749"></a><span class="lineno"> 749</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae3bbfded16bd305dd1ca60de09af1d97">healthy_</a> = <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00750"></a><span class="lineno"> 750</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00751"></a><span class="lineno"> 751</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00752"></a><span class="lineno"> 752</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00753"></a><span class="lineno"> 753</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#ae3bbfded16bd305dd1ca60de09af1d97">healthy_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00754"></a><span class="lineno"> 754</span>  <span class="keywordflow">return</span> Health::ok;</div>
|
|
|
|
|
<div class="line"><a name="l00755"></a><span class="lineno"> 755</span>  <span class="keywordflow">else</span></div>
|
|
|
|
|
<div class="line"><a name="l00756"></a><span class="lineno"> 756</span>  <span class="keywordflow">return</span> Health::unhealthy;</div>
|
|
|
|
|
<div class="line"><a name="l00757"></a><span class="lineno"> 757</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00758"></a><span class="lineno"> 758</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00759"></a><span class="lineno"> 759</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00760"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#ad51f8995dc2a26e24a6057ea904dcb4a"> 760</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#ad51f8995dc2a26e24a6057ea904dcb4a">SHAMapStoreImp::onStop</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00761"></a><span class="lineno"> 761</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00762"></a><span class="lineno"> 762</span>  <span class="comment">// This is really a check for `if (thread_)`.</span></div>
|
|
|
|
|
<div class="line"><a name="l00763"></a><span class="lineno"> 763</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00764"></a><span class="lineno"> 764</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00765"></a><span class="lineno"> 765</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00766"></a><span class="lineno"> 766</span>  <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_1SHAMapStoreImp.html#a13915b042341ae4fe6232c5fd956ef57">mutex_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00767"></a><span class="lineno"> 767</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a3091814df4b2c4fbee9060bbd3bb7e40">stop_</a> = <span class="keyword">true</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00768"></a><span class="lineno"> 768</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00769"></a><span class="lineno"> 769</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a04d7e2ffe07292626a4f7a932ac93ab1">cond_</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/condition_variable/notify_one.html">notify_one</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00770"></a><span class="lineno"> 770</span>  <span class="comment">// stopped() will be called by the thread_ running run(),</span></div>
|
|
|
|
|
<div class="line"><a name="l00771"></a><span class="lineno"> 771</span>  <span class="comment">// when it reaches the check for stop_.</span></div>
|
|
|
|
|
<div class="line"><a name="l00520"></a><span class="lineno"> 520</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00521"></a><span class="lineno"> 521</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00522"></a><span class="lineno"> 522</span>  <span class="keywordtype">bool</span> writableDbExists = <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00523"></a><span class="lineno"> 523</span>  <span class="keywordtype">bool</span> archiveDbExists = <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00524"></a><span class="lineno"> 524</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00525"></a><span class="lineno"> 525</span>  <span class="keywordflow">for</span> (boost::filesystem::directory_iterator it(dbPath);</div>
|
|
|
|
|
<div class="line"><a name="l00526"></a><span class="lineno"> 526</span>  it != boost::filesystem::directory_iterator();</div>
|
|
|
|
|
<div class="line"><a name="l00527"></a><span class="lineno"> 527</span>  ++it)</div>
|
|
|
|
|
<div class="line"><a name="l00528"></a><span class="lineno"> 528</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00529"></a><span class="lineno"> 529</span>  <span class="keywordflow">if</span> (!state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/compare.html">compare</a>(it->path().string()))</div>
|
|
|
|
|
<div class="line"><a name="l00530"></a><span class="lineno"> 530</span>  writableDbExists = <span class="keyword">true</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00531"></a><span class="lineno"> 531</span>  <span class="keywordflow">else</span> <span class="keywordflow">if</span> (!state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/compare.html">compare</a>(it->path().string()))</div>
|
|
|
|
|
<div class="line"><a name="l00532"></a><span class="lineno"> 532</span>  archiveDbExists = <span class="keyword">true</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00533"></a><span class="lineno"> 533</span>  <span class="keywordflow">else</span> <span class="keywordflow">if</span> (!<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3596d0251740f6199a9f561ded944a16">dbPrefix_</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/compare.html">compare</a>(it->path().stem().string()))</div>
|
|
|
|
|
<div class="line"><a name="l00534"></a><span class="lineno"> 534</span>  boost::filesystem::remove_all(it->path());</div>
|
|
|
|
|
<div class="line"><a name="l00535"></a><span class="lineno"> 535</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00536"></a><span class="lineno"> 536</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00537"></a><span class="lineno"> 537</span>  <span class="keywordflow">if</span> ((!writableDbExists && state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/size.html">size</a>()) ||</div>
|
|
|
|
|
<div class="line"><a name="l00538"></a><span class="lineno"> 538</span>  (!archiveDbExists && state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/size.html">size</a>()) ||</div>
|
|
|
|
|
<div class="line"><a name="l00539"></a><span class="lineno"> 539</span>  (writableDbExists != archiveDbExists) ||</div>
|
|
|
|
|
<div class="line"><a name="l00540"></a><span class="lineno"> 540</span>  state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/empty.html">empty</a>() != state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/empty.html">empty</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00541"></a><span class="lineno"> 541</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00542"></a><span class="lineno"> 542</span>  boost::filesystem::path stateDbPathName =</div>
|
|
|
|
|
<div class="line"><a name="l00543"></a><span class="lineno"> 543</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1BasicConfig.html#ae2c21d011e6424d4917db175ef9df301">legacy</a>(<span class="stringliteral">"database_path"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00544"></a><span class="lineno"> 544</span>  stateDbPathName /= <a class="code" href="classripple_1_1SHAMapStoreImp.html#ada1f2f842cafba373412841435061c5f">dbName_</a>;</div>
|
|
|
|
|
<div class="line"><a name="l00545"></a><span class="lineno"> 545</span>  stateDbPathName += <span class="stringliteral">"*"</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00546"></a><span class="lineno"> 546</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00547"></a><span class="lineno"> 547</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a49b0713e65bb8e2c51b76fbf16252afe">error</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00548"></a><span class="lineno"> 548</span>  << <span class="stringliteral">"state db error:\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00549"></a><span class="lineno"> 549</span>  << <span class="stringliteral">" writableDbExists "</span> << writableDbExists << <span class="stringliteral">" archiveDbExists "</span></div>
|
|
|
|
|
<div class="line"><a name="l00550"></a><span class="lineno"> 550</span>  << archiveDbExists << <span class="charliteral">'\n'</span></div>
|
|
|
|
|
<div class="line"><a name="l00551"></a><span class="lineno"> 551</span>  << <span class="stringliteral">" writableDb '"</span> << state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">writableDb</a> << <span class="stringliteral">"' archiveDb '"</span></div>
|
|
|
|
|
<div class="line"><a name="l00552"></a><span class="lineno"> 552</span>  << state.<a class="code" href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a7e3b9c0238ba080669a2298ed40912ca">archiveDb</a> << <span class="stringliteral">"\n\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00553"></a><span class="lineno"> 553</span>  << <span class="stringliteral">"The existing data is in a corrupted state.\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00554"></a><span class="lineno"> 554</span>  << <span class="stringliteral">"To resume operation, remove the files matching "</span></div>
|
|
|
|
|
<div class="line"><a name="l00555"></a><span class="lineno"> 555</span>  << stateDbPathName.<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string/basic_string.html">string</a>() << <span class="stringliteral">" and contents of the directory "</span></div>
|
|
|
|
|
<div class="line"><a name="l00556"></a><span class="lineno"> 556</span>  << get<std::string>(section, <span class="stringliteral">"path"</span>) << <span class="charliteral">'\n'</span></div>
|
|
|
|
|
<div class="line"><a name="l00557"></a><span class="lineno"> 557</span>  << <span class="stringliteral">"Optionally, you can move those files to another\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00558"></a><span class="lineno"> 558</span>  << <span class="stringliteral">"location if you wish to analyze or back up the data.\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00559"></a><span class="lineno"> 559</span>  << <span class="stringliteral">"However, there is no guarantee that the data in its\n"</span></div>
|
|
|
|
|
<div class="line"><a name="l00560"></a><span class="lineno"> 560</span>  << <span class="stringliteral">"existing form is usable."</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00561"></a><span class="lineno"> 561</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00562"></a><span class="lineno"> 562</span>  Throw<std::runtime_error>(<span class="stringliteral">"state db error"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00563"></a><span class="lineno"> 563</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00564"></a><span class="lineno"> 564</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00565"></a><span class="lineno"> 565</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00566"></a><span class="lineno"> 566</span> <a class="codeRef" href="http://en.cppreference.com/w/cpp/memory/unique_ptr.html">std::unique_ptr<NodeStore::Backend></a></div>
|
|
|
|
|
<div class="line"><a name="l00567"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#a347e8e8ba053b93c6b924f277f535a94"> 567</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a347e8e8ba053b93c6b924f277f535a94">SHAMapStoreImp::makeBackendRotating</a>(<a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string.html">std::string</a> path)</div>
|
|
|
|
|
<div class="line"><a name="l00568"></a><span class="lineno"> 568</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00569"></a><span class="lineno"> 569</span>  <a class="code" href="classripple_1_1Section.html">Section</a> section{<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1BasicConfig.html#a60aca585d76b1121dd4f72b358729456">section</a>(<a class="code" href="structripple_1_1ConfigSection.html#a44ee859a6705ddcac4e318602f8fe6ac">ConfigSection::nodeDatabase</a>())};</div>
|
|
|
|
|
<div class="line"><a name="l00570"></a><span class="lineno"> 570</span>  boost::filesystem::path newPath;</div>
|
|
|
|
|
<div class="line"><a name="l00571"></a><span class="lineno"> 571</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00572"></a><span class="lineno"> 572</span>  <span class="keywordflow">if</span> (path.size())</div>
|
|
|
|
|
<div class="line"><a name="l00573"></a><span class="lineno"> 573</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00574"></a><span class="lineno"> 574</span>  newPath = path;</div>
|
|
|
|
|
<div class="line"><a name="l00575"></a><span class="lineno"> 575</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00576"></a><span class="lineno"> 576</span>  <span class="keywordflow">else</span></div>
|
|
|
|
|
<div class="line"><a name="l00577"></a><span class="lineno"> 577</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00578"></a><span class="lineno"> 578</span>  boost::filesystem::path p = get<std::string>(section, <span class="stringliteral">"path"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00579"></a><span class="lineno"> 579</span>  p /= <a class="code" href="classripple_1_1SHAMapStoreImp.html#a3596d0251740f6199a9f561ded944a16">dbPrefix_</a>;</div>
|
|
|
|
|
<div class="line"><a name="l00580"></a><span class="lineno"> 580</span>  p += <span class="stringliteral">".%%%%"</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00581"></a><span class="lineno"> 581</span>  newPath = boost::filesystem::unique_path(p);</div>
|
|
|
|
|
<div class="line"><a name="l00582"></a><span class="lineno"> 582</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00583"></a><span class="lineno"> 583</span>  section.set(<span class="stringliteral">"path"</span>, newPath.string());</div>
|
|
|
|
|
<div class="line"><a name="l00584"></a><span class="lineno"> 584</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00585"></a><span class="lineno"> 585</span>  <span class="keyword">auto</span> backend{<a class="code" href="classripple_1_1NodeStore_1_1Manager.html#a59f9bcb7e6049d1b4c557891992f6cab">NodeStore::Manager::instance</a>().<a class="code" href="classripple_1_1NodeStore_1_1Manager.html#a81a6d60d5ccc13e9b0ad87dd6ea7aeca">make_Backend</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00586"></a><span class="lineno"> 586</span>  section,</div>
|
|
|
|
|
<div class="line"><a name="l00587"></a><span class="lineno"> 587</span>  <a class="code" href="namespaceripple.html#a13d7c6c34d30731bbc221f629e03f8db">megabytes</a>(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1Config.html#aaa6a41c4bde1f4a893ec927ecadea014">getValueFor</a>(<a class="code" href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcbaa62741f39e8a8d667ccccd0642c08746">SizedItem::burstSize</a>, boost::none)),</div>
|
|
|
|
|
<div class="line"><a name="l00588"></a><span class="lineno"> 588</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ac0b7612948a6c06b661d5b67a03280f6">scheduler_</a>,</div>
|
|
|
|
|
<div class="line"><a name="l00589"></a><span class="lineno"> 589</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a25782128c9548339beec993b748b0268">logs</a>().<a class="code" href="classripple_1_1Logs.html#a725d5db842b36c748bd9da3401da3128">journal</a>(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a271d68a9581c5f5a583d1f8f6b1b91aa">nodeStoreName_</a>))};</div>
|
|
|
|
|
<div class="line"><a name="l00590"></a><span class="lineno"> 590</span>  backend->open();</div>
|
|
|
|
|
<div class="line"><a name="l00591"></a><span class="lineno"> 591</span>  <span class="keywordflow">return</span> backend;</div>
|
|
|
|
|
<div class="line"><a name="l00592"></a><span class="lineno"> 592</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00593"></a><span class="lineno"> 593</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00594"></a><span class="lineno"> 594</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00595"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f"> 595</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f">SHAMapStoreImp::clearSql</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00596"></a><span class="lineno"> 596</span>  <a class="code" href="classripple_1_1DatabaseCon.html">DatabaseCon</a>& database,</div>
|
|
|
|
|
<div class="line"><a name="l00597"></a><span class="lineno"> 597</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">LedgerIndex</a> lastRotated,</div>
|
|
|
|
|
<div class="line"><a name="l00598"></a><span class="lineno"> 598</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string.html">std::string</a> <span class="keyword">const</span>& minQuery,</div>
|
|
|
|
|
<div class="line"><a name="l00599"></a><span class="lineno"> 599</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/string/basic_string.html">std::string</a> <span class="keyword">const</span>& deleteQuery)</div>
|
|
|
|
|
<div class="line"><a name="l00600"></a><span class="lineno"> 600</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00601"></a><span class="lineno"> 601</span>  assert(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00602"></a><span class="lineno"> 602</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">LedgerIndex</a> min = <a class="codeRef" href="http://en.cppreference.com/w/cpp/types/numeric_limits/max.html">std::numeric_limits<LedgerIndex>::max</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00603"></a><span class="lineno"> 603</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00604"></a><span class="lineno"> 604</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00605"></a><span class="lineno"> 605</span>  boost::optional<std::uint64_t> m;</div>
|
|
|
|
|
<div class="line"><a name="l00606"></a><span class="lineno"> 606</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00607"></a><span class="lineno"> 607</span>  << <span class="stringliteral">"Begin: Look up lowest value of: "</span> << minQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00608"></a><span class="lineno"> 608</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00609"></a><span class="lineno"> 609</span>  <span class="keyword">auto</span> db = database.<a class="code" href="classripple_1_1DatabaseCon.html#a16c6f729c6462f6200b724543f5c67bc">checkoutDb</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00610"></a><span class="lineno"> 610</span>  *db << minQuery, soci::into(m);</div>
|
|
|
|
|
<div class="line"><a name="l00611"></a><span class="lineno"> 611</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00612"></a><span class="lineno"> 612</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"End: Look up lowest value of: "</span> << minQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00613"></a><span class="lineno"> 613</span>  <span class="keywordflow">if</span> (!m)</div>
|
|
|
|
|
<div class="line"><a name="l00614"></a><span class="lineno"> 614</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00615"></a><span class="lineno"> 615</span>  min = *m;</div>
|
|
|
|
|
<div class="line"><a name="l00616"></a><span class="lineno"> 616</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00617"></a><span class="lineno"> 617</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00618"></a><span class="lineno"> 618</span>  <span class="keywordflow">if</span> (min > lastRotated || <a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>() != Health::ok)</div>
|
|
|
|
|
<div class="line"><a name="l00619"></a><span class="lineno"> 619</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00620"></a><span class="lineno"> 620</span>  <span class="keywordflow">if</span> (min == lastRotated)</div>
|
|
|
|
|
<div class="line"><a name="l00621"></a><span class="lineno"> 621</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00622"></a><span class="lineno"> 622</span>  <span class="comment">// Micro-optimization mainly to clarify logs</span></div>
|
|
|
|
|
<div class="line"><a name="l00623"></a><span class="lineno"> 623</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"Nothing to delete from "</span> << deleteQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00624"></a><span class="lineno"> 624</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00625"></a><span class="lineno"> 625</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00626"></a><span class="lineno"> 626</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00627"></a><span class="lineno"> 627</span>  boost::format formattedDeleteQuery(deleteQuery);</div>
|
|
|
|
|
<div class="line"><a name="l00628"></a><span class="lineno"> 628</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00629"></a><span class="lineno"> 629</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << <span class="stringliteral">"start: "</span> << deleteQuery << <span class="stringliteral">" from "</span> << min</div>
|
|
|
|
|
<div class="line"><a name="l00630"></a><span class="lineno"> 630</span>  << <span class="stringliteral">" to "</span> << lastRotated;</div>
|
|
|
|
|
<div class="line"><a name="l00631"></a><span class="lineno"> 631</span>  <span class="keywordflow">while</span> (min < lastRotated)</div>
|
|
|
|
|
<div class="line"><a name="l00632"></a><span class="lineno"> 632</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00633"></a><span class="lineno"> 633</span>  min = <a class="codeRef" href="http://en.cppreference.com/w/cpp/algorithm/min.html">std::min</a>(lastRotated, min + <a class="code" href="classripple_1_1SHAMapStoreImp.html#a71fc064e474c3b0dd17a92bdbaebe60f">deleteBatch_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00634"></a><span class="lineno"> 634</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"Begin: Delete up to "</span> << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a71fc064e474c3b0dd17a92bdbaebe60f">deleteBatch_</a></div>
|
|
|
|
|
<div class="line"><a name="l00635"></a><span class="lineno"> 635</span>  << <span class="stringliteral">" rows with LedgerSeq < "</span> << min</div>
|
|
|
|
|
<div class="line"><a name="l00636"></a><span class="lineno"> 636</span>  << <span class="stringliteral">" using query: "</span> << deleteQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00637"></a><span class="lineno"> 637</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00638"></a><span class="lineno"> 638</span>  <span class="keyword">auto</span> db = database.<a class="code" href="classripple_1_1DatabaseCon.html#a16c6f729c6462f6200b724543f5c67bc">checkoutDb</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00639"></a><span class="lineno"> 639</span>  *db << boost::str(formattedDeleteQuery % min);</div>
|
|
|
|
|
<div class="line"><a name="l00640"></a><span class="lineno"> 640</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00641"></a><span class="lineno"> 641</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00642"></a><span class="lineno"> 642</span>  << <span class="stringliteral">"End: Delete up to "</span> << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a71fc064e474c3b0dd17a92bdbaebe60f">deleteBatch_</a> << <span class="stringliteral">" rows with LedgerSeq < "</span></div>
|
|
|
|
|
<div class="line"><a name="l00643"></a><span class="lineno"> 643</span>  << min << <span class="stringliteral">" using query: "</span> << deleteQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00644"></a><span class="lineno"> 644</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00645"></a><span class="lineno"> 645</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00646"></a><span class="lineno"> 646</span>  <span class="keywordflow">if</span> (min < lastRotated)</div>
|
|
|
|
|
<div class="line"><a name="l00647"></a><span class="lineno"> 647</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/sleep_for.html">std::this_thread::sleep_for</a>(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a183c24e323752e508bac99fb44e921f9">backOff_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00648"></a><span class="lineno"> 648</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00649"></a><span class="lineno"> 649</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00650"></a><span class="lineno"> 650</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00651"></a><span class="lineno"> 651</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">debug</a>()) << <span class="stringliteral">"finished: "</span> << deleteQuery;</div>
|
|
|
|
|
<div class="line"><a name="l00652"></a><span class="lineno"> 652</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00653"></a><span class="lineno"> 653</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00654"></a><span class="lineno"> 654</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00655"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#af823965870aa9d05f14c8591c771a74a"> 655</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#af823965870aa9d05f14c8591c771a74a">SHAMapStoreImp::clearCaches</a>(<a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">LedgerIndex</a> validatedSeq)</div>
|
|
|
|
|
<div class="line"><a name="l00656"></a><span class="lineno"> 656</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00657"></a><span class="lineno"> 657</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a>-><a class="code" href="classripple_1_1LedgerMaster.html#a043c0ea4eb656f7838e145be8abefbc0">clearLedgerCachePrior</a>(validatedSeq);</div>
|
|
|
|
|
<div class="line"><a name="l00658"></a><span class="lineno"> 658</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#aa652318bb0714902d2cc90903878843f">fullBelowCache_</a>-><a class="code" href="classripple_1_1detail_1_1BasicFullBelowCache.html#ab848d9b7735bd22c13ce05478c322aca">clear</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00659"></a><span class="lineno"> 659</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00660"></a><span class="lineno"> 660</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00661"></a><span class="lineno"> 661</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00662"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#ad486e43fe6ea6c304d7cf119fb009894"> 662</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#ad486e43fe6ea6c304d7cf119fb009894">SHAMapStoreImp::freshenCaches</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00663"></a><span class="lineno"> 663</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00664"></a><span class="lineno"> 664</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a07149340d3c13d6f1a0caca63cc944c0">freshenCache</a>(*<a class="code" href="classripple_1_1SHAMapStoreImp.html#a35ca5214c1ef881ac91ac078f6e3df1c">treeNodeCache_</a>))</div>
|
|
|
|
|
<div class="line"><a name="l00665"></a><span class="lineno"> 665</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00666"></a><span class="lineno"> 666</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a07149340d3c13d6f1a0caca63cc944c0">freshenCache</a>(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aae949580d66cede10b0b392755858e32">getMasterTransaction</a>().<a class="code" href="classripple_1_1TransactionMaster.html#afc49cdcfe8a4b06993b76d0e803aeb19">getCache</a>()))</div>
|
|
|
|
|
<div class="line"><a name="l00667"></a><span class="lineno"> 667</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00668"></a><span class="lineno"> 668</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00669"></a><span class="lineno"> 669</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00670"></a><span class="lineno"> 670</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00671"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#a2b3b5566e7e19153f06459fced983932"> 671</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a2b3b5566e7e19153f06459fced983932">SHAMapStoreImp::clearPrior</a>(<a class="codeRef" href="http://en.cppreference.com/w/cpp/types/integer.html">LedgerIndex</a> lastRotated)</div>
|
|
|
|
|
<div class="line"><a name="l00672"></a><span class="lineno"> 672</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00673"></a><span class="lineno"> 673</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1Config.html#a8fdf3fd3b2112759b3a0a7fa4d8afa05">reporting</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00674"></a><span class="lineno"> 674</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00675"></a><span class="lineno"> 675</span>  assert(<span class="keyword">false</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00676"></a><span class="lineno"> 676</span>  Throw<std::runtime_error>(</div>
|
|
|
|
|
<div class="line"><a name="l00677"></a><span class="lineno"> 677</span>  <span class="stringliteral">"Reporting does not support online_delete. Remove "</span></div>
|
|
|
|
|
<div class="line"><a name="l00678"></a><span class="lineno"> 678</span>  <span class="stringliteral">"online_delete info from config"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00679"></a><span class="lineno"> 679</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00680"></a><span class="lineno"> 680</span>  <span class="comment">// Do not allow ledgers to be acquired from the network</span></div>
|
|
|
|
|
<div class="line"><a name="l00681"></a><span class="lineno"> 681</span>  <span class="comment">// that are about to be deleted.</span></div>
|
|
|
|
|
<div class="line"><a name="l00682"></a><span class="lineno"> 682</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a8efdb3bebe1162a54fc87c08e55dcf44">minimumOnline_</a> = lastRotated + 1;</div>
|
|
|
|
|
<div class="line"><a name="l00683"></a><span class="lineno"> 683</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"Begin: Clear internal ledgers up to "</span></div>
|
|
|
|
|
<div class="line"><a name="l00684"></a><span class="lineno"> 684</span>  << lastRotated;</div>
|
|
|
|
|
<div class="line"><a name="l00685"></a><span class="lineno"> 685</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a>-><a class="code" href="classripple_1_1LedgerMaster.html#a38c5453afb527fe1ef65ba0f5b2b6517">clearPriorLedgers</a>(lastRotated);</div>
|
|
|
|
|
<div class="line"><a name="l00686"></a><span class="lineno"> 686</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#abbe082bd27ca0f1d1365af2824e4f85b">trace</a>()) << <span class="stringliteral">"End: Clear internal ledgers up to "</span></div>
|
|
|
|
|
<div class="line"><a name="l00687"></a><span class="lineno"> 687</span>  << lastRotated;</div>
|
|
|
|
|
<div class="line"><a name="l00688"></a><span class="lineno"> 688</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00689"></a><span class="lineno"> 689</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00690"></a><span class="lineno"> 690</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00691"></a><span class="lineno"> 691</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f">clearSql</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00692"></a><span class="lineno"> 692</span>  *<a class="code" href="classripple_1_1SHAMapStoreImp.html#adee10cb6db30fd4c3f8e5597277968c0">ledgerDb_</a>,</div>
|
|
|
|
|
<div class="line"><a name="l00693"></a><span class="lineno"> 693</span>  lastRotated,</div>
|
|
|
|
|
<div class="line"><a name="l00694"></a><span class="lineno"> 694</span>  <span class="stringliteral">"SELECT MIN(LedgerSeq) FROM Ledgers;"</span>,</div>
|
|
|
|
|
<div class="line"><a name="l00695"></a><span class="lineno"> 695</span>  <span class="stringliteral">"DELETE FROM Ledgers WHERE LedgerSeq < %u;"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00696"></a><span class="lineno"> 696</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00697"></a><span class="lineno"> 697</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00698"></a><span class="lineno"> 698</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00699"></a><span class="lineno"> 699</span>  <span class="keywordflow">if</span> (!<a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#aca56b7c63030174e59720ab51d739422">config</a>().<a class="code" href="classripple_1_1Config.html#aa09be5266eca22f68f27e60169291ec5">useTxTables</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00700"></a><span class="lineno"> 700</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00701"></a><span class="lineno"> 701</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00702"></a><span class="lineno"> 702</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f">clearSql</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00703"></a><span class="lineno"> 703</span>  *<a class="code" href="classripple_1_1SHAMapStoreImp.html#a30713fb55aeab5955e349a6386f59780">transactionDb_</a>,</div>
|
|
|
|
|
<div class="line"><a name="l00704"></a><span class="lineno"> 704</span>  lastRotated,</div>
|
|
|
|
|
<div class="line"><a name="l00705"></a><span class="lineno"> 705</span>  <span class="stringliteral">"SELECT MIN(LedgerSeq) FROM Transactions;"</span>,</div>
|
|
|
|
|
<div class="line"><a name="l00706"></a><span class="lineno"> 706</span>  <span class="stringliteral">"DELETE FROM Transactions WHERE LedgerSeq < %u;"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00707"></a><span class="lineno"> 707</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00708"></a><span class="lineno"> 708</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00709"></a><span class="lineno"> 709</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00710"></a><span class="lineno"> 710</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f">clearSql</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00711"></a><span class="lineno"> 711</span>  *<a class="code" href="classripple_1_1SHAMapStoreImp.html#a30713fb55aeab5955e349a6386f59780">transactionDb_</a>,</div>
|
|
|
|
|
<div class="line"><a name="l00712"></a><span class="lineno"> 712</span>  lastRotated,</div>
|
|
|
|
|
<div class="line"><a name="l00713"></a><span class="lineno"> 713</span>  <span class="stringliteral">"SELECT MIN(LedgerSeq) FROM AccountTransactions;"</span>,</div>
|
|
|
|
|
<div class="line"><a name="l00714"></a><span class="lineno"> 714</span>  <span class="stringliteral">"DELETE FROM AccountTransactions WHERE LedgerSeq < %u;"</span>);</div>
|
|
|
|
|
<div class="line"><a name="l00715"></a><span class="lineno"> 715</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">health</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00716"></a><span class="lineno"> 716</span>  <span class="keywordflow">return</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00717"></a><span class="lineno"> 717</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00718"></a><span class="lineno"> 718</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00719"></a><span class="lineno"> 719</span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#ada256179ba2ac337d7f4bb6c70d8fe8e">SHAMapStoreImp::Health</a></div>
|
|
|
|
|
<div class="line"><a name="l00720"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79"> 720</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">SHAMapStoreImp::health</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00721"></a><span class="lineno"> 721</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00722"></a><span class="lineno"> 722</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00723"></a><span class="lineno"> 723</span>  <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_1SHAMapStoreImp.html#a13915b042341ae4fe6232c5fd956ef57">mutex_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00724"></a><span class="lineno"> 724</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3091814df4b2c4fbee9060bbd3bb7e40">stop_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00725"></a><span class="lineno"> 725</span>  <span class="keywordflow">return</span> Health::stopping;</div>
|
|
|
|
|
<div class="line"><a name="l00726"></a><span class="lineno"> 726</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00727"></a><span class="lineno"> 727</span>  <span class="keywordflow">if</span> (!<a class="code" href="classripple_1_1SHAMapStoreImp.html#a14aaa8478db87f3e4769bc3b2a02e271">netOPs_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00728"></a><span class="lineno"> 728</span>  <span class="keywordflow">return</span> Health::ok;</div>
|
|
|
|
|
<div class="line"><a name="l00729"></a><span class="lineno"> 729</span>  assert(<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00730"></a><span class="lineno"> 730</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00731"></a><span class="lineno"> 731</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#ae3bbfded16bd305dd1ca60de09af1d97">healthy_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00732"></a><span class="lineno"> 732</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00733"></a><span class="lineno"> 733</span>  <span class="keyword">auto</span> age = <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a>-><a class="code" href="classripple_1_1LedgerMaster.html#af6aa770a3d98a0a49d5091163fb675c9">getValidatedLedgerAge</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00734"></a><span class="lineno"> 734</span>  <a class="code" href="namespaceripple.html#a597325d7385ff9c19686e14e5bead510">OperatingMode</a> mode = <a class="code" href="classripple_1_1SHAMapStoreImp.html#a14aaa8478db87f3e4769bc3b2a02e271">netOPs_</a>-><a class="code" href="classripple_1_1NetworkOPs.html#a41818990c5329f7e3d025d52bcf569b5">getOperatingMode</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00735"></a><span class="lineno"> 735</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#ab19ee07adc5e52abea1353ee9d2f3048">recoveryWaitTime_</a> && mode == <a class="code" href="namespaceripple.html#a597325d7385ff9c19686e14e5bead510af0be1f77b2d12fe3d6424fbf9eecc109">OperatingMode::SYNCING</a> &&</div>
|
|
|
|
|
<div class="line"><a name="l00736"></a><span class="lineno"> 736</span>  age < <a class="code" href="classripple_1_1SHAMapStoreImp.html#a892c279b4ed512af158526307a8e32dc">ageThreshold_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00737"></a><span class="lineno"> 737</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00738"></a><span class="lineno"> 738</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#ad8fefe3e8ad583e1ed1bf02094ac3d8f">warn</a>())</div>
|
|
|
|
|
<div class="line"><a name="l00739"></a><span class="lineno"> 739</span>  << <span class="stringliteral">"Waiting "</span> << <a class="code" href="classripple_1_1SHAMapStoreImp.html#ab19ee07adc5e52abea1353ee9d2f3048">recoveryWaitTime_</a>->count()</div>
|
|
|
|
|
<div class="line"><a name="l00740"></a><span class="lineno"> 740</span>  << <span class="stringliteral">"s for node to get back into sync with network. state: "</span></div>
|
|
|
|
|
<div class="line"><a name="l00741"></a><span class="lineno"> 741</span>  << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a7c963aa5c47180b24897ff6b5622e5bc">getOPs</a>().<a class="code" href="classripple_1_1NetworkOPs.html#ad4c27eb535691555917e3b1ae5ab2637">strOperatingMode</a>(mode, <span class="keyword">false</span>) << <span class="stringliteral">". age "</span></div>
|
|
|
|
|
<div class="line"><a name="l00742"></a><span class="lineno"> 742</span>  << age.count() << <span class="charliteral">'s'</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00743"></a><span class="lineno"> 743</span>  <a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/sleep_for.html">std::this_thread::sleep_for</a>(*<a class="code" href="classripple_1_1SHAMapStoreImp.html#ab19ee07adc5e52abea1353ee9d2f3048">recoveryWaitTime_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00744"></a><span class="lineno"> 744</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00745"></a><span class="lineno"> 745</span>  age = <a class="code" href="classripple_1_1SHAMapStoreImp.html#a4ed1e086e2ce9612dccb2493523497c1">ledgerMaster_</a>-><a class="code" href="classripple_1_1LedgerMaster.html#af6aa770a3d98a0a49d5091163fb675c9">getValidatedLedgerAge</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00746"></a><span class="lineno"> 746</span>  mode = <a class="code" href="classripple_1_1SHAMapStoreImp.html#a14aaa8478db87f3e4769bc3b2a02e271">netOPs_</a>-><a class="code" href="classripple_1_1NetworkOPs.html#a41818990c5329f7e3d025d52bcf569b5">getOperatingMode</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00747"></a><span class="lineno"> 747</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00748"></a><span class="lineno"> 748</span>  <span class="keywordflow">if</span> (mode != <a class="code" href="namespaceripple.html#a597325d7385ff9c19686e14e5bead510aba7de5bc6888294e5884b024a4c894f1">OperatingMode::FULL</a> || age > <a class="code" href="classripple_1_1SHAMapStoreImp.html#a892c279b4ed512af158526307a8e32dc">ageThreshold_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00749"></a><span class="lineno"> 749</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00750"></a><span class="lineno"> 750</span>  JLOG(<a class="code" href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">journal_</a>.<a class="code" href="classbeast_1_1Journal.html#ad8fefe3e8ad583e1ed1bf02094ac3d8f">warn</a>()) << <span class="stringliteral">"Not deleting. state: "</span></div>
|
|
|
|
|
<div class="line"><a name="l00751"></a><span class="lineno"> 751</span>  << <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a7c963aa5c47180b24897ff6b5622e5bc">getOPs</a>().<a class="code" href="classripple_1_1NetworkOPs.html#ad4c27eb535691555917e3b1ae5ab2637">strOperatingMode</a>(mode, <span class="keyword">false</span>)</div>
|
|
|
|
|
<div class="line"><a name="l00752"></a><span class="lineno"> 752</span>  << <span class="stringliteral">". age "</span> << age.count() << <span class="charliteral">'s'</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00753"></a><span class="lineno"> 753</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#ae3bbfded16bd305dd1ca60de09af1d97">healthy_</a> = <span class="keyword">false</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00754"></a><span class="lineno"> 754</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00755"></a><span class="lineno"> 755</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00756"></a><span class="lineno"> 756</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00757"></a><span class="lineno"> 757</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#ae3bbfded16bd305dd1ca60de09af1d97">healthy_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00758"></a><span class="lineno"> 758</span>  <span class="keywordflow">return</span> Health::ok;</div>
|
|
|
|
|
<div class="line"><a name="l00759"></a><span class="lineno"> 759</span>  <span class="keywordflow">else</span></div>
|
|
|
|
|
<div class="line"><a name="l00760"></a><span class="lineno"> 760</span>  <span class="keywordflow">return</span> Health::unhealthy;</div>
|
|
|
|
|
<div class="line"><a name="l00761"></a><span class="lineno"> 761</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00762"></a><span class="lineno"> 762</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00763"></a><span class="lineno"> 763</span> <span class="keywordtype">void</span></div>
|
|
|
|
|
<div class="line"><a name="l00764"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#ad51f8995dc2a26e24a6057ea904dcb4a"> 764</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#ad51f8995dc2a26e24a6057ea904dcb4a">SHAMapStoreImp::onStop</a>()</div>
|
|
|
|
|
<div class="line"><a name="l00765"></a><span class="lineno"> 765</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00766"></a><span class="lineno"> 766</span>  <span class="comment">// This is really a check for `if (thread_)`.</span></div>
|
|
|
|
|
<div class="line"><a name="l00767"></a><span class="lineno"> 767</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00768"></a><span class="lineno"> 768</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00769"></a><span class="lineno"> 769</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00770"></a><span class="lineno"> 770</span>  <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_1SHAMapStoreImp.html#a13915b042341ae4fe6232c5fd956ef57">mutex_</a>);</div>
|
|
|
|
|
<div class="line"><a name="l00771"></a><span class="lineno"> 771</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a3091814df4b2c4fbee9060bbd3bb7e40">stop_</a> = <span class="keyword">true</span>;</div>
|
|
|
|
|
<div class="line"><a name="l00772"></a><span class="lineno"> 772</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00773"></a><span class="lineno"> 773</span>  <span class="keywordflow">else</span></div>
|
|
|
|
|
<div class="line"><a name="l00774"></a><span class="lineno"> 774</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00775"></a><span class="lineno"> 775</span>  <span class="comment">// There is no thread running run(), so we must call stopped().</span></div>
|
|
|
|
|
<div class="line"><a name="l00776"></a><span class="lineno"> 776</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00777"></a><span class="lineno"> 777</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00778"></a><span class="lineno"> 778</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00779"></a><span class="lineno"> 779</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00780"></a><span class="lineno"> 780</span> boost::optional<LedgerIndex></div>
|
|
|
|
|
<div class="line"><a name="l00781"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#a6a83852c52d91ffb7fe55092d7b07bce"> 781</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a6a83852c52d91ffb7fe55092d7b07bce">SHAMapStoreImp::minimumOnline</a>()<span class="keyword"> const</span></div>
|
|
|
|
|
<div class="line"><a name="l00782"></a><span class="lineno"> 782</span> <span class="keyword"></span>{</div>
|
|
|
|
|
<div class="line"><a name="l00783"></a><span class="lineno"> 783</span>  <span class="comment">// minimumOnline_ with 0 value is equivalent to unknown/not set.</span></div>
|
|
|
|
|
<div class="line"><a name="l00784"></a><span class="lineno"> 784</span>  <span class="comment">// Don't attempt to acquire ledgers if that value is unknown.</span></div>
|
|
|
|
|
<div class="line"><a name="l00785"></a><span class="lineno"> 785</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a> && <a class="code" href="classripple_1_1SHAMapStoreImp.html#a8efdb3bebe1162a54fc87c08e55dcf44">minimumOnline_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00786"></a><span class="lineno"> 786</span>  <span class="keywordflow">return</span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a8efdb3bebe1162a54fc87c08e55dcf44">minimumOnline_</a>.load();</div>
|
|
|
|
|
<div class="line"><a name="l00787"></a><span class="lineno"> 787</span>  <span class="keywordflow">return</span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a57929fa83c551514e364fe6981b0c104">getLedgerMaster</a>().<a class="code" href="classripple_1_1LedgerMaster.html#a7129c7408cc225ac56bc105d30289da4">minSqlSeq</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00788"></a><span class="lineno"> 788</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00789"></a><span class="lineno"> 789</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00790"></a><span class="lineno"> 790</span> <span class="comment">//------------------------------------------------------------------------------</span></div>
|
|
|
|
|
<div class="line"><a name="l00791"></a><span class="lineno"> 791</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00792"></a><span class="lineno"> 792</span> <a class="codeRef" href="http://en.cppreference.com/w/cpp/memory/unique_ptr.html">std::unique_ptr<SHAMapStore></a></div>
|
|
|
|
|
<div class="line"><a name="l00793"></a><span class="lineno"><a class="line" href="namespaceripple.html#acde3d7e2f059202351f714545da5b233"> 793</a></span> <a class="code" href="namespaceripple.html#acde3d7e2f059202351f714545da5b233">make_SHAMapStore</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00794"></a><span class="lineno"> 794</span>  <a class="code" href="classripple_1_1Application.html">Application</a>& app,</div>
|
|
|
|
|
<div class="line"><a name="l00795"></a><span class="lineno"> 795</span>  <a class="code" href="classripple_1_1Stoppable.html">Stoppable</a>& parent,</div>
|
|
|
|
|
<div class="line"><a name="l00796"></a><span class="lineno"> 796</span>  <a class="code" href="classripple_1_1NodeStore_1_1Scheduler.html">NodeStore::Scheduler</a>& scheduler,</div>
|
|
|
|
|
<div class="line"><a name="l00797"></a><span class="lineno"> 797</span>  <a class="code" href="classbeast_1_1Journal.html">beast::Journal</a> journal)</div>
|
|
|
|
|
<div class="line"><a name="l00798"></a><span class="lineno"> 798</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00799"></a><span class="lineno"> 799</span>  <span class="keywordflow">return</span> std::make_unique<SHAMapStoreImp>(app, parent, scheduler, journal);</div>
|
|
|
|
|
<div class="line"><a name="l00800"></a><span class="lineno"> 800</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00801"></a><span class="lineno"> 801</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00802"></a><span class="lineno"> 802</span> } <span class="comment">// namespace ripple</span></div>
|
|
|
|
|
<div class="line"><a name="l00773"></a><span class="lineno"> 773</span>  <a class="code" href="classripple_1_1SHAMapStoreImp.html#a04d7e2ffe07292626a4f7a932ac93ab1">cond_</a>.<a class="codeRef" href="http://en.cppreference.com/w/cpp/thread/condition_variable/notify_one.html">notify_one</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00774"></a><span class="lineno"> 774</span>  <span class="comment">// stopped() will be called by the thread_ running run(),</span></div>
|
|
|
|
|
<div class="line"><a name="l00775"></a><span class="lineno"> 775</span>  <span class="comment">// when it reaches the check for stop_.</span></div>
|
|
|
|
|
<div class="line"><a name="l00776"></a><span class="lineno"> 776</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00777"></a><span class="lineno"> 777</span>  <span class="keywordflow">else</span></div>
|
|
|
|
|
<div class="line"><a name="l00778"></a><span class="lineno"> 778</span>  {</div>
|
|
|
|
|
<div class="line"><a name="l00779"></a><span class="lineno"> 779</span>  <span class="comment">// There is no thread running run(), so we must call stopped().</span></div>
|
|
|
|
|
<div class="line"><a name="l00780"></a><span class="lineno"> 780</span>  <a class="code" href="classripple_1_1Stoppable.html#a65a95f9c14637491df60d3a07518fa09">stopped</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00781"></a><span class="lineno"> 781</span>  }</div>
|
|
|
|
|
<div class="line"><a name="l00782"></a><span class="lineno"> 782</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00783"></a><span class="lineno"> 783</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00784"></a><span class="lineno"> 784</span> boost::optional<LedgerIndex></div>
|
|
|
|
|
<div class="line"><a name="l00785"></a><span class="lineno"><a class="line" href="classripple_1_1SHAMapStoreImp.html#a6a83852c52d91ffb7fe55092d7b07bce"> 785</a></span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a6a83852c52d91ffb7fe55092d7b07bce">SHAMapStoreImp::minimumOnline</a>()<span class="keyword"> const</span></div>
|
|
|
|
|
<div class="line"><a name="l00786"></a><span class="lineno"> 786</span> <span class="keyword"></span>{</div>
|
|
|
|
|
<div class="line"><a name="l00787"></a><span class="lineno"> 787</span>  <span class="comment">// minimumOnline_ with 0 value is equivalent to unknown/not set.</span></div>
|
|
|
|
|
<div class="line"><a name="l00788"></a><span class="lineno"> 788</span>  <span class="comment">// Don't attempt to acquire ledgers if that value is unknown.</span></div>
|
|
|
|
|
<div class="line"><a name="l00789"></a><span class="lineno"> 789</span>  <span class="keywordflow">if</span> (<a class="code" href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">deleteInterval_</a> && <a class="code" href="classripple_1_1SHAMapStoreImp.html#a8efdb3bebe1162a54fc87c08e55dcf44">minimumOnline_</a>)</div>
|
|
|
|
|
<div class="line"><a name="l00790"></a><span class="lineno"> 790</span>  <span class="keywordflow">return</span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a8efdb3bebe1162a54fc87c08e55dcf44">minimumOnline_</a>.load();</div>
|
|
|
|
|
<div class="line"><a name="l00791"></a><span class="lineno"> 791</span>  <span class="keywordflow">return</span> <a class="code" href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">app_</a>.<a class="code" href="classripple_1_1Application.html#a57929fa83c551514e364fe6981b0c104">getLedgerMaster</a>().<a class="code" href="classripple_1_1LedgerMaster.html#a7129c7408cc225ac56bc105d30289da4">minSqlSeq</a>();</div>
|
|
|
|
|
<div class="line"><a name="l00792"></a><span class="lineno"> 792</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00793"></a><span class="lineno"> 793</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00794"></a><span class="lineno"> 794</span> <span class="comment">//------------------------------------------------------------------------------</span></div>
|
|
|
|
|
<div class="line"><a name="l00795"></a><span class="lineno"> 795</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00796"></a><span class="lineno"> 796</span> <a class="codeRef" href="http://en.cppreference.com/w/cpp/memory/unique_ptr.html">std::unique_ptr<SHAMapStore></a></div>
|
|
|
|
|
<div class="line"><a name="l00797"></a><span class="lineno"><a class="line" href="namespaceripple.html#acde3d7e2f059202351f714545da5b233"> 797</a></span> <a class="code" href="namespaceripple.html#acde3d7e2f059202351f714545da5b233">make_SHAMapStore</a>(</div>
|
|
|
|
|
<div class="line"><a name="l00798"></a><span class="lineno"> 798</span>  <a class="code" href="classripple_1_1Application.html">Application</a>& app,</div>
|
|
|
|
|
<div class="line"><a name="l00799"></a><span class="lineno"> 799</span>  <a class="code" href="classripple_1_1Stoppable.html">Stoppable</a>& parent,</div>
|
|
|
|
|
<div class="line"><a name="l00800"></a><span class="lineno"> 800</span>  <a class="code" href="classripple_1_1NodeStore_1_1Scheduler.html">NodeStore::Scheduler</a>& scheduler,</div>
|
|
|
|
|
<div class="line"><a name="l00801"></a><span class="lineno"> 801</span>  <a class="code" href="classbeast_1_1Journal.html">beast::Journal</a> journal)</div>
|
|
|
|
|
<div class="line"><a name="l00802"></a><span class="lineno"> 802</span> {</div>
|
|
|
|
|
<div class="line"><a name="l00803"></a><span class="lineno"> 803</span>  <span class="keywordflow">return</span> std::make_unique<SHAMapStoreImp>(app, parent, scheduler, journal);</div>
|
|
|
|
|
<div class="line"><a name="l00804"></a><span class="lineno"> 804</span> }</div>
|
|
|
|
|
<div class="line"><a name="l00805"></a><span class="lineno"> 805</span>  </div>
|
|
|
|
|
<div class="line"><a name="l00806"></a><span class="lineno"> 806</span> } <span class="comment">// namespace ripple</span></div>
|
|
|
|
|
</div><!-- fragment --></div><!-- contents -->
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1Section_html"><div class="ttname"><a href="classripple_1_1Section.html">ripple::Section</a></div><div class="ttdoc">Holds a collection of configuration values.</div><div class="ttdef"><b>Definition:</b> <a href="BasicConfig_8h_source.html#l00043">BasicConfig.h:43</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_1_1SavedStateDB_html_a2daf6933e39fef00c2004ea292a5655c"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#a2daf6933e39fef00c2004ea292a5655c">ripple::SHAMapStoreImp::SavedStateDB::setCanDelete</a></div><div class="ttdeci">LedgerIndex setCanDelete(LedgerIndex canDelete)</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00100">SHAMapStoreImp.cpp:100</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a736d110df0b17beacd0897c28c654d79"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">ripple::SHAMapStoreImp::health</a></div><div class="ttdeci">Health health()</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00716">SHAMapStoreImp.cpp:716</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a736d110df0b17beacd0897c28c654d79"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a736d110df0b17beacd0897c28c654d79">ripple::SHAMapStoreImp::health</a></div><div class="ttdeci">Health health()</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00720">SHAMapStoreImp.cpp:720</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#l00102">Application.h:102</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a08a9e9740aebfe570df764bc48d7d554"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a08a9e9740aebfe570df764bc48d7d554">ripple::SHAMapStoreImp::dbPaths</a></div><div class="ttdeci">void dbPaths()</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00478">SHAMapStoreImp.cpp:478</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a08a9e9740aebfe570df764bc48d7d554"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a08a9e9740aebfe570df764bc48d7d554">ripple::SHAMapStoreImp::dbPaths</a></div><div class="ttdeci">void dbPaths()</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00479">SHAMapStoreImp.cpp:479</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1Application_html_a26ccdf06f25ceadec7894dd5f8da7eab"><div class="ttname"><a href="classripple_1_1Application.html#a26ccdf06f25ceadec7894dd5f8da7eab">ripple::Application::getNodeFamily</a></div><div class="ttdeci">virtual Family & getNodeFamily()=0</div></div>
|
|
|
|
|
<div class="ttc" id="asleep_for_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/thread/sleep_for.html">std::this_thread::sleep_for</a></div><div class="ttdeci">T sleep_for(T... args)</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1Family_html_a794019ebd9859fb37a7a65b80e8d6df7"><div class="ttname"><a href="classripple_1_1Family.html#a794019ebd9859fb37a7a65b80e8d6df7">ripple::Family::getTreeNodeCache</a></div><div class="ttdeci">virtual std::shared_ptr< TreeNodeCache > getTreeNodeCache(std::uint32_t ledgerSeq)=0</div><div class="ttdoc">Return a pointer to the Family Tree Node Cache.</div></div>
|
|
|
|
|
@@ -908,7 +912,7 @@ $(function() {
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1NetworkOPs_html_a41818990c5329f7e3d025d52bcf569b5"><div class="ttname"><a href="classripple_1_1NetworkOPs.html#a41818990c5329f7e3d025d52bcf569b5">ripple::NetworkOPs::getOperatingMode</a></div><div class="ttdeci">virtual OperatingMode getOperatingMode() const =0</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_ababf604811e61ccb7ec884f0c660821a"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#ababf604811e61ccb7ec884f0c660821a">ripple::SHAMapStoreImp::journal_</a></div><div class="ttdeci">const beast::Journal journal_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00094">SHAMapStoreImp.h:94</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a04d7e2ffe07292626a4f7a932ac93ab1"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a04d7e2ffe07292626a4f7a932ac93ab1">ripple::SHAMapStoreImp::cond_</a></div><div class="ttdeci">std::condition_variable cond_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00100">SHAMapStoreImp.h:100</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_ad486e43fe6ea6c304d7cf119fb009894"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#ad486e43fe6ea6c304d7cf119fb009894">ripple::SHAMapStoreImp::freshenCaches</a></div><div class="ttdeci">void freshenCaches()</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00661">SHAMapStoreImp.cpp:661</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_ad486e43fe6ea6c304d7cf119fb009894"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#ad486e43fe6ea6c304d7cf119fb009894">ripple::SHAMapStoreImp::freshenCaches</a></div><div class="ttdeci">void freshenCaches()</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00662">SHAMapStoreImp.cpp:662</a></div></div>
|
|
|
|
|
<div class="ttc" id="anamespaceripple_html_a1b38e742ac7fe4c3a80a397e06b83dcbad57786faa593a26172cf6ce03a7558a8"><div class="ttname"><a href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcbad57786faa593a26172cf6ce03a7558a8">ripple::SizedItem::hashNodeDBCache</a></div><div class="ttdeci">@ hashNodeDBCache</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1Family_html_ac16fa71cf792d5716da74e9164707769"><div class="ttname"><a href="classripple_1_1Family.html#ac16fa71cf792d5716da74e9164707769">ripple::Family::getFullBelowCache</a></div><div class="ttdeci">virtual std::shared_ptr< FullBelowCache > getFullBelowCache(std::uint32_t ledgerSeq)=0</div><div class="ttdoc">Return a pointer to the Family Full Below Cache.</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_1_1SavedStateDB_html_ad21f55aa2b33bc3f8c700a8c3f201a4b"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#ad21f55aa2b33bc3f8c700a8c3f201a4b">ripple::SHAMapStoreImp::SavedStateDB::getCanDelete</a></div><div class="ttdeci">LedgerIndex getCanDelete()</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00087">SHAMapStoreImp.cpp:87</a></div></div>
|
|
|
|
|
@@ -921,7 +925,7 @@ $(function() {
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a16657ed3d270e84f7147dc53ba937ffc"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a16657ed3d270e84f7147dc53ba937ffc">ripple::SHAMapStoreImp::dbRotating_</a></div><div class="ttdeci">NodeStore::DatabaseRotating * dbRotating_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00095">SHAMapStoreImp.h:95</a></div></div>
|
|
|
|
|
<div class="ttc" id="anamespaceripple_html_a55f440d44d3b98aa990fadd4ebb7c87e"><div class="ttname"><a href="namespaceripple.html#a55f440d44d3b98aa990fadd4ebb7c87e">ripple::get_if_exists</a></div><div class="ttdeci">bool get_if_exists(Section const &section, std::string const &name, T &v)</div><div class="ttdef"><b>Definition:</b> <a href="BasicConfig_8h_source.html#l00347">BasicConfig.h:347</a></div></div>
|
|
|
|
|
<div class="ttc" id="anamespaceripple_html_a597325d7385ff9c19686e14e5bead510af0be1f77b2d12fe3d6424fbf9eecc109"><div class="ttname"><a href="namespaceripple.html#a597325d7385ff9c19686e14e5bead510af0be1f77b2d12fe3d6424fbf9eecc109">ripple::OperatingMode::SYNCING</a></div><div class="ttdeci">@ SYNCING</div><div class="ttdoc">fallen slightly behind</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_ae1c3ed725e56b73697eb820d90d4805f"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f">ripple::SHAMapStoreImp::clearSql</a></div><div class="ttdeci">void clearSql(DatabaseCon &database, LedgerIndex lastRotated, std::string const &minQuery, std::string const &deleteQuery)</div><div class="ttdoc">delete from sqlite table in batches to not lock the db excessively.</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00594">SHAMapStoreImp.cpp:594</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_ae1c3ed725e56b73697eb820d90d4805f"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#ae1c3ed725e56b73697eb820d90d4805f">ripple::SHAMapStoreImp::clearSql</a></div><div class="ttdeci">void clearSql(DatabaseCon &database, LedgerIndex lastRotated, std::string const &minQuery, std::string const &deleteQuery)</div><div class="ttdoc">delete from sqlite table in batches to not lock the db excessively.</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00595">SHAMapStoreImp.cpp:595</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a78343049bc77cb4e5ef5bc9fd36eba67"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a78343049bc77cb4e5ef5bc9fd36eba67">ripple::SHAMapStoreImp::app_</a></div><div class="ttdeci">Application & app_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00078">SHAMapStoreImp.h:78</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1Config_html_a8fdf3fd3b2112759b3a0a7fa4d8afa05"><div class="ttname"><a href="classripple_1_1Config.html#a8fdf3fd3b2112759b3a0a7fa4d8afa05">ripple::Config::reporting</a></div><div class="ttdeci">bool reporting() const</div><div class="ttdef"><b>Definition:</b> <a href="Config_8h_source.html#l00270">Config.h:270</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1Stoppable_html"><div class="ttname"><a href="classripple_1_1Stoppable.html">ripple::Stoppable</a></div><div class="ttdoc">Provides an interface for starting and stopping.</div><div class="ttdef"><b>Definition:</b> <a href="Stoppable_8h_source.html#l00201">Stoppable.h:201</a></div></div>
|
|
|
|
|
@@ -939,19 +943,20 @@ $(function() {
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_1_1SavedStateDB_html_a2ff3adb29b03343ad89a6d9e6a7e82aa"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#a2ff3adb29b03343ad89a6d9e6a7e82aa">ripple::SHAMapStoreImp::SavedStateDB::setState</a></div><div class="ttdeci">void setState(SavedState const &state)</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00126">SHAMapStoreImp.cpp:126</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a35ca5214c1ef881ac91ac078f6e3df1c"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a35ca5214c1ef881ac91ac078f6e3df1c">ripple::SHAMapStoreImp::treeNodeCache_</a></div><div class="ttdeci">TreeNodeCache * treeNodeCache_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00125">SHAMapStoreImp.h:125</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapTreeNode_html"><div class="ttname"><a href="classripple_1_1SHAMapTreeNode.html">ripple::SHAMapTreeNode</a></div><div class="ttdef"><b>Definition:</b> <a href="SHAMapTreeNode_8h_source.html#l00133">SHAMapTreeNode.h:133</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1Config_html_aa09be5266eca22f68f27e60169291ec5"><div class="ttname"><a href="classripple_1_1Config.html#aa09be5266eca22f68f27e60169291ec5">ripple::Config::useTxTables</a></div><div class="ttdeci">bool useTxTables() const</div><div class="ttdef"><b>Definition:</b> <a href="Config_8h_source.html#l00276">Config.h:276</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_aa45f27d51fbb9cf096b5a5d4d98284af"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#aa45f27d51fbb9cf096b5a5d4d98284af">ripple::SHAMapStoreImp::working_</a></div><div class="ttdeci">std::atomic< bool > working_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00104">SHAMapStoreImp.h:104</a></div></div>
|
|
|
|
|
<div class="ttc" id="ato_string_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/string/basic_string/to_string.html">std::to_string</a></div><div class="ttdeci">T to_string(T... args)</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a3678b1326ca81d2f6282b5dc468f081a"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a3678b1326ca81d2f6282b5dc468f081a">ripple::SHAMapStoreImp::deleteInterval_</a></div><div class="ttdeci">std::uint32_t deleteInterval_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00108">SHAMapStoreImp.h:108</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1Application_html_a860be08979e27d8c6f37f722f996ba6c"><div class="ttname"><a href="classripple_1_1Application.html#a860be08979e27d8c6f37f722f996ba6c">ripple::Application::getJobQueue</a></div><div class="ttdeci">virtual JobQueue & getJobQueue()=0</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_ad51f8995dc2a26e24a6057ea904dcb4a"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#ad51f8995dc2a26e24a6057ea904dcb4a">ripple::SHAMapStoreImp::onStop</a></div><div class="ttdeci">void onStop() override</div><div class="ttdoc">Override called when the stop notification is issued.</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00760">SHAMapStoreImp.cpp:760</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_ad51f8995dc2a26e24a6057ea904dcb4a"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#ad51f8995dc2a26e24a6057ea904dcb4a">ripple::SHAMapStoreImp::onStop</a></div><div class="ttdeci">void onStop() override</div><div class="ttdoc">Override called when the stop notification is issued.</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00764">SHAMapStoreImp.cpp:764</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a892c279b4ed512af158526307a8e32dc"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a892c279b4ed512af158526307a8e32dc">ripple::SHAMapStoreImp::ageThreshold_</a></div><div class="ttdeci">std::chrono::seconds ageThreshold_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00112">SHAMapStoreImp.h:112</a></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_1SHAMapStoreImp_html_a6a83852c52d91ffb7fe55092d7b07bce"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a6a83852c52d91ffb7fe55092d7b07bce">ripple::SHAMapStoreImp::minimumOnline</a></div><div class="ttdeci">boost::optional< LedgerIndex > minimumOnline() const override</div><div class="ttdoc">The minimum ledger to try and maintain in our database.</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00781">SHAMapStoreImp.cpp:781</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a6a83852c52d91ffb7fe55092d7b07bce"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a6a83852c52d91ffb7fe55092d7b07bce">ripple::SHAMapStoreImp::minimumOnline</a></div><div class="ttdeci">boost::optional< LedgerIndex > minimumOnline() const override</div><div class="ttdoc">The minimum ledger to try and maintain in our database.</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00785">SHAMapStoreImp.cpp:785</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1BasicConfig_html_ae2c21d011e6424d4917db175ef9df301"><div class="ttname"><a href="classripple_1_1BasicConfig.html#ae2c21d011e6424d4917db175ef9df301">ripple::BasicConfig::legacy</a></div><div class="ttdeci">void legacy(std::string const &section, std::string value)</div><div class="ttdoc">Set a value that is not a key/value pair.</div><div class="ttdef"><b>Definition:</b> <a href="BasicConfig_8cpp_source.html#l00175">BasicConfig.cpp:175</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1Application_html_a25782128c9548339beec993b748b0268"><div class="ttname"><a href="classripple_1_1Application.html#a25782128c9548339beec993b748b0268">ripple::Application::logs</a></div><div class="ttdeci">virtual Logs & logs()=0</div></div>
|
|
|
|
|
<div class="ttc" id="astructripple_1_1SHAMapStoreImp_1_1SavedState_html_a0c7bb0070a7ed076bf36a4e2fdc7cbaf"><div class="ttname"><a href="structripple_1_1SHAMapStoreImp_1_1SavedState.html#a0c7bb0070a7ed076bf36a4e2fdc7cbaf">ripple::SHAMapStoreImp::SavedState::writableDb</a></div><div class="ttdeci">std::string writableDb</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00042">SHAMapStoreImp.h:42</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1TransactionMaster_html_afc49cdcfe8a4b06993b76d0e803aeb19"><div class="ttname"><a href="classripple_1_1TransactionMaster.html#afc49cdcfe8a4b06993b76d0e803aeb19">ripple::TransactionMaster::getCache</a></div><div class="ttdeci">TaggedCache< uint256, Transaction > & getCache()</div><div class="ttdef"><b>Definition:</b> <a href="TransactionMaster_8cpp_source.html#l00162">TransactionMaster.cpp:162</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a2b3b5566e7e19153f06459fced983932"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a2b3b5566e7e19153f06459fced983932">ripple::SHAMapStoreImp::clearPrior</a></div><div class="ttdeci">void clearPrior(LedgerIndex lastRotated)</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00670">SHAMapStoreImp.cpp:670</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a2b3b5566e7e19153f06459fced983932"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a2b3b5566e7e19153f06459fced983932">ripple::SHAMapStoreImp::clearPrior</a></div><div class="ttdeci">void clearPrior(LedgerIndex lastRotated)</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00671">SHAMapStoreImp.cpp:671</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_1_1SavedStateDB_html_adb71d9af881fdbd4a49cddbe69d38e68"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#adb71d9af881fdbd4a49cddbe69d38e68">ripple::SHAMapStoreImp::SavedStateDB::getState</a></div><div class="ttdeci">SavedState getState()</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00111">SHAMapStoreImp.cpp:111</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassbeast_1_1Journal_html"><div class="ttname"><a href="classbeast_1_1Journal.html">beast::Journal</a></div><div class="ttdoc">A generic endpoint for log messages.</div><div class="ttdef"><b>Definition:</b> <a href="Journal_8h_source.html#l00058">Journal.h:58</a></div></div>
|
|
|
|
|
<div class="ttc" id="anamespaceripple_html_a1b38e742ac7fe4c3a80a397e06b83dcbaa62741f39e8a8d667ccccd0642c08746"><div class="ttname"><a href="namespaceripple.html#a1b38e742ac7fe4c3a80a397e06b83dcbaa62741f39e8a8d667ccccd0642c08746">ripple::SizedItem::burstSize</a></div><div class="ttdeci">@ burstSize</div></div>
|
|
|
|
|
@@ -979,7 +984,7 @@ $(function() {
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_ac502b9f3e8822e3111bce648c7375d32"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#ac502b9f3e8822e3111bce648c7375d32">ripple::SHAMapStoreImp::fdRequired</a></div><div class="ttdeci">int fdRequired() const override</div><div class="ttdoc">Returns the number of file descriptors that are needed.</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00311">SHAMapStoreImp.cpp:311</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1NodeStore_1_1Manager_html_a81a6d60d5ccc13e9b0ad87dd6ea7aeca"><div class="ttname"><a href="classripple_1_1NodeStore_1_1Manager.html#a81a6d60d5ccc13e9b0ad87dd6ea7aeca">ripple::NodeStore::Manager::make_Backend</a></div><div class="ttdeci">virtual std::unique_ptr< Backend > make_Backend(Section const &parameters, std::size_t burstSize, Scheduler &scheduler, beast::Journal journal)=0</div><div class="ttdoc">Create a backend.</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1Logs_html_a725d5db842b36c748bd9da3401da3128"><div class="ttname"><a href="classripple_1_1Logs.html#a725d5db842b36c748bd9da3401da3128">ripple::Logs::journal</a></div><div class="ttdeci">beast::Journal journal(std::string const &name)</div><div class="ttdef"><b>Definition:</b> <a href="Log_8cpp_source.html#l00144">Log.cpp:144</a></div></div>
|
|
|
|
|
<div class="ttc" id="anamespaceripple_html_acde3d7e2f059202351f714545da5b233"><div class="ttname"><a href="namespaceripple.html#acde3d7e2f059202351f714545da5b233">ripple::make_SHAMapStore</a></div><div class="ttdeci">std::unique_ptr< SHAMapStore > make_SHAMapStore(Application &app, Stoppable &parent, NodeStore::Scheduler &scheduler, beast::Journal journal)</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00793">SHAMapStoreImp.cpp:793</a></div></div>
|
|
|
|
|
<div class="ttc" id="anamespaceripple_html_acde3d7e2f059202351f714545da5b233"><div class="ttname"><a href="namespaceripple.html#acde3d7e2f059202351f714545da5b233">ripple::make_SHAMapStore</a></div><div class="ttdeci">std::unique_ptr< SHAMapStore > make_SHAMapStore(Application &app, Stoppable &parent, NodeStore::Scheduler &scheduler, beast::Journal journal)</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00797">SHAMapStoreImp.cpp:797</a></div></div>
|
|
|
|
|
<div class="ttc" id="anamespacestd_html"><div class="ttname"><a href="namespacestd.html">std</a></div><div class="ttdoc">STL namespace.</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_1_1SavedStateDB_html_ad08732c80f7c72199b1853d0516e1e0c"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp_1_1SavedStateDB.html#ad08732c80f7c72199b1853d0516e1e0c">ripple::SHAMapStoreImp::SavedStateDB::setLastRotated</a></div><div class="ttdeci">void setLastRotated(LedgerIndex seq)</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00139">SHAMapStoreImp.cpp:139</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a2ccbaf612bcdd9b53b25453f50d3e298"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a2ccbaf612bcdd9b53b25453f50d3e298">ripple::SHAMapStoreImp::canDelete_</a></div><div class="ttdeci">std::atomic< LedgerIndex > canDelete_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00105">SHAMapStoreImp.h:105</a></div></div>
|
|
|
|
|
@@ -988,11 +993,11 @@ $(function() {
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a71fc064e474c3b0dd17a92bdbaebe60f"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a71fc064e474c3b0dd17a92bdbaebe60f">ripple::SHAMapStoreImp::deleteBatch_</a></div><div class="ttdeci">std::uint32_t deleteBatch_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00110">SHAMapStoreImp.h:110</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_aa652318bb0714902d2cc90903878843f"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#aa652318bb0714902d2cc90903878843f">ripple::SHAMapStoreImp::fullBelowCache_</a></div><div class="ttdeci">FullBelowCache * fullBelowCache_</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8h_source.html#l00124">SHAMapStoreImp.h:124</a></div></div>
|
|
|
|
|
<div class="ttc" id="acount_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/chrono/duration/count.html">std::chrono::seconds::count</a></div><div class="ttdeci">T count(T... args)</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_af823965870aa9d05f14c8591c771a74a"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#af823965870aa9d05f14c8591c771a74a">ripple::SHAMapStoreImp::clearCaches</a></div><div class="ttdeci">void clearCaches(LedgerIndex validatedSeq)</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00654">SHAMapStoreImp.cpp:654</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_af823965870aa9d05f14c8591c771a74a"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#af823965870aa9d05f14c8591c771a74a">ripple::SHAMapStoreImp::clearCaches</a></div><div class="ttdeci">void clearCaches(LedgerIndex validatedSeq)</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00655">SHAMapStoreImp.cpp:655</a></div></div>
|
|
|
|
|
<div class="ttc" id="aempty_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/string/basic_string/empty.html">std::string::empty</a></div><div class="ttdeci">T empty(T... args)</div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1NetworkOPs_html_ad4c27eb535691555917e3b1ae5ab2637"><div class="ttname"><a href="classripple_1_1NetworkOPs.html#ad4c27eb535691555917e3b1ae5ab2637">ripple::NetworkOPs::strOperatingMode</a></div><div class="ttdeci">virtual std::string strOperatingMode(OperatingMode const mode, bool const admin=false) const =0</div></div>
|
|
|
|
|
<div class="ttc" id="anamespaceripple_html_a597325d7385ff9c19686e14e5bead510"><div class="ttname"><a href="namespaceripple.html#a597325d7385ff9c19686e14e5bead510">ripple::OperatingMode</a></div><div class="ttdeci">OperatingMode</div><div class="ttdoc">Specifies the mode under which the server believes it's operating.</div><div class="ttdef"><b>Definition:</b> <a href="NetworkOPs_8h_source.html#l00068">NetworkOPs.h:68</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a347e8e8ba053b93c6b924f277f535a94"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a347e8e8ba053b93c6b924f277f535a94">ripple::SHAMapStoreImp::makeBackendRotating</a></div><div class="ttdeci">std::unique_ptr< NodeStore::Backend > makeBackendRotating(std::string path=std::string())</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00566">SHAMapStoreImp.cpp:566</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a347e8e8ba053b93c6b924f277f535a94"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a347e8e8ba053b93c6b924f277f535a94">ripple::SHAMapStoreImp::makeBackendRotating</a></div><div class="ttdeci">std::unique_ptr< NodeStore::Backend > makeBackendRotating(std::string path=std::string())</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00567">SHAMapStoreImp.cpp:567</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassbeast_1_1Journal_html_a556228cb60bcf405c225d3f64b7b01ae"><div class="ttname"><a href="classbeast_1_1Journal.html#a556228cb60bcf405c225d3f64b7b01ae">beast::Journal::debug</a></div><div class="ttdeci">Stream debug() const</div><div class="ttdef"><b>Definition:</b> <a href="Journal_8h_source.html#l00315">Journal.h:315</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapStoreImp_html_a376d0378bf115b8e476b3771316901c5"><div class="ttname"><a href="classripple_1_1SHAMapStoreImp.html#a376d0378bf115b8e476b3771316901c5">ripple::SHAMapStoreImp::makeNodeStore</a></div><div class="ttdeci">std::unique_ptr< NodeStore::Database > makeNodeStore(std::string const &name, std::int32_t readThreads) override</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapStoreImp_8cpp_source.html#l00236">SHAMapStoreImp.cpp:236</a></div></div>
|
|
|
|
|
<div class="ttc" id="aclassripple_1_1SHAMapHash_html_a8f95b5bc14b7085d368f56aeaa17ef4f"><div class="ttname"><a href="classripple_1_1SHAMapHash.html#a8f95b5bc14b7085d368f56aeaa17ef4f">ripple::SHAMapHash::as_uint256</a></div><div class="ttdeci">uint256 const & as_uint256() const</div><div class="ttdef"><b>Definition:</b> <a href="SHAMapTreeNode_8h_source.html#l00058">SHAMapTreeNode.h:58</a></div></div>
|
|
|
|
|
|