mirror of
https://github.com/XRPLF/rippled.git
synced 2025-11-24 13:05:53 +00:00
deploy: 023f5704d0
This commit is contained in:
@@ -99,50 +99,50 @@ $(function() {
|
||||
<div class="line"><a name="l00028"></a><span class="lineno"><a class="line" href="structripple_1_1PeerFinder_1_1Sim_1_1VertexTraits.html"> 28</a></span> <span class="keyword">struct </span><a class="code" href="structripple_1_1PeerFinder_1_1Sim_1_1VertexTraits.html">VertexTraits</a>;</div>
|
||||
<div class="line"><a name="l00029"></a><span class="lineno"> 29</span>  </div>
|
||||
<div class="line"><a name="l00035"></a><span class="lineno"> 35</span> <span class="keyword">template</span> <<span class="keyword">typename</span> Vertex, <span class="keyword">typename</span> Function></div>
|
||||
<div class="line"><a name="l00036"></a><span class="lineno"><a class="line" href="namespaceripple_1_1PeerFinder_1_1Sim.html#ab4c46379edf889926d192afc3168589f"> 36</a></span> <span class="keywordtype">void</span> <a class="code" href="namespaceripple_1_1PeerFinder_1_1Sim.html#ab4c46379edf889926d192afc3168589f">breadth_first_traverse</a> (Vertex& start, Function f)</div>
|
||||
<div class="line"><a name="l00037"></a><span class="lineno"> 37</span> {</div>
|
||||
<div class="line"><a name="l00038"></a><span class="lineno"> 38</span>  <span class="keyword">using</span> Traits = <a class="code" href="structripple_1_1PeerFinder_1_1Sim_1_1VertexTraits.html">VertexTraits <Vertex></a>;</div>
|
||||
<div class="line"><a name="l00039"></a><span class="lineno"> 39</span>  <span class="keyword">using</span> Edges = <span class="keyword">typename</span> Traits::Edges;</div>
|
||||
<div class="line"><a name="l00040"></a><span class="lineno"> 40</span>  <span class="keyword">using</span> Edge = <span class="keyword">typename</span> Traits::Edge;</div>
|
||||
<div class="line"><a name="l00041"></a><span class="lineno"> 41</span>  </div>
|
||||
<div class="line"><a name="l00042"></a><span class="lineno"> 42</span>  <span class="keyword">using</span> Probe = <a class="codeRef" href="http://en.cppreference.com/w/cpp/utility/pair.html">std::pair <Vertex*, int></a>;</div>
|
||||
<div class="line"><a name="l00043"></a><span class="lineno"> 43</span>  <span class="keyword">using</span> Work = <a class="codeRef" href="http://en.cppreference.com/w/cpp/container/deque.html">std::deque <Probe></a>;</div>
|
||||
<div class="line"><a name="l00044"></a><span class="lineno"> 44</span>  <span class="keyword">using</span> Visited = <a class="codeRef" href="http://en.cppreference.com/w/cpp/container/set.html">std::set <Vertex*></a>;</div>
|
||||
<div class="line"><a name="l00045"></a><span class="lineno"> 45</span>  Work work;</div>
|
||||
<div class="line"><a name="l00046"></a><span class="lineno"> 46</span>  Visited visited;</div>
|
||||
<div class="line"><a name="l00047"></a><span class="lineno"> 47</span>  work.emplace_back (&start, 0);</div>
|
||||
<div class="line"><a name="l00048"></a><span class="lineno"> 48</span>  <span class="keywordtype">int</span> diameter (0);</div>
|
||||
<div class="line"><a name="l00049"></a><span class="lineno"> 49</span>  <span class="keywordflow">while</span> (! work.empty ())</div>
|
||||
<div class="line"><a name="l00050"></a><span class="lineno"> 50</span>  {</div>
|
||||
<div class="line"><a name="l00051"></a><span class="lineno"> 51</span>  Probe <span class="keyword">const</span> p (work.front());</div>
|
||||
<div class="line"><a name="l00052"></a><span class="lineno"> 52</span>  work.pop_front ();</div>
|
||||
<div class="line"><a name="l00053"></a><span class="lineno"> 53</span>  <span class="keywordflow">if</span> (visited.find (p.first) != visited.end ())</div>
|
||||
<div class="line"><a name="l00054"></a><span class="lineno"> 54</span>  <span class="keywordflow">continue</span>;</div>
|
||||
<div class="line"><a name="l00055"></a><span class="lineno"> 55</span>  diameter = <a class="codeRef" href="http://en.cppreference.com/w/cpp/algorithm/max.html">std::max</a> (p.second, diameter);</div>
|
||||
<div class="line"><a name="l00056"></a><span class="lineno"> 56</span>  visited.insert (p.first);</div>
|
||||
<div class="line"><a name="l00057"></a><span class="lineno"> 57</span>  <span class="keywordflow">for</span> (<span class="keyword">typename</span> Edges::iterator iter (</div>
|
||||
<div class="line"><a name="l00058"></a><span class="lineno"> 58</span>  Traits::edges (*p.first).begin());</div>
|
||||
<div class="line"><a name="l00059"></a><span class="lineno"> 59</span>  iter != Traits::edges (*p.first).end(); ++iter)</div>
|
||||
<div class="line"><a name="l00060"></a><span class="lineno"> 60</span>  {</div>
|
||||
<div class="line"><a name="l00061"></a><span class="lineno"> 61</span>  Vertex* v (Traits::vertex (*iter));</div>
|
||||
<div class="line"><a name="l00062"></a><span class="lineno"> 62</span>  <span class="keywordflow">if</span> (visited.find (v) != visited.end())</div>
|
||||
<div class="line"><a name="l00063"></a><span class="lineno"> 63</span>  <span class="keywordflow">continue</span>;</div>
|
||||
<div class="line"><a name="l00064"></a><span class="lineno"> 64</span>  <span class="keywordflow">if</span> (! iter->closed())</div>
|
||||
<div class="line"><a name="l00065"></a><span class="lineno"> 65</span>  work.emplace_back (v, p.second + 1);</div>
|
||||
<div class="line"><a name="l00066"></a><span class="lineno"> 66</span>  }</div>
|
||||
<div class="line"><a name="l00067"></a><span class="lineno"> 67</span>  f (*p.first, diameter);</div>
|
||||
<div class="line"><a name="l00068"></a><span class="lineno"> 68</span>  }</div>
|
||||
<div class="line"><a name="l00069"></a><span class="lineno"> 69</span> }</div>
|
||||
<div class="line"><a name="l00070"></a><span class="lineno"> 70</span>  </div>
|
||||
<div class="line"><a name="l00036"></a><span class="lineno"> 36</span> <span class="keywordtype">void</span></div>
|
||||
<div class="line"><a name="l00037"></a><span class="lineno"><a class="line" href="namespaceripple_1_1PeerFinder_1_1Sim.html#ab4c46379edf889926d192afc3168589f"> 37</a></span> <a class="code" href="namespaceripple_1_1PeerFinder_1_1Sim.html#ab4c46379edf889926d192afc3168589f">breadth_first_traverse</a>(Vertex& start, Function f)</div>
|
||||
<div class="line"><a name="l00038"></a><span class="lineno"> 38</span> {</div>
|
||||
<div class="line"><a name="l00039"></a><span class="lineno"> 39</span>  <span class="keyword">using</span> Traits = <a class="code" href="structripple_1_1PeerFinder_1_1Sim_1_1VertexTraits.html">VertexTraits<Vertex></a>;</div>
|
||||
<div class="line"><a name="l00040"></a><span class="lineno"> 40</span>  <span class="keyword">using</span> Edges = <span class="keyword">typename</span> Traits::Edges;</div>
|
||||
<div class="line"><a name="l00041"></a><span class="lineno"> 41</span>  <span class="keyword">using</span> Edge = <span class="keyword">typename</span> Traits::Edge;</div>
|
||||
<div class="line"><a name="l00042"></a><span class="lineno"> 42</span>  </div>
|
||||
<div class="line"><a name="l00043"></a><span class="lineno"> 43</span>  <span class="keyword">using</span> Probe = <a class="codeRef" href="http://en.cppreference.com/w/cpp/utility/pair.html">std::pair<Vertex*, int></a>;</div>
|
||||
<div class="line"><a name="l00044"></a><span class="lineno"> 44</span>  <span class="keyword">using</span> Work = <a class="codeRef" href="http://en.cppreference.com/w/cpp/container/deque.html">std::deque<Probe></a>;</div>
|
||||
<div class="line"><a name="l00045"></a><span class="lineno"> 45</span>  <span class="keyword">using</span> Visited = <a class="codeRef" href="http://en.cppreference.com/w/cpp/container/set.html">std::set<Vertex*></a>;</div>
|
||||
<div class="line"><a name="l00046"></a><span class="lineno"> 46</span>  Work work;</div>
|
||||
<div class="line"><a name="l00047"></a><span class="lineno"> 47</span>  Visited visited;</div>
|
||||
<div class="line"><a name="l00048"></a><span class="lineno"> 48</span>  work.emplace_back(&start, 0);</div>
|
||||
<div class="line"><a name="l00049"></a><span class="lineno"> 49</span>  <span class="keywordtype">int</span> diameter(0);</div>
|
||||
<div class="line"><a name="l00050"></a><span class="lineno"> 50</span>  <span class="keywordflow">while</span> (!work.empty())</div>
|
||||
<div class="line"><a name="l00051"></a><span class="lineno"> 51</span>  {</div>
|
||||
<div class="line"><a name="l00052"></a><span class="lineno"> 52</span>  Probe <span class="keyword">const</span> p(work.front());</div>
|
||||
<div class="line"><a name="l00053"></a><span class="lineno"> 53</span>  work.pop_front();</div>
|
||||
<div class="line"><a name="l00054"></a><span class="lineno"> 54</span>  <span class="keywordflow">if</span> (visited.find(p.first) != visited.end())</div>
|
||||
<div class="line"><a name="l00055"></a><span class="lineno"> 55</span>  <span class="keywordflow">continue</span>;</div>
|
||||
<div class="line"><a name="l00056"></a><span class="lineno"> 56</span>  diameter = <a class="codeRef" href="http://en.cppreference.com/w/cpp/algorithm/max.html">std::max</a>(p.second, diameter);</div>
|
||||
<div class="line"><a name="l00057"></a><span class="lineno"> 57</span>  visited.insert(p.first);</div>
|
||||
<div class="line"><a name="l00058"></a><span class="lineno"> 58</span>  <span class="keywordflow">for</span> (<span class="keyword">typename</span> Edges::iterator iter(Traits::edges(*p.first).begin());</div>
|
||||
<div class="line"><a name="l00059"></a><span class="lineno"> 59</span>  iter != Traits::edges(*p.first).end();</div>
|
||||
<div class="line"><a name="l00060"></a><span class="lineno"> 60</span>  ++iter)</div>
|
||||
<div class="line"><a name="l00061"></a><span class="lineno"> 61</span>  {</div>
|
||||
<div class="line"><a name="l00062"></a><span class="lineno"> 62</span>  Vertex* v(Traits::vertex(*iter));</div>
|
||||
<div class="line"><a name="l00063"></a><span class="lineno"> 63</span>  <span class="keywordflow">if</span> (visited.find(v) != visited.end())</div>
|
||||
<div class="line"><a name="l00064"></a><span class="lineno"> 64</span>  <span class="keywordflow">continue</span>;</div>
|
||||
<div class="line"><a name="l00065"></a><span class="lineno"> 65</span>  <span class="keywordflow">if</span> (!iter->closed())</div>
|
||||
<div class="line"><a name="l00066"></a><span class="lineno"> 66</span>  work.emplace_back(v, p.second + 1);</div>
|
||||
<div class="line"><a name="l00067"></a><span class="lineno"> 67</span>  }</div>
|
||||
<div class="line"><a name="l00068"></a><span class="lineno"> 68</span>  f(*p.first, diameter);</div>
|
||||
<div class="line"><a name="l00069"></a><span class="lineno"> 69</span>  }</div>
|
||||
<div class="line"><a name="l00070"></a><span class="lineno"> 70</span> }</div>
|
||||
<div class="line"><a name="l00071"></a><span class="lineno"> 71</span>  </div>
|
||||
<div class="line"><a name="l00072"></a><span class="lineno"> 72</span> }</div>
|
||||
<div class="line"><a name="l00073"></a><span class="lineno"> 73</span> }</div>
|
||||
<div class="line"><a name="l00074"></a><span class="lineno"> 74</span> }</div>
|
||||
<div class="line"><a name="l00072"></a><span class="lineno"> 72</span> } <span class="comment">// namespace Sim</span></div>
|
||||
<div class="line"><a name="l00073"></a><span class="lineno"> 73</span> } <span class="comment">// namespace PeerFinder</span></div>
|
||||
<div class="line"><a name="l00074"></a><span class="lineno"> 74</span> } <span class="comment">// namespace ripple</span></div>
|
||||
<div class="line"><a name="l00075"></a><span class="lineno"> 75</span>  </div>
|
||||
<div class="line"><a name="l00076"></a><span class="lineno"> 76</span> <span class="preprocessor">#endif</span></div>
|
||||
</div><!-- fragment --></div><!-- contents -->
|
||||
<div class="ttc" id="apair_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/utility/pair.html">std::pair</a></div></div>
|
||||
<div class="ttc" id="anamespaceripple_1_1PeerFinder_1_1Sim_html_ab4c46379edf889926d192afc3168589f"><div class="ttname"><a href="namespaceripple_1_1PeerFinder_1_1Sim.html#ab4c46379edf889926d192afc3168589f">ripple::PeerFinder::Sim::breadth_first_traverse</a></div><div class="ttdeci">void breadth_first_traverse(Vertex &start, Function f)</div><div class="ttdoc">Call a function for each vertex in a connected graph.</div><div class="ttdef"><b>Definition:</b> <a href="GraphAlgorithms_8h_source.html#l00036">GraphAlgorithms.h:36</a></div></div>
|
||||
<div class="ttc" id="anamespaceripple_1_1PeerFinder_1_1Sim_html_ab4c46379edf889926d192afc3168589f"><div class="ttname"><a href="namespaceripple_1_1PeerFinder_1_1Sim.html#ab4c46379edf889926d192afc3168589f">ripple::PeerFinder::Sim::breadth_first_traverse</a></div><div class="ttdeci">void breadth_first_traverse(Vertex &start, Function f)</div><div class="ttdoc">Call a function for each vertex in a connected graph.</div><div class="ttdef"><b>Definition:</b> <a href="GraphAlgorithms_8h_source.html#l00037">GraphAlgorithms.h:37</a></div></div>
|
||||
<div class="ttc" id="astructripple_1_1PeerFinder_1_1Sim_1_1VertexTraits_html"><div class="ttname"><a href="structripple_1_1PeerFinder_1_1Sim_1_1VertexTraits.html">ripple::PeerFinder::Sim::VertexTraits</a></div><div class="ttdef"><b>Definition:</b> <a href="GraphAlgorithms_8h_source.html#l00028">GraphAlgorithms.h:28</a></div></div>
|
||||
<div class="ttc" id="adeque_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/container/deque.html">std::deque</a></div><div class="ttdoc">STL class.</div></div>
|
||||
<div class="ttc" id="anamespaceripple_html"><div class="ttname"><a href="namespaceripple.html">ripple</a></div><div class="ttdoc">Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.</div><div class="ttdef"><b>Definition:</b> <a href="RCLCensorshipDetector_8h_source.html#l00029">RCLCensorshipDetector.h:29</a></div></div>
|
||||
|
||||
Reference in New Issue
Block a user