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/11/30 17:57:28 UTC

[04/16] mesos-site git commit: Updated the website built from mesos SHA: c035e7e.

http://git-wip-us.apache.org/repos/asf/mesos-site/blob/97c3bd10/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 39229c7..547058b 100644
--- a/content/api/latest/c++/src_2master_2master_8hpp_source.html
+++ b/content/api/latest/c++/src_2master_2master_8hpp_source.html
@@ -2563,409 +2563,406 @@
 <div class="line"><a name="l02624"></a><span class="lineno"> 2624</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="l02625"></a><span class="lineno"> 2625</span>&#160;      &lt;&lt; <span class="stringliteral">&quot;of framework &quot;</span> &lt;&lt; operation-&gt;framework_id();</div>
 <div class="line"><a name="l02626"></a><span class="lineno"> 2626</span>&#160;</div>
-<div class="line"><a name="l02627"></a><span class="lineno"> 2627</span>&#160;    CHECK(<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="l02628"></a><span class="lineno"> 2628</span>&#160;      &lt;&lt; operation-&gt;latest_status().state();</div>
+<div class="line"><a name="l02627"></a><span class="lineno"> 2627</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="l02628"></a><span class="lineno"> 2628</span>&#160;  }</div>
 <div class="line"><a name="l02629"></a><span class="lineno"> 2629</span>&#160;</div>
-<div class="line"><a name="l02630"></a><span class="lineno"> 2630</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="l02631"></a><span class="lineno"> 2631</span>&#160;  }</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"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac971d54c3567de6411c6aa7e998c5417"> 2633</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="l02634"></a><span class="lineno"> 2634</span>&#160;</div>
-<div class="line"><a name="l02635"></a><span class="lineno"> 2635</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="l02636"></a><span class="lineno"> 2636</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="l02637"></a><span class="lineno"> 2637</span>&#160;  <span class="comment">// &#39;webui_url&#39;, &#39;capabilities&#39;, and &#39;labels&#39;.</span></div>
-<div class="line"><a name="l02638"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a8f5f1a0e7c16c0e7750373c1146dc3a1"> 2638</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="l02639"></a><span class="lineno"> 2639</span>&#160;  {</div>
-<div class="line"><a name="l02640"></a><span class="lineno"> 2640</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="l02641"></a><span class="lineno"> 2641</span>&#160;    CHECK_EQ(info.id(), newInfo.id());</div>
+<div class="line"><a name="l02630"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac971d54c3567de6411c6aa7e998c5417"> 2630</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="l02631"></a><span class="lineno"> 2631</span>&#160;</div>
+<div class="line"><a name="l02632"></a><span class="lineno"> 2632</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="l02633"></a><span class="lineno"> 2633</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="l02634"></a><span class="lineno"> 2634</span>&#160;  <span class="comment">// &#39;webui_url&#39;, &#39;capabilities&#39;, and &#39;labels&#39;.</span></div>
+<div class="line"><a name="l02635"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a8f5f1a0e7c16c0e7750373c1146dc3a1"> 2635</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="l02636"></a><span class="lineno"> 2636</span>&#160;  {</div>
+<div class="line"><a name="l02637"></a><span class="lineno"> 2637</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="l02638"></a><span class="lineno"> 2638</span>&#160;    CHECK_EQ(info.id(), newInfo.id());</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="comment">// Save the old list of roles for later.</span></div>
+<div class="line"><a name="l02641"></a><span class="lineno"> 2641</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="l02642"></a><span class="lineno"> 2642</span>&#160;</div>
-<div class="line"><a name="l02643"></a><span class="lineno"> 2643</span>&#160;    <span class="comment">// Save the old list of roles for later.</span></div>
-<div class="line"><a name="l02644"></a><span class="lineno"> 2644</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="l02643"></a><span class="lineno"> 2643</span>&#160;    <span class="comment">// TODO(jmlvanre): Merge other fields as per design doc in</span></div>
+<div class="line"><a name="l02644"></a><span class="lineno"> 2644</span>&#160;    <span class="comment">// MESOS-703.</span></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="comment">// TODO(jmlvanre): Merge other fields as per design doc in</span></div>
-<div class="line"><a name="l02647"></a><span class="lineno"> 2647</span>&#160;    <span class="comment">// MESOS-703.</span></div>
+<div class="line"><a name="l02646"></a><span class="lineno"> 2646</span>&#160;    info.clear_role();</div>
+<div class="line"><a name="l02647"></a><span class="lineno"> 2647</span>&#160;    info.clear_roles();</div>
 <div class="line"><a name="l02648"></a><span class="lineno"> 2648</span>&#160;</div>
-<div class="line"><a name="l02649"></a><span class="lineno"> 2649</span>&#160;    info.clear_role();</div>
-<div class="line"><a name="l02650"></a><span class="lineno"> 2650</span>&#160;    info.clear_roles();</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_role()) {</div>
-<div class="line"><a name="l02653"></a><span class="lineno"> 2653</span>&#160;      info.set_role(newInfo.role());</div>
-<div class="line"><a name="l02654"></a><span class="lineno"> 2654</span>&#160;    }</div>
-<div class="line"><a name="l02655"></a><span class="lineno"> 2655</span>&#160;</div>
-<div class="line"><a name="l02656"></a><span class="lineno"> 2656</span>&#160;    <span class="keywordflow">if</span> (newInfo.roles_size() &gt; 0) {</div>
-<div class="line"><a name="l02657"></a><span class="lineno"> 2657</span>&#160;      info.mutable_roles()-&gt;CopyFrom(newInfo.roles());</div>
-<div class="line"><a name="l02658"></a><span class="lineno"> 2658</span>&#160;    }</div>
-<div class="line"><a name="l02659"></a><span class="lineno"> 2659</span>&#160;</div>
-<div class="line"><a name="l02660"></a><span class="lineno"> 2660</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="l02661"></a><span class="lineno"> 2661</span>&#160;</div>
-<div class="line"><a name="l02662"></a><span class="lineno"> 2662</span>&#160;    <span class="keywordflow">if</span> (newInfo.user() != info.user()) {</div>
-<div class="line"><a name="l02663"></a><span class="lineno"> 2663</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="l02664"></a><span class="lineno"> 2664</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="l02665"></a><span class="lineno"> 2665</span>&#160;    }</div>
-<div class="line"><a name="l02666"></a><span class="lineno"> 2666</span>&#160;</div>
-<div class="line"><a name="l02667"></a><span class="lineno"> 2667</span>&#160;    info.set_name(newInfo.name());</div>
-<div class="line"><a name="l02668"></a><span class="lineno"> 2668</span>&#160;</div>
-<div class="line"><a name="l02669"></a><span class="lineno"> 2669</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_failover_timeout()) {</div>
-<div class="line"><a name="l02670"></a><span class="lineno"> 2670</span>&#160;      info.set_failover_timeout(newInfo.failover_timeout());</div>
-<div class="line"><a name="l02671"></a><span class="lineno"> 2671</span>&#160;    } <span class="keywordflow">else</span> {</div>
-<div class="line"><a name="l02672"></a><span class="lineno"> 2672</span>&#160;      info.clear_failover_timeout();</div>
-<div class="line"><a name="l02673"></a><span class="lineno"> 2673</span>&#160;    }</div>
-<div class="line"><a name="l02674"></a><span class="lineno"> 2674</span>&#160;</div>
-<div class="line"><a name="l02675"></a><span class="lineno"> 2675</span>&#160;    <span class="keywordflow">if</span> (newInfo.checkpoint() != info.checkpoint()) {</div>
-<div class="line"><a name="l02676"></a><span class="lineno"> 2676</span>&#160;      LOG(WARNING) &lt;&lt; <span class="stringliteral">&quot;Cannot update FrameworkInfo.checkpoint to &#39;&quot;</span></div>
-<div class="line"><a name="l02677"></a><span class="lineno"> 2677</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="l02678"></a><span class="lineno"> 2678</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="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">if</span> (newInfo.has_hostname()) {</div>
-<div class="line"><a name="l02682"></a><span class="lineno"> 2682</span>&#160;      info.set_hostname(newInfo.hostname());</div>
-<div class="line"><a name="l02683"></a><span class="lineno"> 2683</span>&#160;    } <span class="keywordflow">else</span> {</div>
-<div class="line"><a name="l02684"></a><span class="lineno"> 2684</span>&#160;      info.clear_hostname();</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;</div>
-<div class="line"><a name="l02687"></a><span class="lineno"> 2687</span>&#160;    <span class="keywordflow">if</span> (newInfo.principal() != info.principal()) {</div>
-<div class="line"><a name="l02688"></a><span class="lineno"> 2688</span>&#160;      LOG(WARNING) &lt;&lt; <span class="stringliteral">&quot;Cannot update FrameworkInfo.principal to &#39;&quot;</span></div>
-<div class="line"><a name="l02689"></a><span class="lineno"> 2689</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="l02690"></a><span class="lineno"> 2690</span>&#160;                   &lt;&lt; <span class="stringliteral">&quot;. Check MESOS-703&quot;</span>;</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;    <span class="keywordflow">if</span> (newInfo.has_webui_url()) {</div>
-<div class="line"><a name="l02694"></a><span class="lineno"> 2694</span>&#160;      info.set_webui_url(newInfo.webui_url());</div>
-<div class="line"><a name="l02695"></a><span class="lineno"> 2695</span>&#160;    } <span class="keywordflow">else</span> {</div>
-<div class="line"><a name="l02696"></a><span class="lineno"> 2696</span>&#160;      info.clear_webui_url();</div>
-<div class="line"><a name="l02697"></a><span class="lineno"> 2697</span>&#160;    }</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">if</span> (newInfo.capabilities_size() &gt; 0) {</div>
-<div class="line"><a name="l02700"></a><span class="lineno"> 2700</span>&#160;      info.mutable_capabilities()-&gt;CopyFrom(newInfo.capabilities());</div>
-<div class="line"><a name="l02701"></a><span class="lineno"> 2701</span>&#160;    } <span class="keywordflow">else</span> {</div>
-<div class="line"><a name="l02702"></a><span class="lineno"> 2702</span>&#160;      info.clear_capabilities();</div>
-<div class="line"><a name="l02703"></a><span class="lineno"> 2703</span>&#160;    }</div>
-<div class="line"><a name="l02704"></a><span class="lineno"> 2704</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="l02705"></a><span class="lineno"> 2705</span>&#160;</div>
-<div class="line"><a name="l02706"></a><span class="lineno"> 2706</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_labels()) {</div>
-<div class="line"><a name="l02707"></a><span class="lineno"> 2707</span>&#160;      info.mutable_labels()-&gt;CopyFrom(newInfo.labels());</div>
-<div class="line"><a name="l02708"></a><span class="lineno"> 2708</span>&#160;    } <span class="keywordflow">else</span> {</div>
-<div class="line"><a name="l02709"></a><span class="lineno"> 2709</span>&#160;      info.clear_labels();</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"> 2712</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="l02713"></a><span class="lineno"> 2713</span>&#160;</div>
-<div class="line"><a name="l02714"></a><span class="lineno"> 2714</span>&#160;    <span class="keyword">const</span> std::set&lt;std::string&gt; removedRoles = [&amp;]() {</div>
-<div class="line"><a name="l02715"></a><span class="lineno"> 2715</span>&#160;      std::set&lt;std::string&gt; result = oldRoles;</div>
-<div class="line"><a name="l02716"></a><span class="lineno"> 2716</span>&#160;      <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, newRoles) {</div>
-<div class="line"><a name="l02717"></a><span class="lineno"> 2717</span>&#160;        result.erase(role);</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;      <span class="keywordflow">return</span> result;</div>
-<div class="line"><a name="l02720"></a><span class="lineno"> 2720</span>&#160;    }();</div>
-<div class="line"><a name="l02721"></a><span class="lineno"> 2721</span>&#160;</div>
-<div class="line"><a name="l02722"></a><span class="lineno"> 2722</span>&#160;    <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, removedRoles) {</div>
-<div class="line"><a name="l02723"></a><span class="lineno"> 2723</span>&#160;      <span class="keyword">auto</span> allocatedToRole = [&amp;role](<span class="keyword">const</span> Resource&amp; resource) {</div>
-<div class="line"><a name="l02724"></a><span class="lineno"> 2724</span>&#160;        <span class="keywordflow">return</span> resource.allocation_info().role() == role;</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;</div>
-<div class="line"><a name="l02727"></a><span class="lineno"> 2727</span>&#160;      <span class="comment">// Stop tracking the framework under this role if there are</span></div>
-<div class="line"><a name="l02728"></a><span class="lineno"> 2728</span>&#160;      <span class="comment">// no longer any resources allocated to it.</span></div>
-<div class="line"><a name="l02729"></a><span class="lineno"> 2729</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="l02730"></a><span class="lineno"> 2730</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="l02731"></a><span class="lineno"> 2731</span>&#160;        <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3edaf411ec6e409a3f8b2a77988ef65a">untrackUnderRole</a>(role);</div>
-<div class="line"><a name="l02732"></a><span class="lineno"> 2732</span>&#160;      }</div>
-<div class="line"><a name="l02733"></a><span class="lineno"> 2733</span>&#160;    }</div>
-<div class="line"><a name="l02734"></a><span class="lineno"> 2734</span>&#160;</div>
-<div class="line"><a name="l02735"></a><span class="lineno"> 2735</span>&#160;    <span class="keyword">const</span> std::set&lt;std::string&gt; addedRoles = [&amp;]() {</div>
-<div class="line"><a name="l02736"></a><span class="lineno"> 2736</span>&#160;      std::set&lt;std::string&gt; result = newRoles;</div>
-<div class="line"><a name="l02737"></a><span class="lineno"> 2737</span>&#160;      <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, oldRoles) {</div>
-<div class="line"><a name="l02738"></a><span class="lineno"> 2738</span>&#160;        result.erase(role);</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;      <span class="keywordflow">return</span> result;</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="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, addedRoles) {</div>
-<div class="line"><a name="l02744"></a><span class="lineno"> 2744</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="l02745"></a><span class="lineno"> 2745</span>&#160;      <span class="comment">// under the role because a framework can unsubscribe from a role</span></div>
-<div class="line"><a name="l02746"></a><span class="lineno"> 2746</span>&#160;      <span class="comment">// while it still has resources allocated to the role.</span></div>
-<div class="line"><a name="l02747"></a><span class="lineno"> 2747</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="l02748"></a><span class="lineno"> 2748</span>&#160;        <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#afa185682905163563412aa1915e612c8">trackUnderRole</a>(role);</div>
-<div class="line"><a name="l02749"></a><span class="lineno"> 2749</span>&#160;      }</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;  }</div>
-<div class="line"><a name="l02752"></a><span class="lineno"> 2752</span>&#160;</div>
-<div class="line"><a name="l02753"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#aa21baf526b32c397ea45f103cea5dd15"> 2753</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="l02754"></a><span class="lineno"> 2754</span>&#160;  {</div>
-<div class="line"><a name="l02755"></a><span class="lineno"> 2755</span>&#160;    <span class="comment">// Cleanup the HTTP connnection if this is a downgrade from HTTP</span></div>
-<div class="line"><a name="l02756"></a><span class="lineno"> 2756</span>&#160;    <span class="comment">// to PID. Note that the connection may already be closed.</span></div>
-<div class="line"><a name="l02757"></a><span class="lineno"> 2757</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="l02758"></a><span class="lineno"> 2758</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a54362f290514769903a61d7cd0d6506b">closeHttpConnection</a>();</div>
-<div class="line"><a name="l02759"></a><span class="lineno"> 2759</span>&#160;    }</div>
-<div class="line"><a name="l02760"></a><span class="lineno"> 2760</span>&#160;</div>
-<div class="line"><a name="l02761"></a><span class="lineno"> 2761</span>&#160;    <span class="comment">// TODO(benh): unlink(oldPid);</span></div>
-<div class="line"><a name="l02762"></a><span class="lineno"> 2762</span>&#160;    pid = newPid;</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#aab28c60e6ecfa298c41f4e006f73a911"> 2765</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="l02766"></a><span class="lineno"> 2766</span>&#160;  {</div>
-<div class="line"><a name="l02767"></a><span class="lineno"> 2767</span>&#160;    <span class="keywordflow">if</span> (pid.isSome()) {</div>
-<div class="line"><a name="l02768"></a><span class="lineno"> 2768</span>&#160;      <span class="comment">// Wipe the PID if this is an upgrade from PID to HTTP.</span></div>
-<div class="line"><a name="l02769"></a><span class="lineno"> 2769</span>&#160;      <span class="comment">// TODO(benh): unlink(oldPid);</span></div>
-<div class="line"><a name="l02770"></a><span class="lineno"> 2770</span>&#160;      pid = <a class="code" href="structNone.html">None</a>();</div>
-<div class="line"><a name="l02771"></a><span class="lineno"> 2771</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="l02772"></a><span class="lineno"> 2772</span>&#160;      <span class="comment">// Cleanup the old HTTP connection.</span></div>
-<div class="line"><a name="l02773"></a><span class="lineno"> 2773</span>&#160;      <span class="comment">// Note that master creates a new HTTP connection for every</span></div>
-<div class="line"><a name="l02774"></a><span class="lineno"> 2774</span>&#160;      <span class="comment">// subscribe request, so &#39;newHttp&#39; should always be different</span></div>
-<div class="line"><a name="l02775"></a><span class="lineno"> 2775</span>&#160;      <span class="comment">// from &#39;http&#39;.</span></div>
-<div class="line"><a name="l02776"></a><span class="lineno"> 2776</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a54362f290514769903a61d7cd0d6506b">closeHttpConnection</a>();</div>
-<div class="line"><a name="l02777"></a><span class="lineno"> 2777</span>&#160;    }</div>
-<div class="line"><a name="l02778"></a><span class="lineno"> 2778</span>&#160;</div>
-<div class="line"><a name="l02779"></a><span class="lineno"> 2779</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="l02649"></a><span class="lineno"> 2649</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_role()) {</div>
+<div class="line"><a name="l02650"></a><span class="lineno"> 2650</span>&#160;      info.set_role(newInfo.role());</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;</div>
+<div class="line"><a name="l02653"></a><span class="lineno"> 2653</span>&#160;    <span class="keywordflow">if</span> (newInfo.roles_size() &gt; 0) {</div>
+<div class="line"><a name="l02654"></a><span class="lineno"> 2654</span>&#160;      info.mutable_roles()-&gt;CopyFrom(newInfo.roles());</div>
+<div class="line"><a name="l02655"></a><span class="lineno"> 2655</span>&#160;    }</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;    <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="l02658"></a><span class="lineno"> 2658</span>&#160;</div>
+<div class="line"><a name="l02659"></a><span class="lineno"> 2659</span>&#160;    <span class="keywordflow">if</span> (newInfo.user() != info.user()) {</div>
+<div class="line"><a name="l02660"></a><span class="lineno"> 2660</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="l02661"></a><span class="lineno"> 2661</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="l02662"></a><span class="lineno"> 2662</span>&#160;    }</div>
+<div class="line"><a name="l02663"></a><span class="lineno"> 2663</span>&#160;</div>
+<div class="line"><a name="l02664"></a><span class="lineno"> 2664</span>&#160;    info.set_name(newInfo.name());</div>
+<div class="line"><a name="l02665"></a><span class="lineno"> 2665</span>&#160;</div>
+<div class="line"><a name="l02666"></a><span class="lineno"> 2666</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_failover_timeout()) {</div>
+<div class="line"><a name="l02667"></a><span class="lineno"> 2667</span>&#160;      info.set_failover_timeout(newInfo.failover_timeout());</div>
+<div class="line"><a name="l02668"></a><span class="lineno"> 2668</span>&#160;    } <span class="keywordflow">else</span> {</div>
+<div class="line"><a name="l02669"></a><span class="lineno"> 2669</span>&#160;      info.clear_failover_timeout();</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;</div>
+<div class="line"><a name="l02672"></a><span class="lineno"> 2672</span>&#160;    <span class="keywordflow">if</span> (newInfo.checkpoint() != info.checkpoint()) {</div>
+<div class="line"><a name="l02673"></a><span class="lineno"> 2673</span>&#160;      LOG(WARNING) &lt;&lt; <span class="stringliteral">&quot;Cannot update FrameworkInfo.checkpoint to &#39;&quot;</span></div>
+<div class="line"><a name="l02674"></a><span class="lineno"> 2674</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="l02675"></a><span class="lineno"> 2675</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="l02676"></a><span class="lineno"> 2676</span>&#160;    }</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">if</span> (newInfo.has_hostname()) {</div>
+<div class="line"><a name="l02679"></a><span class="lineno"> 2679</span>&#160;      info.set_hostname(newInfo.hostname());</div>
+<div class="line"><a name="l02680"></a><span class="lineno"> 2680</span>&#160;    } <span class="keywordflow">else</span> {</div>
+<div class="line"><a name="l02681"></a><span class="lineno"> 2681</span>&#160;      info.clear_hostname();</div>
+<div class="line"><a name="l02682"></a><span class="lineno"> 2682</span>&#160;    }</div>
+<div class="line"><a name="l02683"></a><span class="lineno"> 2683</span>&#160;</div>
+<div class="line"><a name="l02684"></a><span class="lineno"> 2684</span>&#160;    <span class="keywordflow">if</span> (newInfo.principal() != info.principal()) {</div>
+<div class="line"><a name="l02685"></a><span class="lineno"> 2685</span>&#160;      LOG(WARNING) &lt;&lt; <span class="stringliteral">&quot;Cannot update FrameworkInfo.principal to &#39;&quot;</span></div>
+<div class="line"><a name="l02686"></a><span class="lineno"> 2686</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="l02687"></a><span class="lineno"> 2687</span>&#160;                   &lt;&lt; <span class="stringliteral">&quot;. Check MESOS-703&quot;</span>;</div>
+<div class="line"><a name="l02688"></a><span class="lineno"> 2688</span>&#160;    }</div>
+<div class="line"><a name="l02689"></a><span class="lineno"> 2689</span>&#160;</div>
+<div class="line"><a name="l02690"></a><span class="lineno"> 2690</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_webui_url()) {</div>
+<div class="line"><a name="l02691"></a><span class="lineno"> 2691</span>&#160;      info.set_webui_url(newInfo.webui_url());</div>
+<div class="line"><a name="l02692"></a><span class="lineno"> 2692</span>&#160;    } <span class="keywordflow">else</span> {</div>
+<div class="line"><a name="l02693"></a><span class="lineno"> 2693</span>&#160;      info.clear_webui_url();</div>
+<div class="line"><a name="l02694"></a><span class="lineno"> 2694</span>&#160;    }</div>
+<div class="line"><a name="l02695"></a><span class="lineno"> 2695</span>&#160;</div>
+<div class="line"><a name="l02696"></a><span class="lineno"> 2696</span>&#160;    <span class="keywordflow">if</span> (newInfo.capabilities_size() &gt; 0) {</div>
+<div class="line"><a name="l02697"></a><span class="lineno"> 2697</span>&#160;      info.mutable_capabilities()-&gt;CopyFrom(newInfo.capabilities());</div>
+<div class="line"><a name="l02698"></a><span class="lineno"> 2698</span>&#160;    } <span class="keywordflow">else</span> {</div>
+<div class="line"><a name="l02699"></a><span class="lineno"> 2699</span>&#160;      info.clear_capabilities();</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;    <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="l02702"></a><span class="lineno"> 2702</span>&#160;</div>
+<div class="line"><a name="l02703"></a><span class="lineno"> 2703</span>&#160;    <span class="keywordflow">if</span> (newInfo.has_labels()) {</div>
+<div class="line"><a name="l02704"></a><span class="lineno"> 2704</span>&#160;      info.mutable_labels()-&gt;CopyFrom(newInfo.labels());</div>
+<div class="line"><a name="l02705"></a><span class="lineno"> 2705</span>&#160;    } <span class="keywordflow">else</span> {</div>
+<div class="line"><a name="l02706"></a><span class="lineno"> 2706</span>&#160;      info.clear_labels();</div>
+<div class="line"><a name="l02707"></a><span class="lineno"> 2707</span>&#160;    }</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;    <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="l02710"></a><span class="lineno"> 2710</span>&#160;</div>
+<div class="line"><a name="l02711"></a><span class="lineno"> 2711</span>&#160;    <span class="keyword">const</span> std::set&lt;std::string&gt; removedRoles = [&amp;]() {</div>
+<div class="line"><a name="l02712"></a><span class="lineno"> 2712</span>&#160;      std::set&lt;std::string&gt; result = oldRoles;</div>
+<div class="line"><a name="l02713"></a><span class="lineno"> 2713</span>&#160;      <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, newRoles) {</div>
+<div class="line"><a name="l02714"></a><span class="lineno"> 2714</span>&#160;        result.erase(role);</div>
+<div class="line"><a name="l02715"></a><span class="lineno"> 2715</span>&#160;      }</div>
+<div class="line"><a name="l02716"></a><span class="lineno"> 2716</span>&#160;      <span class="keywordflow">return</span> result;</div>
+<div class="line"><a name="l02717"></a><span class="lineno"> 2717</span>&#160;    }();</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;    <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, removedRoles) {</div>
+<div class="line"><a name="l02720"></a><span class="lineno"> 2720</span>&#160;      <span class="keyword">auto</span> allocatedToRole = [&amp;role](<span class="keyword">const</span> Resource&amp; resource) {</div>
+<div class="line"><a name="l02721"></a><span class="lineno"> 2721</span>&#160;        <span class="keywordflow">return</span> resource.allocation_info().role() == role;</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"> 2724</span>&#160;      <span class="comment">// Stop tracking the framework under this role if there are</span></div>
+<div class="line"><a name="l02725"></a><span class="lineno"> 2725</span>&#160;      <span class="comment">// no longer any resources allocated to it.</span></div>
+<div class="line"><a name="l02726"></a><span class="lineno"> 2726</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="l02727"></a><span class="lineno"> 2727</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="l02728"></a><span class="lineno"> 2728</span>&#160;        <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3edaf411ec6e409a3f8b2a77988ef65a">untrackUnderRole</a>(role);</div>
+<div class="line"><a name="l02729"></a><span class="lineno"> 2729</span>&#160;      }</div>
+<div class="line"><a name="l02730"></a><span class="lineno"> 2730</span>&#160;    }</div>
+<div class="line"><a name="l02731"></a><span class="lineno"> 2731</span>&#160;</div>
+<div class="line"><a name="l02732"></a><span class="lineno"> 2732</span>&#160;    <span class="keyword">const</span> std::set&lt;std::string&gt; addedRoles = [&amp;]() {</div>
+<div class="line"><a name="l02733"></a><span class="lineno"> 2733</span>&#160;      std::set&lt;std::string&gt; result = newRoles;</div>
+<div class="line"><a name="l02734"></a><span class="lineno"> 2734</span>&#160;      <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, oldRoles) {</div>
+<div class="line"><a name="l02735"></a><span class="lineno"> 2735</span>&#160;        result.erase(role);</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;      <span class="keywordflow">return</span> result;</div>
+<div class="line"><a name="l02738"></a><span class="lineno"> 2738</span>&#160;    }();</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;    <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string&amp; role, addedRoles) {</div>
+<div class="line"><a name="l02741"></a><span class="lineno"> 2741</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="l02742"></a><span class="lineno"> 2742</span>&#160;      <span class="comment">// under the role because a framework can unsubscribe from a role</span></div>
+<div class="line"><a name="l02743"></a><span class="lineno"> 2743</span>&#160;      <span class="comment">// while it still has resources allocated to the role.</span></div>
+<div class="line"><a name="l02744"></a><span class="lineno"> 2744</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="l02745"></a><span class="lineno"> 2745</span>&#160;        <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#afa185682905163563412aa1915e612c8">trackUnderRole</a>(role);</div>
+<div class="line"><a name="l02746"></a><span class="lineno"> 2746</span>&#160;      }</div>
+<div class="line"><a name="l02747"></a><span class="lineno"> 2747</span>&#160;    }</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;</div>
+<div class="line"><a name="l02750"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#aa21baf526b32c397ea45f103cea5dd15"> 2750</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="l02751"></a><span class="lineno"> 2751</span>&#160;  {</div>
+<div class="line"><a name="l02752"></a><span class="lineno"> 2752</span>&#160;    <span class="comment">// Cleanup the HTTP connnection if this is a downgrade from HTTP</span></div>
+<div class="line"><a name="l02753"></a><span class="lineno"> 2753</span>&#160;    <span class="comment">// to PID. Note that the connection may already be closed.</span></div>
+<div class="line"><a name="l02754"></a><span class="lineno"> 2754</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="l02755"></a><span class="lineno"> 2755</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a54362f290514769903a61d7cd0d6506b">closeHttpConnection</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;</div>
+<div class="line"><a name="l02758"></a><span class="lineno"> 2758</span>&#160;    <span class="comment">// TODO(benh): unlink(oldPid);</span></div>
+<div class="line"><a name="l02759"></a><span class="lineno"> 2759</span>&#160;    pid = newPid;</div>
+<div class="line"><a name="l02760"></a><span class="lineno"> 2760</span>&#160;  }</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"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#aab28c60e6ecfa298c41f4e006f73a911"> 2762</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="l02763"></a><span class="lineno"> 2763</span>&#160;  {</div>
+<div class="line"><a name="l02764"></a><span class="lineno"> 2764</span>&#160;    <span class="keywordflow">if</span> (pid.isSome()) {</div>
+<div class="line"><a name="l02765"></a><span class="lineno"> 2765</span>&#160;      <span class="comment">// Wipe the PID if this is an upgrade from PID to HTTP.</span></div>
+<div class="line"><a name="l02766"></a><span class="lineno"> 2766</span>&#160;      <span class="comment">// TODO(benh): unlink(oldPid);</span></div>
+<div class="line"><a name="l02767"></a><span class="lineno"> 2767</span>&#160;      pid = <a class="code" href="structNone.html">None</a>();</div>
+<div class="line"><a name="l02768"></a><span class="lineno"> 2768</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="l02769"></a><span class="lineno"> 2769</span>&#160;      <span class="comment">// Cleanup the old HTTP connection.</span></div>
+<div class="line"><a name="l02770"></a><span class="lineno"> 2770</span>&#160;      <span class="comment">// Note that master creates a new HTTP connection for every</span></div>
+<div class="line"><a name="l02771"></a><span class="lineno"> 2771</span>&#160;      <span class="comment">// subscribe request, so &#39;newHttp&#39; should always be different</span></div>
+<div class="line"><a name="l02772"></a><span class="lineno"> 2772</span>&#160;      <span class="comment">// from &#39;http&#39;.</span></div>
+<div class="line"><a name="l02773"></a><span class="lineno"> 2773</span>&#160;      <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a54362f290514769903a61d7cd0d6506b">closeHttpConnection</a>();</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;</div>
+<div class="line"><a name="l02776"></a><span class="lineno"> 2776</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="l02777"></a><span class="lineno"> 2777</span>&#160;</div>
+<div class="line"><a name="l02778"></a><span class="lineno"> 2778</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a> = newHttp;</div>
+<div class="line"><a name="l02779"></a><span class="lineno"> 2779</span>&#160;  }</div>
 <div class="line"><a name="l02780"></a><span class="lineno"> 2780</span>&#160;</div>
-<div class="line"><a name="l02781"></a><span class="lineno"> 2781</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a> = newHttp;</div>
-<div class="line"><a name="l02782"></a><span class="lineno"> 2782</span>&#160;  }</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;  <span class="comment">// Closes the HTTP connection and stops the heartbeat.</span></div>
-<div class="line"><a name="l02785"></a><span class="lineno"> 2785</span>&#160;  <span class="comment">//</span></div>
-<div class="line"><a name="l02786"></a><span class="lineno"> 2786</span>&#160;  <span class="comment">// TODO(vinod): Currently `state` variable is set separately</span></div>
-<div class="line"><a name="l02787"></a><span class="lineno"> 2787</span>&#160;  <span class="comment">// from this method. We need to make sure these are in sync.</span></div>
-<div class="line"><a name="l02788"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a54362f290514769903a61d7cd0d6506b"> 2788</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="l02789"></a><span class="lineno"> 2789</span>&#160;  {</div>
-<div class="line"><a name="l02790"></a><span class="lineno"> 2790</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="l02791"></a><span class="lineno"> 2791</span>&#160;</div>
-<div class="line"><a name="l02792"></a><span class="lineno"> 2792</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="l02793"></a><span class="lineno"> 2793</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="l02794"></a><span class="lineno"> 2794</span>&#160;    }</div>
-<div class="line"><a name="l02795"></a><span class="lineno"> 2795</span>&#160;</div>
-<div class="line"><a name="l02796"></a><span class="lineno"> 2796</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="l02797"></a><span class="lineno"> 2797</span>&#160;</div>
-<div class="line"><a name="l02798"></a><span class="lineno"> 2798</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="l02781"></a><span class="lineno"> 2781</span>&#160;  <span class="comment">// Closes the HTTP connection and stops the heartbeat.</span></div>
+<div class="line"><a name="l02782"></a><span class="lineno"> 2782</span>&#160;  <span class="comment">//</span></div>
+<div class="line"><a name="l02783"></a><span class="lineno"> 2783</span>&#160;  <span class="comment">// TODO(vinod): Currently `state` variable is set separately</span></div>
+<div class="line"><a name="l02784"></a><span class="lineno"> 2784</span>&#160;  <span class="comment">// from this method. We need to make sure these are in sync.</span></div>
+<div class="line"><a name="l02785"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a54362f290514769903a61d7cd0d6506b"> 2785</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="l02786"></a><span class="lineno"> 2786</span>&#160;  {</div>
+<div class="line"><a name="l02787"></a><span class="lineno"> 2787</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="l02788"></a><span class="lineno"> 2788</span>&#160;</div>
+<div class="line"><a name="l02789"></a><span class="lineno"> 2789</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="l02790"></a><span class="lineno"> 2790</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="l02791"></a><span class="lineno"> 2791</span>&#160;    }</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"> 2793</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="l02794"></a><span class="lineno"> 2794</span>&#160;</div>
+<div class="line"><a name="l02795"></a><span class="lineno"> 2795</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="l02796"></a><span class="lineno"> 2796</span>&#160;</div>
+<div class="line"><a name="l02797"></a><span class="lineno"> 2797</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="l02798"></a><span class="lineno"> 2798</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="l02799"></a><span class="lineno"> 2799</span>&#160;</div>
-<div class="line"><a name="l02800"></a><span class="lineno"> 2800</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="l02801"></a><span class="lineno"> 2801</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="l02800"></a><span class="lineno"> 2800</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="l02801"></a><span class="lineno"> 2801</span>&#160;  }</div>
 <div class="line"><a name="l02802"></a><span class="lineno"> 2802</span>&#160;</div>
-<div class="line"><a name="l02803"></a><span class="lineno"> 2803</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="l02804"></a><span class="lineno"> 2804</span>&#160;  }</div>
-<div class="line"><a name="l02805"></a><span class="lineno"> 2805</span>&#160;</div>
-<div class="line"><a name="l02806"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab307cdcfe7dbfca8894b12097759bb41"> 2806</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="l02807"></a><span class="lineno"> 2807</span>&#160;  {</div>
-<div class="line"><a name="l02808"></a><span class="lineno"> 2808</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="l02809"></a><span class="lineno"> 2809</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="l02810"></a><span class="lineno"> 2810</span>&#160;</div>
-<div class="line"><a name="l02811"></a><span class="lineno"> 2811</span>&#160;    <span class="comment">// TODO(vinod): Make heartbeat interval configurable and include</span></div>
-<div class="line"><a name="l02812"></a><span class="lineno"> 2812</span>&#160;    <span class="comment">// this information in the SUBSCRIBED response.</span></div>
-<div class="line"><a name="l02813"></a><span class="lineno"> 2813</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="l02814"></a><span class="lineno"> 2814</span>&#160;    <span class="keyword">event</span>.set_type(scheduler::Event::HEARTBEAT);</div>
-<div class="line"><a name="l02815"></a><span class="lineno"> 2815</span>&#160;</div>
-<div class="line"><a name="l02816"></a><span class="lineno"> 2816</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70">heartbeater</a> =</div>
-<div class="line"><a name="l02817"></a><span class="lineno"> 2817</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="l02818"></a><span class="lineno"> 2818</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="l02819"></a><span class="lineno"> 2819</span>&#160;          event,</div>
-<div class="line"><a name="l02820"></a><span class="lineno"> 2820</span>&#160;          <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a>.get(),</div>
-<div class="line"><a name="l02821"></a><span class="lineno"> 2821</span>&#160;          <a class="code" href="namespacemesos_1_1internal_1_1master.html#a241384d7256ec21bea9b9e9cba24f766">DEFAULT_HEARTBEAT_INTERVAL</a>);</div>
+<div class="line"><a name="l02803"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab307cdcfe7dbfca8894b12097759bb41"> 2803</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="l02804"></a><span class="lineno"> 2804</span>&#160;  {</div>
+<div class="line"><a name="l02805"></a><span class="lineno"> 2805</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="l02806"></a><span class="lineno"> 2806</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="l02807"></a><span class="lineno"> 2807</span>&#160;</div>
+<div class="line"><a name="l02808"></a><span class="lineno"> 2808</span>&#160;    <span class="comment">// TODO(vinod): Make heartbeat interval configurable and include</span></div>
+<div class="line"><a name="l02809"></a><span class="lineno"> 2809</span>&#160;    <span class="comment">// this information in the SUBSCRIBED response.</span></div>
+<div class="line"><a name="l02810"></a><span class="lineno"> 2810</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="l02811"></a><span class="lineno"> 2811</span>&#160;    <span class="keyword">event</span>.set_type(scheduler::Event::HEARTBEAT);</div>
+<div class="line"><a name="l02812"></a><span class="lineno"> 2812</span>&#160;</div>
+<div class="line"><a name="l02813"></a><span class="lineno"> 2813</span>&#160;    <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a36dcfd05ca84ba51bc10c73dce933d70">heartbeater</a> =</div>
+<div class="line"><a name="l02814"></a><span class="lineno"> 2814</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="l02815"></a><span class="lineno"> 2815</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="l02816"></a><span class="lineno"> 2816</span>&#160;          event,</div>
+<div class="line"><a name="l02817"></a><span class="lineno"> 2817</span>&#160;          <a class="code" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c">http</a>.get(),</div>
+<div class="line"><a name="l02818"></a><span class="lineno"> 2818</span>&#160;          <a class="code" href="namespacemesos_1_1internal_1_1master.html#a241384d7256ec21bea9b9e9cba24f766">DEFAULT_HEARTBEAT_INTERVAL</a>);</div>
+<div class="line"><a name="l02819"></a><span class="lineno"> 2819</span>&#160;</div>
+<div class="line"><a name="l02820"></a><span class="lineno"> 2820</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="l02821"></a><span class="lineno"> 2821</span>&#160;  }</div>
 <div class="line"><a name="l02822"></a><span class="lineno"> 2822</span>&#160;</div>
-<div class="line"><a name="l02823"></a><span class="lineno"> 2823</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="l02824"></a><span class="lineno"> 2824</span>&#160;  }</div>
-<div class="line"><a name="l02825"></a><span class="lineno"> 2825</span>&#160;</div>
-<div class="line"><a name="l02826"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#acfcf3cedb8bf9ab2a0d76ca9026dc50a"> 2826</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="l02827"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab741aebff99e28269136e04ab76800fa"> 2827</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="l02828"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab5285e7b6a2266d1d12167d1a9f561d2"> 2828</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="l02829"></a><span class="lineno"> 2829</span>&#160;</div>
-<div class="line"><a name="l02830"></a><span class="lineno"> 2830</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="l02831"></a><span class="lineno"> 2831</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="l02832"></a><span class="lineno"> 2832</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="l02833"></a><span class="lineno"> 2833</span>&#160;</div>
-<div class="line"><a name="l02834"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3b912abb827bb20ef35d46b2388ae1f0"> 2834</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="l02835"></a><span class="lineno"> 2835</span>&#160;</div>
-<div class="line"><a name="l02836"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#aaa84eaf9694ad355fdb76ff15818b295"> 2836</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="l02837"></a><span class="lineno"> 2837</span>&#160;</div>
-<div class="line"><a name="l02838"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a2d8cbc0dbd23317d8194398a3810a5b5"> 2838</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="l02839"></a><span class="lineno"> 2839</span>&#160;</div>
-<div class="line"><a name="l02840"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a4bd6909f50c4594e8db3f4f791814dc7"> 2840</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="l02841"></a><span class="lineno"> 2841</span>&#160;</div>
-<div class="line"><a name="l02842"></a><span class="lineno"> 2842</span>&#160;  <span class="comment">// Frameworks can either be connected via HTTP or by message passing</span></div>
-<div class="line"><a name="l02843"></a><span class="lineno"> 2843</span>&#160;  <span class="comment">// (scheduler driver). At most one of `http` and `pid` will be set</span></div>
-<div class="line"><a name="l02844"></a><span class="lineno"> 2844</span>&#160;  <span class="comment">// according to the last connection made by the framework; neither</span></div>
-<div class="line"><a name="l02845"></a><span class="lineno"> 2845</span>&#160;  <span class="comment">// field will be set if the framework is in state `RECOVERED`.</span></div>
-<div class="line"><a name="l02846"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a574beb521d564fcbbbce942e694d106c"> 2846</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="l02847"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#acccaa7a1d26e66b6c1d3d6de4b1897e0"> 2847</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="l02848"></a><span class="lineno"> 2848</span>&#160;</div>
-<div class="line"><a name="l02849"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#af4322f8c99cfc37c386d3b5457a6f053"> 2849</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="l02850"></a><span class="lineno"> 2850</span>&#160;</div>
-<div class="line"><a name="l02851"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a0e09e14adf247dd3326bfd3dc09c6c7b"> 2851</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="l02852"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a0883625e8cc8fc902b5957d12e63f9a1"> 2852</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="l02853"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ac1cc9915f69092137574206fe15e571c"> 2853</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="l02854"></a><span class="lineno"> 2854</span>&#160;</div>
-<div class="line"><a name="l02855"></a><span class="lineno"> 2855</span>&#160;  <span class="comment">// Tasks that have not yet been launched because they are currently</span></div>
-<div class="line"><a name="l02856"></a><span class="lineno"> 2856</span>&#160;  <span class="comment">// being authorized.</span></div>
-<div class="line"><a name="l02857"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a146261f2447bec7776ebd06a80178d09"> 2857</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="l02858"></a><span class="lineno"> 2858</span>&#160;</div>
-<div class="line"><a name="l02859"></a><span class="lineno"> 2859</span>&#160;  <span class="comment">// TODO(bmahler): Make this private to enforce that `addTask()` and</span></div>
-<div class="line"><a name="l02860"></a><span class="lineno"> 2860</span>&#160;  <span class="comment">// `removeTask()` are used, and provide a const view into the tasks.</span></div>
-<div class="line"><a name="l02861"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#af54ac5eba8a7026cb92968fb6c6efd8a"> 2861</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="l02862"></a><span class="lineno"> 2862</span>&#160;</div>
-<div class="line"><a name="l02863"></a><span class="lineno"> 2863</span>&#160;  <span class="comment">// Tasks launched by this framework that have reached a terminal</span></div>
-<div class="line"><a name="l02864"></a><span class="lineno"> 2864</span>&#160;  <span class="comment">// state and have had all their updates acknowledged. We only keep a</span></div>
-<div class="line"><a name="l02865"></a><span class="lineno"> 2865</span>&#160;  <span class="comment">// fixed-size cache to avoid consuming too much memory. We use</span></div>
-<div class="line"><a name="l02866"></a><span class="lineno"> 2866</span>&#160;  <span class="comment">// boost::circular_buffer rather than BoundedHashMap because there</span></div>
-<div class="line"><a name="l02867"></a><span class="lineno"> 2867</span>&#160;  <span class="comment">// can be multiple completed tasks with the same task ID.</span></div>
-<div class="line"><a name="l02868"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a24bbb82d27e409d2f48ed01fbf2619f1"> 2868</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="l02869"></a><span class="lineno"> 2869</span>&#160;</div>
-<div class="line"><a name="l02870"></a><span class="lineno"> 2870</span>&#160;  <span class="comment">// When an agent is marked unreachable, tasks running on it are stored</span></div>
-<div class="line"><a name="l02871"></a><span class="lineno"> 2871</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="l02872"></a><span class="lineno"> 2872</span>&#160;  <span class="comment">// NOTE: Non-partition-aware unreachable tasks in this map are marked</span></div>
-<div class="line"><a name="l02873"></a><span class="lineno"> 2873</span>&#160;  <span class="comment">// TASK_LOST instead of TASK_UNREACHABLE for backward compatibility.</span></div>
-<div class="line"><a name="l02874"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a9db50e71935c3f9ac83ba47e18c700f8"> 2874</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="l02875"></a><span class="lineno"> 2875</span>&#160;</div>
-<div class="line"><a name="l02876"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a6fe60c0c1a491ac16776bad1598da52e"> 2876</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="l02877"></a><span class="lineno"> 2877</span>&#160;</div>
-<div class="line"><a name="l02878"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a53c59b3da6fae1d939e4ef662b1db164"> 2878</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="l02879"></a><span class="lineno"> 2879</span>&#160;</div>
-<div class="line"><a name="l02880"></a><span class="lineno"> 2880</span>&#160;  <span class="comment">// TODO(bmahler): Make this private to enforce that `addExecutor()`</span></div>
-<div class="line"><a name="l02881"></a><span class="lineno"> 2881</span>&#160;  <span class="comment">// and `removeExecutor()` are used, and provide a const view into</span></div>
-<div class="line"><a name="l02882"></a><span class="lineno"> 2882</span>&#160;  <span class="comment">// the executors.</span></div>
-<div class="line"><a name="l02883"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a1e784cda7e5c31ad19ec72b6a7b6fdee"> 2883</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="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">// Pending operations or terminal operations that have</span></div>
-<div class="line"><a name="l02886"></a><span class="lineno"> 2886</span>&#160;  <span class="comment">// unacknowledged status updates.</span></div>
-<div class="line"><a name="l02887"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a650e493bb396d724446d9571e5842901"> 2887</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="l02888"></a><span class="lineno"> 2888</span>&#160;</div>
-<div class="line"><a name="l02889"></a><span class="lineno"> 2889</span>&#160;  <span class="comment">// The map from the framework-specified operation ID to the</span></div>
-<div class="line"><a name="l02890"></a><span class="lineno"> 2890</span>&#160;  <span class="comment">// corresponding internal operation UUID.</span></div>
-<div class="line"><a name="l02891"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a4d211f2b6fca34349126f16bc2cef3e0"> 2891</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="l02892"></a><span class="lineno"> 2892</span>&#160;</div>
-<div class="line"><a name="l02893"></a><span class="lineno"> 2893</span>&#160;  <span class="comment">// NOTE: For the used and offered resources below, we keep the</span></div>
-<div class="line"><a name="l02894"></a><span class="lineno"> 2894</span>&#160;  <span class="comment">// total as well as partitioned by SlaveID.</span></div>
-<div class="line"><a name="l02895"></a><span class="lineno"> 2895</span>&#160;  <span class="comment">// We expose the total resources via the HTTP endpoint, and we</span></div>
-<div class="line"><a name="l02896"></a><span class="lineno"> 2896</span>&#160;  <span class="comment">// keep a running total of the resources because looping over the</span></div>
-<div class="line"><a name="l02897"></a><span class="lineno"> 2897</span>&#160;  <span class="comment">// slaves to sum the resources has led to perf issues (MESOS-1862).</span></div>
-<div class="line"><a name="l02898"></a><span class="lineno"> 2898</span>&#160;  <span class="comment">// We keep the resources partitioned by SlaveID because non-scalar</span></div>
-<div class="line"><a name="l02899"></a><span class="lineno"> 2899</span>&#160;  <span class="comment">// resources can be lost when summing them up across multiple</span></div>
-<div class="line"><a name="l02900"></a><span class="lineno"> 2900</span>&#160;  <span class="comment">// slaves (MESOS-2373).</span></div>
-<div class="line"><a name="l02901"></a><span class="lineno"> 2901</span>&#160;  <span class="comment">//</span></div>
-<div class="line"><a name="l02902"></a><span class="lineno"> 2902</span>&#160;  <span class="comment">// Also note that keeping the totals is safe even though it yields</span></div>
-<div class="line"><a name="l02903"></a><span class="lineno"> 2903</span>&#160;  <span class="comment">// incorrect results for non-scalar resources.</span></div>
-<div class="line"><a name="l02904"></a><span class="lineno"> 2904</span>&#160;  <span class="comment">//   (1) For overlapping set items / ranges across slaves, these</span></div>
-<div class="line"><a name="l02905"></a><span class="lineno"> 2905</span>&#160;  <span class="comment">//       will get added N times but only represented once.</span></div>
-<div class="line"><a name="l02906"></a><span class="lineno"> 2906</span>&#160;  <span class="comment">//   (2) When an initial subtraction occurs (N-1), the resource is</span></div>
-<div class="line"><a name="l02907"></a><span class="lineno"> 2907</span>&#160;  <span class="comment">//       no longer represented. (This is the source of the bug).</span></div>
-<div class="line"><a name="l02908"></a><span class="lineno"> 2908</span>&#160;  <span class="comment">//   (3) When any further subtractions occur (N-(1+M)), the</span></div>
-<div class="line"><a name="l02909"></a><span class="lineno"> 2909</span>&#160;  <span class="comment">//       Resources simply ignores the subtraction since there&#39;s</span></div>
-<div class="line"><a name="l02910"></a><span class="lineno"> 2910</span>&#160;  <span class="comment">//       nothing to remove, so this is safe for now.</span></div>
+<div class="line"><a name="l02823"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#acfcf3cedb8bf9ab2a0d76ca9026dc50a"> 2823</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="l02824"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab741aebff99e28269136e04ab76800fa"> 2824</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="l02825"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#ab5285e7b6a2266d1d12167d1a9f561d2"> 2825</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="l02826"></a><span class="lineno"> 2826</span>&#160;</div>
+<div class="line"><a name="l02827"></a><span class="lineno"> 2827</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="l02828"></a><span class="lineno"> 2828</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="l02829"></a><span class="lineno"> 2829</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="l02830"></a><span class="lineno"> 2830</span>&#160;</div>
+<div class="line"><a name="l02831"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#a3b912abb827bb20ef35d46b2388ae1f0"> 2831</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="l02832"></a><span class="lineno"> 2832</span>&#160;</div>
+<div class="line"><a name="l02833"></a><span class="lineno"><a class="line" href="structmesos_1_1internal_1_1master_1_1Framework.html#aaa84eaf9694ad355fd

<TRUNCATED>