You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@mesos.apache.org by gi...@apache.org on 2017/12/05 04:18:11 UTC

[2/3] mesos-site git commit: Updated the website built from mesos SHA: 0e35094.

http://git-wip-us.apache.org/repos/asf/mesos-site/blob/4d37bae2/content/api/latest/c++/src_2master_2master_8hpp_source.html
----------------------------------------------------------------------
diff --git a/content/api/latest/c++/src_2master_2master_8hpp_source.html b/content/api/latest/c++/src_2master_2master_8hpp_source.html
index 66f28dd..918fffd 100644
--- a/content/api/latest/c++/src_2master_2master_8hpp_source.html
+++ b/content/api/latest/c++/src_2master_2master_8hpp_source.html
@@ -2457,474 +2457,473 @@
 <div class="line"><a name="l02518"></a><span class="lineno"> 2518</span>&#160;      <span class="comment">// role is absent from the framework&#39;s set of roles. In this</span></div>
 <div class="line"><a name="l02519"></a><span class="lineno"> 2519</span>&#160;      <span class="comment">// case, we track the role&#39;s allocation for this framework.</span></div>
 <div class="line"><a name="l02520"></a><span class="lineno"> 2520</span>&#160;      <a class="code" href="foreach_8hpp.html#acac417231a256d7c6164a86db970da86">foreachkey</a> (<span class="keyword">const</span> std::string&amp; role, consumed-&gt;allocations()) {</div>
-<div class="line"><a name="l02521"></a><span class="lineno"> 2521</span>&#160;        <span class="keyword">auto</span> allocatedToRole = [&amp;role](<span class="keyword">const</span> Resource&amp; resource) {</div>
-<div class="line"><a name="l02522"></a><span class="lineno"> 2522</span>&#160;          <span class="keywordflow">return</span> resource.allocation_info().role() == role;</div>
-<div class="line"><a name="l02523"></a><span class="lineno"> 2523</span>&#160;        };</div>
-<div class="line"><a name="l02524"></a><span class="lineno"> 2524</span>&#160;</div>
-<div class="line"><a name="l02525"></a><span class="lineno"> 2525</span>&#160;        <span class="keywordflow">if</span> (<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5">roles</a>.count(role) == 0 &amp;&amp;</div>
-<div class="line"><a name="l02526"></a><span class="lineno"> 2526</span>&#160;            <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a35847f2388d25e0cb9b3a9d0a722fbdd">totalUsedResources</a>.<a class="code" href="classmesos_1_1Resources.html#a62ae547c0d24fdfb139549e9b8126fdf">filter</a>(allocatedToRole).<a class="code" href="classmesos_1_1Resources.html#ab46b900ebe62b19390d9a2a82b46eb15">empty</a>()) {</div>
-<div class="line"><a name="l02527"></a><span class="lineno"> 2527</span>&#160;          CHECK(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a965f66810b71a0d2bab683fee1b6a9b6">totalOfferedResources</a>.<a class="code" href="classmesos_1_1Resources.html#a62ae547c0d24fdfb139549e9b8126fdf">filter</a>(allocatedToRole).<a class="code" href="classmesos_1_1Resources.html#ab46b900ebe62b19390d9a2a82b46eb15">empty</a>());</div>
-<div class="line"><a name="l02528"></a><span class="lineno"> 2528</span>&#160;          <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3edaf411ec6e409a3f8b2a77988ef65a">untrackUnderRole</a>(role);</div>
-<div class="line"><a name="l02529"></a><span class="lineno"> 2529</span>&#160;        }</div>
-<div class="line"><a name="l02530"></a><span class="lineno"> 2530</span>&#160;      }</div>
-<div class="line"><a name="l02531"></a><span class="lineno"> 2531</span>&#160;    }</div>
-<div class="line"><a name="l02532"></a><span class="lineno"> 2532</span>&#160;  }</div>
-<div class="line"><a name="l02533"></a><span class="lineno"> 2533</span>&#160;</div>
-<div class="line"><a name="l02534"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2cbf9814d6392f471a6970ed488be080"> 2534</a></span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2cbf9814d6392f471a6970ed488be080">recoverResources</a>(OfferOperation* operation)</div>
-<div class="line"><a name="l02535"></a><span class="lineno"> 2535</span>&#160;  {</div>
-<div class="line"><a name="l02536"></a><span class="lineno"> 2536</span>&#160;    CHECK(operation-&gt;has_slave_id())</div>
-<div class="line"><a name="l02537"></a><span class="lineno"> 2537</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;External resource provider is not supported yet&quot;</span>;</div>
+<div class="line"><a name="l02521"></a><span class="lineno"> 2521</span>&#160;        <span class="keywordflow">if</span> (!<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a614fb3ba127133b939e2a733c6ecbf2a">isTrackedUnderRole</a>(role)) {</div>
+<div class="line"><a name="l02522"></a><span class="lineno"> 2522</span>&#160;          <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#afa185682905163563412aa1915e612c8">trackUnderRole</a>(role);</div>
+<div class="line"><a name="l02523"></a><span class="lineno"> 2523</span>&#160;        }</div>
+<div class="line"><a name="l02524"></a><span class="lineno"> 2524</span>&#160;      }</div>
+<div class="line"><a name="l02525"></a><span class="lineno"> 2525</span>&#160;    }</div>
+<div class="line"><a name="l02526"></a><span class="lineno"> 2526</span>&#160;  }</div>
+<div class="line"><a name="l02527"></a><span class="lineno"> 2527</span>&#160;</div>
+<div class="line"><a name="l02528"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2cbf9814d6392f471a6970ed488be080"> 2528</a></span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2cbf9814d6392f471a6970ed488be080">recoverResources</a>(OfferOperation* operation)</div>
+<div class="line"><a name="l02529"></a><span class="lineno"> 2529</span>&#160;  {</div>
+<div class="line"><a name="l02530"></a><span class="lineno"> 2530</span>&#160;    CHECK(operation-&gt;has_slave_id())</div>
+<div class="line"><a name="l02531"></a><span class="lineno"> 2531</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;External resource provider is not supported yet&quot;</span>;</div>
+<div class="line"><a name="l02532"></a><span class="lineno"> 2532</span>&#160;</div>
+<div class="line"><a name="l02533"></a><span class="lineno"> 2533</span>&#160;    <span class="keyword">const</span> SlaveID&amp; slaveId = operation-&gt;slave_id();</div>
+<div class="line"><a name="l02534"></a><span class="lineno"> 2534</span>&#160;</div>
+<div class="line"><a name="l02535"></a><span class="lineno"> 2535</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="namespacemesos_1_1internal_1_1protobuf.html#a19a8e8be02b815dab4cecd8382e3dd26">protobuf::isSpeculativeOperation</a>(operation-&gt;info())) {</div>
+<div class="line"><a name="l02536"></a><span class="lineno"> 2536</span>&#160;      <span class="keywordflow">return</span>;</div>
+<div class="line"><a name="l02537"></a><span class="lineno"> 2537</span>&#160;    }</div>
 <div class="line"><a name="l02538"></a><span class="lineno"> 2538</span>&#160;</div>
-<div class="line"><a name="l02539"></a><span class="lineno"> 2539</span>&#160;    <span class="keyword">const</span> SlaveID&amp; slaveId = operation-&gt;slave_id();</div>
-<div class="line"><a name="l02540"></a><span class="lineno"> 2540</span>&#160;</div>
-<div class="line"><a name="l02541"></a><span class="lineno"> 2541</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="namespacemesos_1_1internal_1_1protobuf.html#a19a8e8be02b815dab4cecd8382e3dd26">protobuf::isSpeculativeOperation</a>(operation-&gt;info())) {</div>
-<div class="line"><a name="l02542"></a><span class="lineno"> 2542</span>&#160;      <span class="keywordflow">return</span>;</div>
-<div class="line"><a name="l02543"></a><span class="lineno"> 2543</span>&#160;    }</div>
-<div class="line"><a name="l02544"></a><span class="lineno"> 2544</span>&#160;</div>
-<div class="line"><a name="l02545"></a><span class="lineno"> 2545</span>&#160;    <a class="code" href="classTry.html">Try&lt;Resources&gt;</a> consumed = <a class="code" href="namespacemesos_1_1internal_1_1protobuf.html#aaad34fc9798891303cecdba77c1e473c">protobuf::getConsumedResources</a>(operation-&gt;info());</div>
-<div class="line"><a name="l02546"></a><span class="lineno"> 2546</span>&#160;    <a class="code" href="stout_2include_2stout_2check_8hpp.html#aee320e7c6e107071f4b85d4cc135a265">CHECK_SOME</a>(consumed);</div>
-<div class="line"><a name="l02547"></a><span class="lineno"> 2547</span>&#160;</div>
-<div class="line"><a name="l02548"></a><span class="lineno"> 2548</span>&#160;    CHECK(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a35847f2388d25e0cb9b3a9d0a722fbdd">totalUsedResources</a>.<a class="code" href="classmesos_1_1Resources.html#a30fc4fe000da99818bfcee5bb780e5d4">contains</a>(consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>()))</div>
-<div class="line"><a name="l02549"></a><span class="lineno"> 2549</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;Tried to recover resources &quot;</span> &lt;&lt; consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>()</div>
-<div class="line"><a name="l02550"></a><span class="lineno"> 2550</span>&#160;      &lt;&lt; <span class="stringliteral">&quot; which do not seem used&quot;</span>;</div>
-<div class="line"><a name="l02551"></a><span class="lineno"> 2551</span>&#160;</div>
-<div class="line"><a name="l02552"></a><span class="lineno"> 2552</span>&#160;    CHECK(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9085d3f2c156a7772cbd243776a62491">usedResources</a>[slaveId].<a class="code" href="namespacestrings.html#a269921757daf11096d3f5e02686f8444">contains</a>(consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>()))</div>
-<div class="line"><a name="l02553"></a><span class="lineno"> 2553</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;Tried to recover resources &quot;</span> &lt;&lt; consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>() &lt;&lt; <span class="stringliteral">&quot; of agent &quot;</span></div>
-<div class="line"><a name="l02554"></a><span class="lineno"> 2554</span>&#160;      &lt;&lt; slaveId &lt;&lt; <span class="stringliteral">&quot; which do not seem used&quot;</span>;</div>
+<div class="line"><a name="l02539"></a><span class="lineno"> 2539</span>&#160;    <a class="code" href="classTry.html">Try&lt;Resources&gt;</a> consumed = <a class="code" href="namespacemesos_1_1internal_1_1protobuf.html#aaad34fc9798891303cecdba77c1e473c">protobuf::getConsumedResources</a>(operation-&gt;info());</div>
+<div class="line"><a name="l02540"></a><span class="lineno"> 2540</span>&#160;    <a class="code" href="stout_2include_2stout_2check_8hpp.html#aee320e7c6e107071f4b85d4cc135a265">CHECK_SOME</a>(consumed);</div>
+<div class="line"><a name="l02541"></a><span class="lineno"> 2541</span>&#160;</div>
+<div class="line"><a name="l02542"></a><span class="lineno"> 2542</span>&#160;    CHECK(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a35847f2388d25e0cb9b3a9d0a722fbdd">totalUsedResources</a>.<a class="code" href="classmesos_1_1Resources.html#a30fc4fe000da99818bfcee5bb780e5d4">contains</a>(consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>()))</div>
+<div class="line"><a name="l02543"></a><span class="lineno"> 2543</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;Tried to recover resources &quot;</span> &lt;&lt; consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>()</div>
+<div class="line"><a name="l02544"></a><span class="lineno"> 2544</span>&#160;      &lt;&lt; <span class="stringliteral">&quot; which do not seem used&quot;</span>;</div>
+<div class="line"><a name="l02545"></a><span class="lineno"> 2545</span>&#160;</div>
+<div class="line"><a name="l02546"></a><span class="lineno"> 2546</span>&#160;    CHECK(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9085d3f2c156a7772cbd243776a62491">usedResources</a>[slaveId].<a class="code" href="namespacestrings.html#a269921757daf11096d3f5e02686f8444">contains</a>(consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>()))</div>
+<div class="line"><a name="l02547"></a><span class="lineno"> 2547</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;Tried to recover resources &quot;</span> &lt;&lt; consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>() &lt;&lt; <span class="stringliteral">&quot; of agent &quot;</span></div>
+<div class="line"><a name="l02548"></a><span class="lineno"> 2548</span>&#160;      &lt;&lt; slaveId &lt;&lt; <span class="stringliteral">&quot; which do not seem used&quot;</span>;</div>
+<div class="line"><a name="l02549"></a><span class="lineno"> 2549</span>&#160;</div>
+<div class="line"><a name="l02550"></a><span class="lineno"> 2550</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a35847f2388d25e0cb9b3a9d0a722fbdd">totalUsedResources</a> -= consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>();</div>
+<div class="line"><a name="l02551"></a><span class="lineno"> 2551</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9085d3f2c156a7772cbd243776a62491">usedResources</a>[slaveId] -= consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>();</div>
+<div class="line"><a name="l02552"></a><span class="lineno"> 2552</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9085d3f2c156a7772cbd243776a62491">usedResources</a>[slaveId].empty()) {</div>
+<div class="line"><a name="l02553"></a><span class="lineno"> 2553</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9085d3f2c156a7772cbd243776a62491">usedResources</a>.erase(slaveId);</div>
+<div class="line"><a name="l02554"></a><span class="lineno"> 2554</span>&#160;    }</div>
 <div class="line"><a name="l02555"></a><span class="lineno"> 2555</span>&#160;</div>
-<div class="line"><a name="l02556"></a><span class="lineno"> 2556</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a35847f2388d25e0cb9b3a9d0a722fbdd">totalUsedResources</a> -= consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>();</div>
-<div class="line"><a name="l02557"></a><span class="lineno"> 2557</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9085d3f2c156a7772cbd243776a62491">usedResources</a>[slaveId] -= consumed.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>();</div>
-<div class="line"><a name="l02558"></a><span class="lineno"> 2558</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9085d3f2c156a7772cbd243776a62491">usedResources</a>[slaveId].empty()) {</div>
-<div class="line"><a name="l02559"></a><span class="lineno"> 2559</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9085d3f2c156a7772cbd243776a62491">usedResources</a>.erase(slaveId);</div>
-<div class="line"><a name="l02560"></a><span class="lineno"> 2560</span>&#160;    }</div>
-<div class="line"><a name="l02561"></a><span class="lineno"> 2561</span>&#160;</div>
-<div class="line"><a name="l02562"></a><span class="lineno"> 2562</span>&#160;    <span class="comment">// If we are no longer subscribed to the role to which these</span></div>
-<div class="line"><a name="l02563"></a><span class="lineno"> 2563</span>&#160;    <span class="comment">// resources are being returned to, and we have no more resources</span></div>
-<div class="line"><a name="l02564"></a><span class="lineno"> 2564</span>&#160;    <span class="comment">// allocated to us for that role, stop tracking the framework</span></div>
-<div class="line"><a name="l02565"></a><span class="lineno"> 2565</span>&#160;    <span class="comment">// under the role.</span></div>
-<div class="line"><a name="l02566"></a><span class="lineno"> 2566</span>&#160;    <a class="code" href="foreach_8hpp.html#acac417231a256d7c6164a86db970da86">foreachkey</a> (<span class="keyword">const</span> std::string&amp; role, consumed-&gt;allocations()) {</div>
-<div class="line"><a name="l02567"></a><span class="lineno"> 2567</span>&#160;      <span class="keyword">auto</span> allocatedToRole = [&amp;role](<span class="keyword">const</span> Resource&amp; resource) {</div>
-<div class="line"><a name="l02568"></a><span class="lineno"> 2568</span>&#160;        <span class="keywordflow">return</span> resource.allocation_info().role() == role;</div>
-<div class="line"><a name="l02569"></a><span class="lineno"> 2569</span>&#160;      };</div>
-<div class="line"><a name="l02570"></a><span class="lineno"> 2570</span>&#160;</div>
-<div class="line"><a name="l02571"></a><span class="lineno"> 2571</span>&#160;      <span class="keywordflow">if</span> (<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5">roles</a>.count(role) == 0 &amp;&amp;</div>
-<div class="line"><a name="l02572"></a><span class="lineno"> 2572</span>&#160;          <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a35847f2388d25e0cb9b3a9d0a722fbdd">totalUsedResources</a>.<a class="code" href="classmesos_1_1Resources.html#a62ae547c0d24fdfb139549e9b8126fdf">filter</a>(allocatedToRole).<a class="code" href="classmesos_1_1Resources.html#ab46b900ebe62b19390d9a2a82b46eb15">empty</a>()) {</div>
-<div class="line"><a name="l02573"></a><span class="lineno"> 2573</span>&#160;        CHECK(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a965f66810b71a0d2bab683fee1b6a9b6">totalOfferedResources</a>.<a class="code" href="classmesos_1_1Resources.html#a62ae547c0d24fdfb139549e9b8126fdf">filter</a>(allocatedToRole).<a class="code" href="classmesos_1_1Resources.html#ab46b900ebe62b19390d9a2a82b46eb15">empty</a>());</div>
-<div class="line"><a name="l02574"></a><span class="lineno"> 2574</span>&#160;        <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3edaf411ec6e409a3f8b2a77988ef65a">untrackUnderRole</a>(role);</div>
-<div class="line"><a name="l02575"></a><span class="lineno"> 2575</span>&#160;      }</div>
-<div class="line"><a name="l02576"></a><span class="lineno"> 2576</span>&#160;    }</div>
-<div class="line"><a name="l02577"></a><span class="lineno"> 2577</span>&#160;  }</div>
-<div class="line"><a name="l02578"></a><span class="lineno"> 2578</span>&#160;</div>
-<div class="line"><a name="l02579"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ad28965b324be81c14e5d41524e917beb"> 2579</a></span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ad28965b324be81c14e5d41524e917beb">removeOfferOperation</a>(OfferOperation* operation)</div>
-<div class="line"><a name="l02580"></a><span class="lineno"> 2580</span>&#160;  {</div>
-<div class="line"><a name="l02581"></a><span class="lineno"> 2581</span>&#160;    <a class="code" href="classTry.html">Try&lt;UUID&gt;</a> uuid = UUID::fromBytes(operation-&gt;operation_uuid());</div>
-<div class="line"><a name="l02582"></a><span class="lineno"> 2582</span>&#160;    <a class="code" href="stout_2include_2stout_2check_8hpp.html#aee320e7c6e107071f4b85d4cc135a265">CHECK_SOME</a>(uuid);</div>
-<div class="line"><a name="l02583"></a><span class="lineno"> 2583</span>&#160;</div>
-<div class="line"><a name="l02584"></a><span class="lineno"> 2584</span>&#160;    CHECK(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a650e493bb396d724446d9571e5842901">offerOperations</a>.<a class="code" href="classhashmap.html#ac142b3f8b73c76d5d4545bbd299007e5">contains</a>(uuid.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>()))</div>
-<div class="line"><a name="l02585"></a><span class="lineno"> 2585</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;Unknown offer operation &#39;&quot;</span> &lt;&lt; operation-&gt;info().id()</div>
-<div class="line"><a name="l02586"></a><span class="lineno"> 2586</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;&#39; (uuid: &quot;</span> &lt;&lt; uuid-&gt;<a class="code" href="structid_1_1UUID.html#af024badbc379374ac635031eed57dc5f">toString</a>() &lt;&lt; <span class="stringliteral">&quot;) &quot;</span></div>
-<div class="line"><a name="l02587"></a><span class="lineno"> 2587</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;of framework &quot;</span> &lt;&lt; operation-&gt;framework_id();</div>
-<div class="line"><a name="l02588"></a><span class="lineno"> 2588</span>&#160;</div>
-<div class="line"><a name="l02589"></a><span class="lineno"> 2589</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a650e493bb396d724446d9571e5842901">offerOperations</a>.erase(uuid.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>());</div>
-<div class="line"><a name="l02590"></a><span class="lineno"> 2590</span>&#160;  }</div>
-<div class="line"><a name="l02591"></a><span class="lineno"> 2591</span>&#160;</div>
-<div class="line"><a name="l02592"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac971d54c3567de6411c6aa7e998c5417"> 2592</a></span>&#160;  <span class="keyword">const</span> FrameworkID <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac971d54c3567de6411c6aa7e998c5417">id</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> info.id(); }</div>
-<div class="line"><a name="l02593"></a><span class="lineno"> 2593</span>&#160;</div>
-<div class="line"><a name="l02594"></a><span class="lineno"> 2594</span>&#160;  <span class="comment">// Update fields in &#39;info&#39; using those in &#39;newInfo&#39;. Currently this</span></div>
-<div class="line"><a name="l02595"></a><span class="lineno"> 2595</span>&#160;  <span class="comment">// only updates `role`/`roles`, &#39;name&#39;, &#39;failover_timeout&#39;, &#39;hostname&#39;,</span></div>
-<div class="line"><a name="l02596"></a><span class="lineno"> 2596</span>&#160;  <span class="comment">// &#39;webui_url&#39;, &#39;capabilities&#39;, and &#39;labels&#39;.</span></div>
-<div class="line"><a name="l02597"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a8f5f1a0e7c16c0e7750373c1146dc3a1"> 2597</a></span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a8f5f1a0e7c16c0e7750373c1146dc3a1">update</a>(<span class="keyword">const</span> FrameworkInfo&amp; newInfo)</div>
-<div class="line"><a name="l02598"></a><span class="lineno"> 2598</span>&#160;  {</div>
-<div class="line"><a name="l02599"></a><span class="lineno"> 2599</span>&#160;    <span class="comment">// We only merge &#39;info&#39; from the same framework &#39;id&#39;.</span></div>
-<div class="line"><a name="l02600"></a><span class="lineno"> 2600</span>&#160;    CHECK_EQ(info.id(), newInfo.id());</div>
-<div class="line"><a name="l02601"></a><span class="lineno"> 2601</span>&#160;</div>
-<div class="line"><a name="l02602"></a><span class="lineno"> 2602</span>&#160;    <span class="comment">// Save the old list of roles for later.</span></div>
-<div class="line"><a name="l02603"></a><span class="lineno"> 2603</span>&#160;    std::set&lt;std::string&gt; oldRoles = <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5">roles</a>;</div>
-<div class="line"><a name="l02604"></a><span class="lineno"> 2604</span>&#160;</div>
-<div class="line"><a name="l02605"></a><span class="lineno"> 2605</span>&#160;    <span class="comment">// TODO(jmlvanre): Merge other fields as per design doc in</span></div>
-<div class="line"><a name="l02606"></a><span class="lineno"> 2606</span>&#160;    <span class="comment">// MESOS-703.</span></div>
-<div class="line"><a name="l02607"></a><span class="lineno"> 2607</span>&#160;</div>
-<div class="line"><a name="l02608"></a><span class="lineno"> 2608</span>&#160;    info.clear_role();</div>
-<div class="line"><a name="l02609"></a><span class="lineno"> 2609</span>&#160;    info.clear_roles();</div>
-<div class="line"><a name="l02610"></a><span class="lineno"> 2610</span>&#160;</div>
-<div class="line"><a name="l02611"></a><span class="lineno"> 2611</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_role()) {</div>
-<div class="line"><a name="l02612"></a><span class="lineno"> 2612</span>&#160;      info.set_role(newInfo.role());</div>
-<div class="line"><a name="l02613"></a><span class="lineno"> 2613</span>&#160;    }</div>
-<div class="line"><a name="l02614"></a><span class="lineno"> 2614</span>&#160;</div>
-<div class="line"><a name="l02615"></a><span class="lineno"> 2615</span>&#160;    <span class="keywordflow">if</span> (newInfo.roles_size() &gt; 0) {</div>
-<div class="line"><a name="l02616"></a><span class="lineno"> 2616</span>&#160;      info.mutable_roles()-&gt;CopyFrom(newInfo.roles());</div>
-<div class="line"><a name="l02617"></a><span class="lineno"> 2617</span>&#160;    }</div>
-<div class="line"><a name="l02618"></a><span class="lineno"> 2618</span>&#160;</div>
-<div class="line"><a name="l02619"></a><span class="lineno"> 2619</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5">roles</a> = <a class="code" href="namespacemesos_1_1internal_1_1protobuf_1_1framework.html#a34d007aecebcd1c9dbd3ee0ad1d39155">protobuf::framework::getRoles</a>(newInfo);</div>
-<div class="line"><a name="l02620"></a><span class="lineno"> 2620</span>&#160;</div>
-<div class="line"><a name="l02621"></a><span class="lineno"> 2621</span>&#160;    <span class="keywordflow">if</span> (newInfo.user() != info.user()) {</div>
-<div class="line"><a name="l02622"></a><span class="lineno"> 2622</span>&#160;      LOG(WARNING) &lt;&lt; <span class="stringliteral">&quot;Cannot update FrameworkInfo.user to &#39;&quot;</span> &lt;&lt; newInfo.user()</div>
-<div class="line"><a name="l02623"></a><span class="lineno"> 2623</span>&#160;                   &lt;&lt; <span class="stringliteral">&quot;&#39; for framework &quot;</span> &lt;&lt; <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac971d54c3567de6411c6aa7e998c5417">id</a>() &lt;&lt; <span class="stringliteral">&quot;. Check MESOS-703&quot;</span>;</div>
-<div class="line"><a name="l02624"></a><span class="lineno"> 2624</span>&#160;    }</div>
-<div class="line"><a name="l02625"></a><span class="lineno"> 2625</span>&#160;</div>
-<div class="line"><a name="l02626"></a><span class="lineno"> 2626</span>&#160;    info.set_name(newInfo.name());</div>
-<div class="line"><a name="l02627"></a><span class="lineno"> 2627</span>&#160;</div>
-<div class="line"><a name="l02628"></a><span class="lineno"> 2628</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_failover_timeout()) {</div>
-<div class="line"><a name="l02629"></a><span class="lineno"> 2629</span>&#160;      info.set_failover_timeout(newInfo.failover_timeout());</div>
-<div class="line"><a name="l02630"></a><span class="lineno"> 2630</span>&#160;    } <span class="keywordflow">else</span> {</div>
-<div class="line"><a name="l02631"></a><span class="lineno"> 2631</span>&#160;      info.clear_failover_timeout();</div>
-<div class="line"><a name="l02632"></a><span class="lineno"> 2632</span>&#160;    }</div>
-<div class="line"><a name="l02633"></a><span class="lineno"> 2633</span>&#160;</div>
-<div class="line"><a name="l02634"></a><span class="lineno"> 2634</span>&#160;    <span class="keywordflow">if</span> (newInfo.checkpoint() != info.checkpoint()) {</div>
-<div class="line"><a name="l02635"></a><span class="lineno"> 2635</span>&#160;      LOG(WARNING) &lt;&lt; <span class="stringliteral">&quot;Cannot update FrameworkInfo.checkpoint to &#39;&quot;</span></div>
-<div class="line"><a name="l02636"></a><span class="lineno"> 2636</span>&#160;                   &lt;&lt; <a class="code" href="namespacens.html#a28116b46e6543597a11733424cd1aa20">stringify</a>(newInfo.checkpoint()) &lt;&lt; <span class="stringliteral">&quot;&#39; for framework &quot;</span></div>
-<div class="line"><a name="l02637"></a><span class="lineno"> 2637</span>&#160;                   &lt;&lt; <span class="keywordtype">id</span>() &lt;&lt; <span class="stringliteral">&quot;. Check MESOS-703&quot;</span>;</div>
-<div class="line"><a name="l02638"></a><span class="lineno"> 2638</span>&#160;    }</div>
-<div class="line"><a name="l02639"></a><span class="lineno"> 2639</span>&#160;</div>
-<div class="line"><a name="l02640"></a><span class="lineno"> 2640</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_hostname()) {</div>
-<div class="line"><a name="l02641"></a><span class="lineno"> 2641</span>&#160;      info.set_hostname(newInfo.hostname());</div>
-<div class="line"><a name="l02642"></a><span class="lineno"> 2642</span>&#160;    } <span class="keywordflow">else</span> {</div>
-<div class="line"><a name="l02643"></a><span class="lineno"> 2643</span>&#160;      info.clear_hostname();</div>
-<div class="line"><a name="l02644"></a><span class="lineno"> 2644</span>&#160;    }</div>
-<div class="line"><a name="l02645"></a><span class="lineno"> 2645</span>&#160;</div>
-<div class="line"><a name="l02646"></a><span class="lineno"> 2646</span>&#160;    <span class="keywordflow">if</span> (newInfo.principal() != info.principal()) {</div>
-<div class="line"><a name="l02647"></a><span class="lineno"> 2647</span>&#160;      LOG(WARNING) &lt;&lt; <span class="stringliteral">&quot;Cannot update FrameworkInfo.principal to &#39;&quot;</span></div>
-<div class="line"><a name="l02648"></a><span class="lineno"> 2648</span>&#160;                   &lt;&lt; newInfo.principal() &lt;&lt; <span class="stringliteral">&quot;&#39; for framework &quot;</span> &lt;&lt; <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac971d54c3567de6411c6aa7e998c5417">id</a>()</div>
-<div class="line"><a name="l02649"></a><span class="lineno"> 2649</span>&#160;                   &lt;&lt; <span class="stringliteral">&quot;. Check MESOS-703&quot;</span>;</div>
-<div class="line"><a name="l02650"></a><span class="lineno"> 2650</span>&#160;    }</div>
-<div class="line"><a name="l02651"></a><span class="lineno"> 2651</span>&#160;</div>
-<div class="line"><a name="l02652"></a><span class="lineno"> 2652</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_webui_url()) {</div>
-<div class="line"><a name="l02653"></a><span class="lineno"> 2653</span>&#160;      info.set_webui_url(newInfo.webui_url());</div>
-<div class="line"><a name="l02654"></a><span class="lineno"> 2654</span>&#160;    } <span class="keywordflow">else</span> {</div>
-<div class="line"><a name="l02655"></a><span class="lineno"> 2655</span>&#160;      info.clear_webui_url();</div>
-<div class="line"><a name="l02656"></a><span class="lineno"> 2656</span>&#160;    }</div>
-<div class="line"><a name="l02657"></a><span class="lineno"> 2657</span>&#160;</div>
-<div class="line"><a name="l02658"></a><span class="lineno"> 2658</span>&#160;    <span class="keywordflow">if</span> (newInfo.capabilities_size() &gt; 0) {</div>
-<div class="line"><a name="l02659"></a><span class="lineno"> 2659</span>&#160;      info.mutable_capabilities()-&gt;CopyFrom(newInfo.capabilities());</div>
-<div class="line"><a name="l02660"></a><span class="lineno"> 2660</span>&#160;    } <span class="keywordflow">else</span> {</div>
-<div class="line"><a name="l02661"></a><span class="lineno"> 2661</span>&#160;      info.clear_capabilities();</div>
-<div class="line"><a name="l02662"></a><span class="lineno"> 2662</span>&#160;    }</div>
-<div class="line"><a name="l02663"></a><span class="lineno"> 2663</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a4bd6909f50c4594e8db3f4f791814dc7">capabilities</a> = <a class="code" href="structmesos_1_1internal_1_1protobuf_1_1framework_1_1Capabilities.html">protobuf::framework::Capabilities</a>(info.capabilities());</div>
-<div class="line"><a name="l02664"></a><span class="lineno"> 2664</span>&#160;</div>
-<div class="line"><a name="l02665"></a><span class="lineno"> 2665</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_labels()) {</div>
-<div class="line"><a name="l02666"></a><span class="lineno"> 2666</span>&#160;      info.mutable_labels()-&gt;CopyFrom(newInfo.labels());</div>
-<div class="line"><a name="l02667"></a><span class="lineno"> 2667</span>&#160;    } <span class="keywordflow">else</span> {</div>
-<div class="line"><a name="l02668"></a><span class="lineno"> 2668</span>&#160;      info.clear_labels();</div>
-<div class="line"><a name="l02669"></a><span class="lineno"> 2669</span>&#160;    }</div>
-<div class="line"><a name="l02670"></a><span class="lineno"> 2670</span>&#160;</div>
-<div class="line"><a name="l02671"></a><span class="lineno"> 2671</span>&#160;    <span class="keyword">const</span> std::set&lt;std::string&gt;&amp; newRoles = <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5">roles</a>;</div>
-<div class="line"><a name="l02672"></a><span class="lineno"> 2672</span>&#160;</div>
-<div class="line"><a name="l02673"></a><span class="lineno"> 2673</span>&#160;    <span class="keyword">const</span> std::set&lt;std::string&gt; removedRoles = [&amp;]() {</div>
-<div class="line"><a name="l02674"></a><span class="lineno"> 2674</span>&#160;      std::set&lt;std::string&gt; result = oldRoles;</div>
-<div class="line"><a name="l02675"></a><span class="lineno"> 2675</span>&#160;      <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, newRoles) {</div>
-<div class="line"><a name="l02676"></a><span class="lineno"> 2676</span>&#160;        result.erase(role);</div>
-<div class="line"><a name="l02677"></a><span class="lineno"> 2677</span>&#160;      }</div>
-<div class="line"><a name="l02678"></a><span class="lineno"> 2678</span>&#160;      <span class="keywordflow">return</span> result;</div>
-<div class="line"><a name="l02679"></a><span class="lineno"> 2679</span>&#160;    }();</div>
-<div class="line"><a name="l02680"></a><span class="lineno"> 2680</span>&#160;</div>
-<div class="line"><a name="l02681"></a><span class="lineno"> 2681</span>&#160;    <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, removedRoles) {</div>
-<div class="line"><a name="l02682"></a><span class="lineno"> 2682</span>&#160;      <span class="keyword">auto</span> allocatedToRole = [&amp;role](<span class="keyword">const</span> Resource&amp; resource) {</div>
-<div class="line"><a name="l02683"></a><span class="lineno"> 2683</span>&#160;        <span class="keywordflow">return</span> resource.allocation_info().role() == role;</div>
-<div class="line"><a name="l02684"></a><span class="lineno"> 2684</span>&#160;      };</div>
-<div class="line"><a name="l02685"></a><span class="lineno"> 2685</span>&#160;</div>
-<div class="line"><a name="l02686"></a><span class="lineno"> 2686</span>&#160;      <span class="comment">// Stop tracking the framework under this role if there are</span></div>
-<div class="line"><a name="l02687"></a><span class="lineno"> 2687</span>&#160;      <span class="comment">// no longer any resources allocated to it.</span></div>
-<div class="line"><a name="l02688"></a><span class="lineno"> 2688</span>&#160;      <span class="keywordflow">if</span> (<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a35847f2388d25e0cb9b3a9d0a722fbdd">totalUsedResources</a>.<a class="code" href="classmesos_1_1Resources.html#a62ae547c0d24fdfb139549e9b8126fdf">filter</a>(allocatedToRole).<a class="code" href="classmesos_1_1Resources.html#ab46b900ebe62b19390d9a2a82b46eb15">empty</a>()) {</div>
-<div class="line"><a name="l02689"></a><span class="lineno"> 2689</span>&#160;        CHECK(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a965f66810b71a0d2bab683fee1b6a9b6">totalOfferedResources</a>.<a class="code" href="classmesos_1_1Resources.html#a62ae547c0d24fdfb139549e9b8126fdf">filter</a>(allocatedToRole).<a class="code" href="classmesos_1_1Resources.html#ab46b900ebe62b19390d9a2a82b46eb15">empty</a>());</div>
-<div class="line"><a name="l02690"></a><span class="lineno"> 2690</span>&#160;        <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3edaf411ec6e409a3f8b2a77988ef65a">untrackUnderRole</a>(role);</div>
-<div class="line"><a name="l02691"></a><span class="lineno"> 2691</span>&#160;      }</div>
-<div class="line"><a name="l02692"></a><span class="lineno"> 2692</span>&#160;    }</div>
-<div class="line"><a name="l02693"></a><span class="lineno"> 2693</span>&#160;</div>
-<div class="line"><a name="l02694"></a><span class="lineno"> 2694</span>&#160;    <span class="keyword">const</span> std::set&lt;std::string&gt; addedRoles = [&amp;]() {</div>
-<div class="line"><a name="l02695"></a><span class="lineno"> 2695</span>&#160;      std::set&lt;std::string&gt; result = newRoles;</div>
-<div class="line"><a name="l02696"></a><span class="lineno"> 2696</span>&#160;      <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, oldRoles) {</div>
-<div class="line"><a name="l02697"></a><span class="lineno"> 2697</span>&#160;        result.erase(role);</div>
-<div class="line"><a name="l02698"></a><span class="lineno"> 2698</span>&#160;      }</div>
-<div class="line"><a name="l02699"></a><span class="lineno"> 2699</span>&#160;      <span class="keywordflow">return</span> result;</div>
-<div class="line"><a name="l02700"></a><span class="lineno"> 2700</span>&#160;    }();</div>
-<div class="line"><a name="l02701"></a><span class="lineno"> 2701</span>&#160;</div>
-<div class="line"><a name="l02702"></a><span class="lineno"> 2702</span>&#160;    <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, addedRoles) {</div>
-<div class="line"><a name="l02703"></a><span class="lineno"> 2703</span>&#160;      <span class="comment">// NOTE: It&#39;s possible that we&#39;re already tracking this framework</span></div>
-<div class="line"><a name="l02704"></a><span class="lineno"> 2704</span>&#160;      <span class="comment">// under the role because a framework can unsubscribe from a role</span></div>
-<div class="line"><a name="l02705"></a><span class="lineno"> 2705</span>&#160;      <span class="comment">// while it still has resources allocated to the role.</span></div>
-<div class="line"><a name="l02706"></a><span class="lineno"> 2706</span>&#160;      <span class="keywordflow">if</span> (!<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a614fb3ba127133b939e2a733c6ecbf2a">isTrackedUnderRole</a>(role)) {</div>
-<div class="line"><a name="l02707"></a><span class="lineno"> 2707</span>&#160;        <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#afa185682905163563412aa1915e612c8">trackUnderRole</a>(role);</div>
-<div class="line"><a name="l02708"></a><span class="lineno"> 2708</span>&#160;      }</div>
-<div class="line"><a name="l02709"></a><span class="lineno"> 2709</span>&#160;    }</div>
-<div class="line"><a name="l02710"></a><span class="lineno"> 2710</span>&#160;  }</div>
-<div class="line"><a name="l02711"></a><span class="lineno"> 2711</span>&#160;</div>
-<div class="line"><a name="l02712"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#aa21baf526b32c397ea45f103cea5dd15"> 2712</a></span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#aa21baf526b32c397ea45f103cea5dd15">updateConnection</a>(<span class="keyword">const</span> <a class="code" href="structprocess_1_1UPID.html">process::UPID</a>&amp; newPid)</div>
-<div class="line"><a name="l02713"></a><span class="lineno"> 2713</span>&#160;  {</div>
-<div class="line"><a name="l02714"></a><span class="lineno"> 2714</span>&#160;    <span class="comment">// Cleanup the HTTP connnection if this is a downgrade from HTTP</span></div>
-<div class="line"><a name="l02715"></a><span class="lineno"> 2715</span>&#160;    <span class="comment">// to PID. Note that the connection may already be closed.</span></div>
-<div class="line"><a name="l02716"></a><span class="lineno"> 2716</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a>.isSome()) {</div>
-<div class="line"><a name="l02717"></a><span class="lineno"> 2717</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a54362f290514769903a61d7cd0d6506b">closeHttpConnection</a>();</div>
-<div class="line"><a name="l02718"></a><span class="lineno"> 2718</span>&#160;    }</div>
-<div class="line"><a name="l02719"></a><span class="lineno"> 2719</span>&#160;</div>
-<div class="line"><a name="l02720"></a><span class="lineno"> 2720</span>&#160;    <span class="comment">// TODO(benh): unlink(oldPid);</span></div>
-<div class="line"><a name="l02721"></a><span class="lineno"> 2721</span>&#160;    pid = newPid;</div>
-<div class="line"><a name="l02722"></a><span class="lineno"> 2722</span>&#160;  }</div>
-<div class="line"><a name="l02723"></a><span class="lineno"> 2723</span>&#160;</div>
-<div class="line"><a name="l02724"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#aab28c60e6ecfa298c41f4e006f73a911"> 2724</a></span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#aab28c60e6ecfa298c41f4e006f73a911">updateConnection</a>(<span class="keyword">const</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1HttpConnection.html">HttpConnection</a>&amp; newHttp)</div>
-<div class="line"><a name="l02725"></a><span class="lineno"> 2725</span>&#160;  {</div>
-<div class="line"><a name="l02726"></a><span class="lineno"> 2726</span>&#160;    <span class="keywordflow">if</span> (pid.isSome()) {</div>
-<div class="line"><a name="l02727"></a><span class="lineno"> 2727</span>&#160;      <span class="comment">// Wipe the PID if this is an upgrade from PID to HTTP.</span></div>
-<div class="line"><a name="l02728"></a><span class="lineno"> 2728</span>&#160;      <span class="comment">// TODO(benh): unlink(oldPid);</span></div>
-<div class="line"><a name="l02729"></a><span class="lineno"> 2729</span>&#160;      pid = <a class="code" href="structNone.html">None</a>();</div>
-<div class="line"><a name="l02730"></a><span class="lineno"> 2730</span>&#160;    } <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a>.isSome()) {</div>
-<div class="line"><a name="l02731"></a><span class="lineno"> 2731</span>&#160;      <span class="comment">// Cleanup the old HTTP connection.</span></div>
-<div class="line"><a name="l02732"></a><span class="lineno"> 2732</span>&#160;      <span class="comment">// Note that master creates a new HTTP connection for every</span></div>
-<div class="line"><a name="l02733"></a><span class="lineno"> 2733</span>&#160;      <span class="comment">// subscribe request, so &#39;newHttp&#39; should always be different</span></div>
-<div class="line"><a name="l02734"></a><span class="lineno"> 2734</span>&#160;      <span class="comment">// from &#39;http&#39;.</span></div>
-<div class="line"><a name="l02735"></a><span class="lineno"> 2735</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a54362f290514769903a61d7cd0d6506b">closeHttpConnection</a>();</div>
-<div class="line"><a name="l02736"></a><span class="lineno"> 2736</span>&#160;    }</div>
-<div class="line"><a name="l02737"></a><span class="lineno"> 2737</span>&#160;</div>
-<div class="line"><a name="l02738"></a><span class="lineno"> 2738</span>&#160;    <a class="code" href="stout_2include_2stout_2check_8hpp.html#ab8738e43a60086f3b434c0278933e85e">CHECK_NONE</a>(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a>);</div>
-<div class="line"><a name="l02739"></a><span class="lineno"> 2739</span>&#160;</div>
-<div class="line"><a name="l02740"></a><span class="lineno"> 2740</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a> = newHttp;</div>
-<div class="line"><a name="l02741"></a><span class="lineno"> 2741</span>&#160;  }</div>
-<div class="line"><a name="l02742"></a><span class="lineno"> 2742</span>&#160;</div>
-<div class="line"><a name="l02743"></a><span class="lineno"> 2743</span>&#160;  <span class="comment">// Closes the HTTP connection and stops the heartbeat.</span></div>
-<div class="line"><a name="l02744"></a><span class="lineno"> 2744</span>&#160;  <span class="comment">//</span></div>
-<div class="line"><a name="l02745"></a><span class="lineno"> 2745</span>&#160;  <span class="comment">// TODO(vinod): Currently `state` variable is set separately</span></div>
-<div class="line"><a name="l02746"></a><span class="lineno"> 2746</span>&#160;  <span class="comment">// from this method. We need to make sure these are in sync.</span></div>
-<div class="line"><a name="l02747"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a54362f290514769903a61d7cd0d6506b"> 2747</a></span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a54362f290514769903a61d7cd0d6506b">closeHttpConnection</a>()</div>
-<div class="line"><a name="l02748"></a><span class="lineno"> 2748</span>&#160;  {</div>
-<div class="line"><a name="l02749"></a><span class="lineno"> 2749</span>&#160;    <a class="code" href="stout_2include_2stout_2check_8hpp.html#aee320e7c6e107071f4b85d4cc135a265">CHECK_SOME</a>(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a>);</div>
-<div class="line"><a name="l02750"></a><span class="lineno"> 2750</span>&#160;</div>
-<div class="line"><a name="l02751"></a><span class="lineno"> 2751</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab741aebff99e28269136e04ab76800fa">connected</a>() &amp;&amp; !<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a>.get().close()) {</div>
-<div class="line"><a name="l02752"></a><span class="lineno"> 2752</span>&#160;      LOG(WARNING) &lt;&lt; <span class="stringliteral">&quot;Failed to close HTTP pipe for &quot;</span> &lt;&lt; *<span class="keyword">this</span>;</div>
-<div class="line"><a name="l02753"></a><span class="lineno"> 2753</span>&#160;    }</div>
-<div class="line"><a name="l02754"></a><span class="lineno"> 2754</span>&#160;</div>
-<div class="line"><a name="l02755"></a><span class="lineno"> 2755</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a> = <a class="code" href="structNone.html">None</a>();</div>
-<div class="line"><a name="l02756"></a><span class="lineno"> 2756</span>&#160;</div>
-<div class="line"><a name="l02757"></a><span class="lineno"> 2757</span>&#160;    <a class="code" href="stout_2include_2stout_2check_8hpp.html#aee320e7c6e107071f4b85d4cc135a265">CHECK_SOME</a>(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70">heartbeater</a>);</div>
-<div class="line"><a name="l02758"></a><span class="lineno"> 2758</span>&#160;</div>
-<div class="line"><a name="l02759"></a><span class="lineno"> 2759</span>&#160;    <a class="code" href="namespaceprocess.html#a20443908afa3212215166e26065349e5">terminate</a>(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70">heartbeater</a>.get().get());</div>
-<div class="line"><a name="l02760"></a><span class="lineno"> 2760</span>&#160;    <a class="code" href="namespaceprocess.html#a07833fb41a8b0c1f18fa5485ca8c18d4">wait</a>(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70">heartbeater</a>.get().get());</div>
-<div class="line"><a name="l02761"></a><span class="lineno"> 2761</span>&#160;</div>
-<div class="line"><a name="l02762"></a><span class="lineno"> 2762</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70">heartbeater</a> = <a class="code" href="structNone.html">None</a>();</div>
-<div class="line"><a name="l02763"></a><span class="lineno"> 2763</span>&#160;  }</div>
-<div class="line"><a name="l02764"></a><span class="lineno"> 2764</span>&#160;</div>
-<div class="line"><a name="l02765"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab307cdcfe7dbfca8894b12097759bb41"> 2765</a></span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab307cdcfe7dbfca8894b12097759bb41">heartbeat</a>()</div>
-<div class="line"><a name="l02766"></a><span class="lineno"> 2766</span>&#160;  {</div>
-<div class="line"><a name="l02767"></a><span class="lineno"> 2767</span>&#160;    <a class="code" href="stout_2include_2stout_2check_8hpp.html#ab8738e43a60086f3b434c0278933e85e">CHECK_NONE</a>(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70">heartbeater</a>);</div>
-<div class="line"><a name="l02768"></a><span class="lineno"> 2768</span>&#160;    <a class="code" href="stout_2include_2stout_2check_8hpp.html#aee320e7c6e107071f4b85d4cc135a265">CHECK_SOME</a>(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a>);</div>
-<div class="line"><a name="l02769"></a><span class="lineno"> 2769</span>&#160;</div>
-<div class="line"><a name="l02770"></a><span class="lineno"> 2770</span>&#160;    <span class="comment">// TODO(vinod): Make heartbeat interval configurable and include</span></div>
-<div class="line"><a name="l02771"></a><span class="lineno"> 2771</span>&#160;    <span class="comment">// this information in the SUBSCRIBED response.</span></div>
-<div class="line"><a name="l02772"></a><span class="lineno"> 2772</span>&#160;    <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1v1_1_1scheduler.html#acd3fa8addac36f513726743665631d79">scheduler::Event</a> event;</div>
-<div class="line"><a name="l02773"></a><span class="lineno"> 2773</span>&#160;    <span class="keyword">event</span>.set_type(scheduler::Event::HEARTBEAT);</div>
-<div class="line"><a name="l02774"></a><span class="lineno"> 2774</span>&#160;</div>
-<div class="line"><a name="l02775"></a><span class="lineno"> 2775</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70">heartbeater</a> =</div>
-<div class="line"><a name="l02776"></a><span class="lineno"> 2776</span>&#160;      <span class="keyword">new</span> <a class="code" href="classmesos_1_1internal_1_1master_1_1Heartbeater.html">Heartbeater&lt;scheduler::Event, v1::scheduler::Event&gt;</a>(</div>
-<div class="line"><a name="l02777"></a><span class="lineno"> 2777</span>&#160;          <span class="stringliteral">&quot;framework &quot;</span> + <a class="code" href="namespacens.html#a28116b46e6543597a11733424cd1aa20">stringify</a>(info.id()),</div>
-<div class="line"><a name="l02778"></a><span class="lineno"> 2778</span>&#160;          event,</div>
-<div class="line"><a name="l02779"></a><span class="lineno"> 2779</span>&#160;          <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a>.get(),</div>
-<div class="line"><a name="l02780"></a><span class="lineno"> 2780</span>&#160;          <a class="code" href="namespacemesos_1_1internal_1_1master.html#a241384d7256ec21bea9b9e9cba24f766">DEFAULT_HEARTBEAT_INTERVAL</a>);</div>
-<div class="line"><a name="l02781"></a><span class="lineno"> 2781</span>&#160;</div>
-<div class="line"><a name="l02782"></a><span class="lineno"> 2782</span>&#160;    <a class="code" href="namespaceprocess.html#aff22904a83567125d3b4d0d88e5a2270">process::spawn</a>(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70">heartbeater</a>.get().get());</div>
-<div class="line"><a name="l02783"></a><span class="lineno"> 2783</span>&#160;  }</div>
-<div class="line"><a name="l02784"></a><span class="lineno"> 2784</span>&#160;</div>
-<div class="line"><a name="l02785"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#acfcf3cedb8bf9ab2a0d76ca9026dc50a"> 2785</a></span>&#160;  <span class="keywordtype">bool</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#acfcf3cedb8bf9ab2a0d76ca9026dc50a">active</a>()<span class="keyword"> const    </span>{ <span class="keywordflow">return</span> state == <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a96a90d8ae734d729489ba877367e6b65a6228d0b8755323f0a5d2cf44863226d5">ACTIVE</a>; }</div>
-<div class="line"><a name="l02786"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab741aebff99e28269136e04ab76800fa"> 2786</a></span>&#160;  <span class="keywordtype">bool</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab741aebff99e28269136e04ab76800fa">connected</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> state == <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a96a90d8ae734d729489ba877367e6b65a6228d0b8755323f0a5d2cf44863226d5">ACTIVE</a> || state == <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a96a90d8ae734d729489ba877367e6b65a9564d46b6ef0e132e3856ac29e22b065">INACTIVE</a>; }</div>
-<div class="line"><a name="l02787"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab5285e7b6a2266d1d12167d1a9f561d2"> 2787</a></span>&#160;  <span class="keywordtype">bool</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab5285e7b6a2266d1d12167d1a9f561d2">recovered</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> state == <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a96a90d8ae734d729489ba877367e6b65a2781c7e12fec2c505d95224df19bbea4">RECOVERED</a>; }</div>
-<div class="line"><a name="l02788"></a><span class="lineno"> 2788</span>&#160;</div>
-<div class="line"><a name="l02789"></a><span class="lineno"> 2789</span>&#160;  <span class="keywordtype">bool</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a614fb3ba127133b939e2a733c6ecbf2a">isTrackedUnderRole</a>(<span class="keyword">const</span> std::string&amp; role) <span class="keyword">const</span>;</div>
-<div class="line"><a name="l02790"></a><span class="lineno"> 2790</span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#afa185682905163563412aa1915e612c8">trackUnderRole</a>(<span class="keyword">const</span> std::string&amp; role);</div>
-<div class="line"><a name="l02791"></a><span class="lineno"> 2791</span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3edaf411ec6e409a3f8b2a77988ef65a">untrackUnderRole</a>(<span class="keyword">const</span> std::string&amp; role);</div>
-<div class="line"><a name="l02792"></a><span class="lineno"> 2792</span>&#160;</div>
-<div class="line"><a name="l02793"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3b912abb827bb20ef35d46b2388ae1f0"> 2793</a></span>&#160;  <a class="code" href="classmesos_1_1internal_1_1master_1_1Master.html">Master</a>* <span class="keyword">const</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3b912abb827bb20ef35d46b2388ae1f0">master</a>;</div>
-<div class="line"><a name="l02794"></a><span class="lineno"> 2794</span>&#160;</div>
-<div class="line"><a name="l02795"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#aaa84eaf9694ad355fdb76ff15818b295"> 2795</a></span>&#160;  FrameworkInfo <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#aaa84eaf9694ad355fdb76ff15818b295">info</a>;</div>
-<div class="line"><a name="l02796"></a><span class="lineno"> 2796</span>&#160;</div>
-<div class="line"><a name="l02797"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5"> 2797</a></span>&#160;  std::set&lt;std::string&gt; <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5">roles</a>;</div>
-<div class="line"><a name="l02798"></a><span class="lineno"> 2798</span>&#160;</div>
-<div class="line"><a name="l02799"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a4bd6909f50c4594e8db3f4f791814dc7"> 2799</a></span>&#160;  <a class="code" href="structmesos_1_1internal_1_1protobuf_1_1framework_1_1Capabilities.html">protobuf::framework::Capabilities</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a4bd6909f50c4594e8db3f4f791814dc7">capabilities</a>;</div>
-<div class="line"><a name="l02800"></a><span class="lineno"> 2800</span>&#160;</div>
-<div class="line"><a name="l02801"></a><span class="lineno"> 2801</span>&#160;  <span class="comment">// Frameworks can either be connected via HTTP or by message passing</span></div>
-<div class="line"><a name="l02802"></a><span class="lineno"> 2802</span>&#160;  <span class="comment">// (scheduler driver). At most one of `http` and `pid` will be set</span></div>
-<div class="line"><a name="l02803"></a><span class="lineno"> 2803</span>&#160;  <span class="comment">// according to the last connection made by the framework; neither</span></div>
-<div class="line"><a name="l02804"></a><span class="lineno"> 2804</span>&#160;  <span class="comment">// field will be set if the framework is in state `RECOVERED`.</span></div>
-<div class="line"><a name="l02805"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c"> 2805</a></span>&#160;  <a class="code" href="classOption.html">Option&lt;HttpConnection&gt;</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a>;</div>
-<div class="line"><a name="l02806"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#acccaa7a1d26e66b6c1d3d6de4b1897e0"> 2806</a></span>&#160;  <a class="code" href="classOption.html">Option&lt;process::UPID&gt;</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#acccaa7a1d26e66b6c1d3d6de4b1897e0">pid</a>;</div>
-<div class="line"><a name="l02807"></a><span class="lineno"> 2807</span>&#160;</div>
-<div class="line"><a name="l02808"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#af4322f8c99cfc37c386d3b5457a6f053"> 2808</a></span>&#160;  <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a96a90d8ae734d729489ba877367e6b65">State</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#af4322f8c99cfc37c386d3b5457a6f053">state</a>;</div>
-<div class="line"><a name="l02809"></a><span class="lineno"> 2809</span>&#160;</div>
-<div class="line"><a name="l02810"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a0e09e14adf247dd3326bfd3dc09c6c7b"> 2810</a></span>&#160;  <a class="code" href="classprocess_1_1Time.html">process::Time</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a0e09e14adf247dd3326bfd3dc09c6c7b">registeredTime</a>;</div>
-<div class="line"><a name="l02811"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a0883625e8cc8fc902b5957d12e63f9a1"> 2811</a></span>&#160;  <a class="code" href="classprocess_1_1Time.html">process::Time</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a0883625e8cc8fc902b5957d12e63f9a1">reregisteredTime</a>;</div>
-<div class="line"><a name="l02812"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac1cc9915f69092137574206fe15e571c"> 2812</a></span>&#160;  <a class="code" href="classprocess_1_1Time.html">process::Time</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac1cc9915f69092137574206fe15e571c">unregisteredTime</a>;</div>
-<div class="line"><a name="l02813"></a><span class="lineno"> 2813</span>&#160;</div>
-<div class="line"><a name="l02814"></a><span class="lineno"> 2814</span>&#160;  <span class="comment">// Tasks that have not yet been launched because they are currently</span></div>
-<div class="line"><a name="l02815"></a><span class="lineno"> 2815</span>&#160;  <span class="comment">// being authorized.</span></div>
-<div class="line"><a name="l02816"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a146261f2447bec7776ebd06a80178d09"> 2816</a></span>&#160;  <a class="code" href="classhashmap.html">hashmap&lt;TaskID, TaskInfo&gt;</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a146261f2447bec7776ebd06a80178d09">pendingTasks</a>;</div>
-<div class="line"><a name="l02817"></a><span class="lineno"> 2817</span>&#160;</div>
-<div class="line"><a name="l02818"></a><span class="lineno"> 2818</span>&#160;  <span class="comment">// TODO(bmahler): Make this private to enforce that `addTask()` and</span></div>
-<div class="line"><a name="l02819"></a><span class="lineno"> 2819</span>&#160;  <span class="comment">// `removeTask()` are used, and provide a const view into the tasks.</span></div>
-<div class="line"><a name="l02820"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#af54ac5eba8a7026cb92968fb6c6efd8a"> 2820</a></span>&#160;  <a class="code" href="classhashmap.html">hashmap&lt;TaskID, Task*&gt;</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#af54ac5eba8a7026cb92968fb6c6efd8a">tasks</a>;</div>
-<div class="line"><a name="l02821"></a><span class="lineno"> 2821</span>&#160;</div>
-<div class="line"><a name="l02822"></a><span class="lineno"> 2822</span>&#160;  <span class="comment">// Tasks launched by this framework that have reached a terminal</span></div>
-<div class="line"><a name="l02823"></a><span class="lineno"> 2823</span>&#160;  <span class="comment">// state and have had all their updates acknowledged. We only keep a</span></div>
-<div class="line"><a name="l02824"></a><span class="lineno"> 2824</span>&#160;  <span class="comment">// fixed-size cache to avoid consuming too much memory. We use</span></div>
-<div class="line"><a name="l02825"></a><span class="lineno"> 2825</span>&#160;  <span class="comment">// boost::circular_buffer rather than BoundedHashMap because there</span></div>
-<div class="line"><a name="l02826"></a><span class="lineno"> 2826</span>&#160;  <span class="comment">// can be multiple completed tasks with the same task ID.</span></div>
-<div class="line"><a name="l02827"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a24bbb82d27e409d2f48ed01fbf2619f1"> 2827</a></span>&#160;  boost::circular_buffer&lt;process::Owned&lt;Task&gt;&gt; <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a24bbb82d27e409d2f48ed01fbf2619f1">completedTasks</a>;</div>
-<div class="line"><a name="l02828"></a><span class="lineno"> 2828</span>&#160;</div>
-<div class="line"><a name="l02829"></a><span class="lineno"> 2829</span>&#160;  <span class="comment">// When an agent is marked unreachable, tasks running on it are stored</span></div>
-<div class="line"><a name="l02830"></a><span class="lineno"> 2830</span>&#160;  <span class="comment">// here. We only keep a fixed-size cache to avoid consuming too much memory.</span></div>
-<div class="line"><a name="l02831"></a><span class="lineno"> 2831</span>&#160;  <span class="comment">// NOTE: Non-partition-aware unreachable tasks in this map are marked</span></div>
-<div class="line"><a name="l02832"></a><span class="lineno"> 2832</span>&#160;  <span class="comment">// TASK_LOST instead of TASK_UNREACHABLE for backward compatibility.</span></div>
-<div class="line"><a name="l02833"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9db50e71935c3f9ac83ba47e18c700f8"> 2833</a></span>&#160;  <a class="code" href="classBoundedHashMap.html">BoundedHashMap&lt;TaskID, process::Owned&lt;Task&gt;</a>&gt; <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9db50e71935c3f9ac83ba47e18c700f8">unreachableTasks</a>;</div>
-<div class="line"><a name="l02834"></a><span class="lineno"> 2834</span>&#160;</div>
-<div class="line"><a name="l02835"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a6fe60c0c1a491ac16776bad1598da52e"> 2835</a></span>&#160;  <a class="code" href="classhashset.html">hashset&lt;Offer*&gt;</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a6fe60c0c1a491ac16776bad1598da52e">offers</a>; <span class="comment">// Active offers for framework.</span></div>
-<div class="line"><a name="l02836"></a><span class="lineno"> 2836</span>&#160;</div>
-<div class="line"><a name="l02837"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a53c59b3da6fae1d939e4ef662b1db164"> 2837</a></span>&#160;  <a class="code" href="classhashset.html">hashset&lt;InverseOffer*&gt;</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a53c59b3da6fae1d939e4ef662b1db164">inverseOffers</a>; <span class="comment">// Active inverse offers for framework.</span></div>
-<div class="line"><a name="l02838"></a><span class="lineno"> 2838</span>&#160;</div>
-<div class="line"><a name="l02839"></a><span class="lineno"> 2839</span>&#160;  <span class="comment">// TODO(bmahler): Make this private to enforce that `addExecutor()`</span></div>
-<div class="line"><a name="l02840"></a><span class="lineno"> 2840</span>&#160;  <span class="comment">// and `removeExecutor()` are used, and provide a const view into</span></div>
-<div class="line"><a name="l02841"></a><span class="lineno"> 2841</span>&#160;  <span class="comment">// the executors.</span></div>
-<div class="line"><a name="l02842"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a1e784cda7e5c31ad19ec72b6a7b6fdee"> 2842</a></span>&#160;  <a class="code" href="classhashmap.html">hashmap&lt;SlaveID, hashmap&lt;ExecutorID, ExecutorInfo&gt;</a>&gt; <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a1e784cda7e5c31ad19ec72b6a7b6fdee">executors</a>;</div>
-<div class="line"><a name="l02843"></a><span class="lineno"> 2843</span>&#160;</div>
-<div class="line"><a name="l02844"></a><span class="lineno"> 2844</span>&#160;  <span class="comment">// Pending operations or terminal operations that have</span></div>
-<div class="line"><a name="l02845"></a><span class="lineno"> 2845</span>&#160;  <span class="comment">// unacknowledged status updates.</span></div>
-<div class="line"><a name="l02846"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a650e493bb396d724446d9571e5842901"> 2846</a></span>&#160;  <a class="code" href="classhashmap.html">hashmap&lt;UUID, OfferOperation*&gt;</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a650e493bb396d724446d9571e5842901">offerOperations</a>;</div>
-<div class="line"><a name="l02847"></a><span class="lineno"> 2847</span>&#160;</div>
-<div class="line"><a name="l02848"></a><span class="lineno"> 2848</span>&#160;  <span class="comment">// The map from the framework-specified operation ID to the</span></div>
-<div class="line"><a name="l02849"></a><span class="lineno"> 2849</span>&#160;  <span class="comment">// corresponding internal operation UUID.</span></div>
-<div class="line"><a name="l02850"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a4d211f2b6fca34349126f16bc2cef3e0"> 2850</a></span>&#160;  <a class="code" href="classhashmap.html">hashmap&lt;OfferOperationID, UUID&gt;</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a4d211f2b6fca34349126f16bc2cef3e0">offerOperationUUIDs</a>;</div>
-<div class="line"><a name="l02851"></a><span class="lineno"> 2851</span>&#160;</div>
-<div class="line"><a name="l02852"></a><span class="lineno"> 2852</span>&#160;  <span class="comment">// NOTE: For the used and offered resources below, we keep the</span></div>
-<div class="line"><a name="l02853"></a><span class="lineno"> 2853</span>&#160;  <span class="comment">// total as well as partitioned by SlaveID.</span></div>
-<div class="line"><a name="l02854"></a><span class="lineno"> 2854</span>&#160;  <span class="comment">// We expose the total resources via the HTTP endpoint, and we</span></div>
-<div class="line"><a name="l02855"></a><span class="lineno"> 2855</span>&#160;  <span class="comment">// keep a running total of the resources because looping over the</span></div>
-<div class="line"><a name="l02856"></a><span class="lineno"> 2856</span>&#160;  <span class="comment">// slaves to sum the resources has led to perf issues (MESOS-1862).</span></div>
-<div class="line"><a name="l02857"></a><span class="lineno"> 2857</span>&#160;  <span class="comment">// We keep the resources partitioned by SlaveID because non-scalar</span></div>
-<div class="line"><a name="l02858"></a><span class="lineno"> 2858</span>&#160;  <span class="comment">// resources can be lost when summing them up across multiple</span></div>
-<div class="line"><a name="l02859"></a><span class="lineno"> 2859</span>&#160;  <span class="comment">// slaves (MESOS-2373).</span></div>
-<div class="line"><a name="l02860"></a><span class="lineno"> 2860</span>&#160;  <span class="comment">//</span></div>
-<div class="line"><a name="l02861"></a><span class="lineno"> 2861</span>&#160;  <span class="comment">// Also note that keeping the totals is safe even though it yields</span></div>
-<div class="line"><a name="l02862"></a><span class="lineno"> 2862</span>&#160;  <span class="comment">// incorrect results for non-scalar resources.</span></div>
-<div class="line"><a name="l02863"></a><span class="lineno"> 2863</span>&#160;  <span class="comment">//   (1) For overlapping set items / ranges across slaves, these</span></div>
-<div class="line"><a name="l02864"></a><span class="lineno"> 2864</span>&#160;  <span class="comment">//       will get added N times but only represented once.</span></div>
-<div class="line"><a name="l02865"></a><span class="lineno"> 2865</span>&#160;  <span class="comment">//   (2) When an initial subtraction occurs (N-1), the resource is</span></div>
-<div class="line"><a name="l02866"></a><span class="lineno"> 2866</span>&#160;  <span class="comment">//       no longer represented. (This is the source of the bug).</span></div>
-<div class="line"><a name="l02867"></a><span class="lineno"> 2867</span>&#160;  <span class="comment">//   (3) When any further subtractions occur (N-(1+M)), the</span></div>
-<div class="line"><a name="l02868"></a><span class="lineno"> 2868</span>&#160;  <span class="comment">//       Resources simply ignores the subtraction since there&#39;s</span></div>
-<div class="line"><a name="l02869"></a><span class="lineno"> 2869</span>&#160;  <span class="comment">//       nothing to remove, so this is safe for now.</span></div>
-<div class="line"><a name="l02870"></a><span class="lineno"> 2870</span>&#160;</div>
-<div class="line"><a name="l02871"></a><span class="lineno"> 2871</span>&#160;  <span class="comment">// TODO(mpark): Strip the non-scalar resources out of the totals</span></div>
-<div class="line"><a name="l02872"></a><span class="lineno"> 2872</span>&#160;  <span class="comment">// in order to avoid reporting incorrect statistics (MESOS-2623).</span></div>
-<div class="line"><a name="l02873"></a><span class="lineno"> 2873</span>&#160;</div>
-<div class="line"><a name="l02874"></a><span class="lineno"> 2874</span>&#160;  <span class="comment">// Active task / executor / offer operation resources.</span></div>
-<div class="line"><a name="l02875"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a35847f2388d25e0cb9b3a9d0a722fbdd"> 2875</a></span>&#160;  <a class="code" href="classmesos_1_1Resources.html">Resources</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a35847f2388d25e0cb9b3a9d0a722fbdd">totalUsedResources</a>;</div>
-<div class="line"><a name="l02876"></a><span class="lineno"> 2876</span>&#160;</div>
-<div class="line"><a name="l02877"></a><span class="lineno"> 2877</span>&#160;  <span class="comment">// Note that we maintain multiple copies of each shared resource in</span></div>
-<div class="line"><a name="l02878"></a><span class="lineno"> 2878</span>&#160;  <span class="comment">// `usedResources` as they are used by multiple tasks.</span></div>
-<div class="line"><a name="l02879"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9085d3f2c156a7772cbd243776a62491"> 2879</a></span>&#160;  <a class="code" href="classhashmap.html">hashmap&lt;SlaveID, Resources&gt;</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9085d3f2c156a7772cbd243776a62491">usedResources</a>;</div>
-<div class="line"><a name="l02880"></a><span class="lineno"> 2880</span>&#160;</div>
-<div class="line"><a name="l02881"></a><span class="lineno"> 2881</span>&#160;  <span class="comment">// Offered resources.</span></div>
-<div class="line"><a name="l02882"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a965f66810b71a0d2bab683fee1b6a9b6"> 2882</a></span>&#160;  <a class="code" href="classmesos_1_1Resources.html">Resources</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a965f66810b71a0d2bab683fee1b6a9b6">totalOfferedResources</a>;</div>
-<div class="line"><a name="l02883"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac11f863cb7ccbc451d099fe77989cfce"> 2883</a></span>&#160;  <a class="code" href="classhashmap.html">hashmap&lt;SlaveID, Resources&gt;</a> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac11f863cb7ccbc451d099fe77989cfce">offeredResources</a>;</div>
-<div class="line"><a name="l02884"></a><span class="lineno"> 2884</span>&#160;</div>
-<div class="line"><a name="l02885"></a><span class="lineno"> 2885</span>&#160;  <span class="comment">// This is only set for HTTP frameworks.</span></div>
-<div class="line"><a name="l02886"></a><span class="lineno"> 2886</span>&#160;  <a class="code" href="classOption.html">Option&lt;process::Owned&lt;Heartbeater&lt;scheduler::Event, v1::scheduler::Event&gt;</a>&gt;&gt;</div>
-<div class="line"><a name="l02887"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70"> 2887</a></span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70">heartbeater</a>;</div>
-<div class="line"><a name="l02888"></a><span class="lineno"> 2888</span>&#160;</div>
-<div class="line"><a name="l02889"></a><span class="lineno"> 2889</span>&#160;<span class="keyword">private</span>:</div>
-<div class="line"><a name="l02890"></a><span class="lineno"> 2890</span>&#160;  <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a5ca92e3fadf6870a101d9bb811d4c3a5">Framework</a>(<a class="code" href="classmesos_1_1internal_1_1master_1_1Master.html">Master</a>* <span class="keyword">const</span> _master,</div>
-<div class="line"><a name="l02891"></a><span class="lineno"> 2891</span>&#160;            <span class="keyword">const</span> <a class="code" href="classmesos_1_1internal_1_1master_1_1Flags.html">Flags</a>&amp; masterFlags,</div>
-<div class="line"><a name="l02892"></a><span class="lineno"> 2892</span>&#160;            <span class="keyword">const</span> FrameworkInfo&amp; _info,</div>
-<div class="line"><a name="l02893"></a><span class="lineno"> 2893</span>&#160;            <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a96a90d8ae734d729489ba877367e6b65">State</a> state,</div>
-<div class="line"><a name="l02894"></a><span class="lineno"> 2894</span>&#160;            <span class="keyword">const</span> <a class="code" href="classprocess_1_1Time.html">process::Time</a>&amp; <a class="code" href="namespacecgroups_1_1blkio_1_1cfq.html#abe4d7d69fdf7ca70fb30c6cd34a953e4">time</a>)</div>
-<div class="line"><a name="l02895"></a><span class="lineno"> 2895</span>&#160;    : master(_master),</div>
-<div class="line"><a name="l02896"></a><span class="lineno"> 2896</span>&#160;      info(_info),</div>
-<div class="line"><a name="l02897"></a><span class="lineno"> 2897</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5">roles</a>(<a class="code" href="namespaceJSON.html#a93c179a1a5bd4164169d47cb1803f2a6">protobuf</a>::framework::<a class="code" href="namespacemesos_1_1internal_1_1protobuf_1_1framework.html#a34d007aecebcd1c9dbd3ee0ad1d39155">getRoles</a>(_info)),</div>
-<div class="line"><a name="l02898"></a><span class="lineno"> 2898</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a4bd6909f50c4594e8db3f4f791814dc7">capabilities</a>(_info.<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a4bd6909f50c4594e8db3f4f791814dc7">capabilities</a>()),</div>
-<div class="line"><a name="l02899"></a><span class="lineno"> 2899</span>&#160;      state(state),</div>
-<div class="line"><a name="l02900"></a><span class="lineno"> 2900</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a0e09e14adf247dd3326bfd3dc09c6c7b">registeredTime</a>(time),</div>
-<div class="line"><a name="l02901"></a><span class="lineno"> 2901</span>&#160;      reregisteredTime(time),</div>
-<div class="line"><a name="l02902"></a><span class="lineno"> 2902</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a24bbb82d27e409d2f48ed01fbf2619f1">completedTasks</a>(masterFlags.max_completed_tasks_per_framework),</div>
-<div class="line"><a name="l02903"></a><span class="lineno"> 2903</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9db50e71935c3f9ac83ba47e18c700f8">unreachableTasks</a>(masterFlags.max_unreachable_tasks_per_framework)</div>
-<div class="line"><a name="l02904"></a><span class="lineno"> 2904</span>&#160;  {</div>
-<div class="line"><a name="l02905"></a><span class="lineno"> 2905</span>&#160;    <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5">roles</a>) {</div>
-<div class="line"><a name="l02906"></a><span class="lineno"> 2906</span>&#160;      <span class="comment">// NOTE: It&#39;s possible that we&#39;re already being tracked under the role</span></div>
-<div class="line"><a name="l02907"></a><span class="lineno"> 2907</span>&#160;      <span class="comment">// because a framework can unsubscribe from a role while it still has</span></div>
-<div class="line"><a name="l02908"></a><span class="lineno"> 2908</span>&#160;      <span class="comment">// resources allocated to the role.</span></div>
-<div class="line"><a name="l02909"></a><span class="lineno"> 2909</span>&#160;      <span class="keywordflow">if</span> (!<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a614fb3ba127133b939e2a733c6ecbf2a">isTrackedUnderRole</a>(role)) {</div>
-<div class="line"><a name="l02910"></a><span class="lineno"> 2910</span>&#160;        <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#afa185682905163563412aa1915e612c8">trackUnderRole</a>(role);</div>
-<div class="line"><a name="l02911"></a><span class="lineno"> 2911</span>&#160;      }</div>
-<div class="line"><a name="l02912"></a><span class="lineno"> 2912</span>&#160;    }</div>
-<div class="line"><a name="l02913"></a><span class="lineno"> 2913</span>&#160;  }</div>
-<div class="line"><a name="l02914"></a><span class="lineno"> 2914</span>&#160;</div>
-<div class="line"><a name="l02915"></a><span class="lineno"> 2915</span>&#160;  <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a5ca92e3fadf6870a101d9bb811d4c3a5">Framework</a>(<span class="keyword">const</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html">Framework</a>&amp;);              <span class="comment">// No copying.</span></div>
-<div class="line"><a name="l02916"></a><span class="lineno"> 2916</span>&#160;  <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html">Framework</a>&amp; operator=(<span class="keyword">const</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html">Framework</a>&amp;); <span class="comment">// No assigning.</span></div>
-<div class="line"><a name="l02917"></a><span class="lineno"> 2917</span>&#160;};</div>
+<div class="line"><a name="l02556"></a><span class="lineno"> 2556</span>&#160;    <span class="comment">// If we are no longer subscribed to the role to which these</span></div>
+<div class="line"><a name="l02557"></a><span class="lineno"> 2557</span>&#160;    <span class="comment">// resources are being returned to, and we have no more resources</span></div>
+<div class="line"><a name="l02558"></a><span class="lineno"> 2558</span>&#160;    <span class="comment">// allocated to us for that role, stop tracking the framework</span></div>
+<div class="line"><a name="l02559"></a><span class="lineno"> 2559</span>&#160;    <span class="comment">// under the role.</span></div>
+<div class="line"><a name="l02560"></a><span class="lineno"> 2560</span>&#160;    <a class="code" href="foreach_8hpp.html#acac417231a256d7c6164a86db970da86">foreachkey</a> (<span class="keyword">const</span> std::string&amp; role, consumed-&gt;allocations()) {</div>
+<div class="line"><a name="l02561"></a><span class="lineno"> 2561</span>&#160;      <span class="keyword">auto</span> allocatedToRole = [&amp;role](<span class="keyword">const</span> Resource&amp; resource) {</div>
+<div class="line"><a name="l02562"></a><span class="lineno"> 2562</span>&#160;        <span class="keywordflow">return</span> resource.allocation_info().role() == role;</div>
+<div class="line"><a name="l02563"></a><span class="lineno"> 2563</span>&#160;      };</div>
+<div class="line"><a name="l02564"></a><span class="lineno"> 2564</span>&#160;</div>
+<div class="line"><a name="l02565"></a><span class="lineno"> 2565</span>&#160;      <span class="keywordflow">if</span> (<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5">roles</a>.count(role) == 0 &amp;&amp;</div>
+<div class="line"><a name="l02566"></a><span class="lineno"> 2566</span>&#160;          <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a35847f2388d25e0cb9b3a9d0a722fbdd">totalUsedResources</a>.<a class="code" href="classmesos_1_1Resources.html#a62ae547c0d24fdfb139549e9b8126fdf">filter</a>(allocatedToRole).<a class="code" href="classmesos_1_1Resources.html#ab46b900ebe62b19390d9a2a82b46eb15">empty</a>()) {</div>
+<div class="line"><a name="l02567"></a><span class="lineno"> 2567</span>&#160;        CHECK(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a965f66810b71a0d2bab683fee1b6a9b6">totalOfferedResources</a>.<a class="code" href="classmesos_1_1Resources.html#a62ae547c0d24fdfb139549e9b8126fdf">filter</a>(allocatedToRole).<a class="code" href="classmesos_1_1Resources.html#ab46b900ebe62b19390d9a2a82b46eb15">empty</a>());</div>
+<div class="line"><a name="l02568"></a><span class="lineno"> 2568</span>&#160;        <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3edaf411ec6e409a3f8b2a77988ef65a">untrackUnderRole</a>(role);</div>
+<div class="line"><a name="l02569"></a><span class="lineno"> 2569</span>&#160;      }</div>
+<div class="line"><a name="l02570"></a><span class="lineno"> 2570</span>&#160;    }</div>
+<div class="line"><a name="l02571"></a><span class="lineno"> 2571</span>&#160;  }</div>
+<div class="line"><a name="l02572"></a><span class="lineno"> 2572</span>&#160;</div>
+<div class="line"><a name="l02573"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ad28965b324be81c14e5d41524e917beb"> 2573</a></span>&#160;  <span class="keywordtype">void</span> <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#ad28965b324be81c14e5d41524e917beb">removeOfferOperation</a>(OfferOperation* operation)</div>
+<div class="line"><a name="l02574"></a><span class="lineno"> 2574</span>&#160;  {</div>
+<div class="line"><a name="l02575"></a><span class="lineno"> 2575</span>&#160;    <a class="code" href="classTry.html">Try&lt;UUID&gt;</a> uuid = UUID::fromBytes(operation-&gt;operation_uuid());</div>
+<div class="line"><a name="l02576"></a><span class="lineno"> 2576</span>&#160;    <a class="code" href="stout_2include_2stout_2check_8hpp.html#aee320e7c6e107071f4b85d4cc135a265">CHECK_SOME</a>(uuid);</div>
+<div class="line"><a name="l02577"></a><span class="lineno"> 2577</span>&#160;</div>
+<div class="line"><a name="l02578"></a><span class="lineno"> 2578</span>&#160;    CHECK(<a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a650e493bb396d724446d9571e5842901">offerOperations</a>.<a class="code" href="classhashmap.html#ac142b3f8b73c76d5d4545bbd299007e5">contains</a>(uuid.<a class="code" href="classTry.html#a7be0768038e0628632492edf6cc1515a">get</a>()))</div>
+<div class="line"><a name="l02579"></a><span class="lineno"> 2579</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;Unknown offer operation &#39;&quot;</span> &lt;&lt; operation-&gt;info().id()</div>
+<div class="line"><a name="l02580"></a><span class="lineno"> 2580</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;&#39; (uuid: &quot;</span> &lt;&lt; uuid-&gt;<a class="code" href="structid_1_1UUID.html#af024badbc379374ac635031eed57dc5f">toString</a>() &lt;&lt; <span class="stringliteral">&quot;) &quot;</span></div>
+<div class="line"><a name="l02581"></a><span class="lineno"> 2581</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;of framework &quot;</span> &lt;&lt; operation-&gt;framework_id();</div>
+<div class="line"><a name="l02582"></a><span class="lineno"> 2582</span>&#160;</div>
+<div class="line"><a name="l02583"></a><span class="lineno"> 2583</span>&#160;    <span class="keywordflow">if</span> (!<a class="code" href="namespacemesos_1_1internal_1_1protobuf.html#a19a8e8be02b815dab4cecd8382e3dd26">protobuf::isSpeculativeOperation</a>(operation-&gt;info()) &amp;&amp;</div>
+<div class="line"><a name="l02584"></a><span class="lineno"> 2584</span>&#160;        !<a class="code" href="namespacemesos_1_1internal_1_1protobuf.html#aa31907fb62769822a77c06ffbf10451f">protobuf::isTerminalState</a>(operation-&gt;latest_status().state())) {</div>
+<div class="line"><a name="l02585"></a><span class="lineno"> 2585</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.ht

<TRUNCATED>