http://git-wip-us.apache.org/repos/asf/mesos-site/blob/cfbae833/content/api/latest/c++/http__connection_8hpp_source.html
----------------------------------------------------------------------
diff --git a/content/api/latest/c++/http__connection_8hpp_source.html 
b/content/api/latest/c++/http__connection_8hpp_source.html
index d5b35be..0b3af81 100644
--- a/content/api/latest/c++/http__connection_8hpp_source.html
+++ b/content/api/latest/c++/http__connection_8hpp_source.html
@@ -73,7 +73,7 @@
 <div class="ttc" 
id="structprocess_1_1http_1_1Response_html_ad6530fddd03380dbb3b23b17523cb242"><div
 class="ttname"><a 
href="structprocess_1_1http_1_1Response.html#ad6530fddd03380dbb3b23b17523cb242">process::http::Response::code</a></div><div
 class="ttdeci">uint16_t code</div><div class="ttdef"><b>Definition:</b> 
http.hpp:657</div></div>
 <div class="ttc" 
id="namespaceos_1_1libraries_1_1Library_html_ab0e1a0e311049b6d685de1068e8f4690"><div
 class="ttname"><a 
href="namespaceos_1_1libraries_1_1Library.html#ab0e1a0e311049b6d685de1068e8f4690">os::libraries::Library::prefix</a></div><div
 class="ttdeci">constexpr const char * prefix</div><div 
class="ttdef"><b>Definition:</b> os.hpp:94</div></div>
 <div class="ttc" 
id="classmesos_1_1internal_1_1HttpConnectionProcess_html_a81fc91fa235309d5486bf019260e6480"><div
 class="ttname"><a 
href="classmesos_1_1internal_1_1HttpConnectionProcess.html#a81fc91fa235309d5486bf019260e6480">mesos::internal::HttpConnectionProcess::receive</a></div><div
 class="ttdeci">void receive(const Event &amp;event)</div><div 
class="ttdef"><b>Definition:</b> http_connection.hpp:467</div></div>
-<div class="ttc" 
id="namespacemesos_1_1internal_1_1tests_1_1v1_1_1scheduler_html_acb18ceaa5f6f2338f2a9727af398eb79"><div
 class="ttname"><a 
href="namespacemesos_1_1internal_1_1tests_1_1v1_1_1scheduler.html#acb18ceaa5f6f2338f2a9727af398eb79">mesos::internal::tests::v1::scheduler::Call</a></div><div
 class="ttdeci">mesos::v1::scheduler::Call Call</div><div 
class="ttdef"><b>Definition:</b> mesos.hpp:2611</div></div>
+<div class="ttc" 
id="namespacemesos_1_1internal_1_1tests_1_1v1_1_1scheduler_html_acb18ceaa5f6f2338f2a9727af398eb79"><div
 class="ttname"><a 
href="namespacemesos_1_1internal_1_1tests_1_1v1_1_1scheduler.html#acb18ceaa5f6f2338f2a9727af398eb79">mesos::internal::tests::v1::scheduler::Call</a></div><div
 class="ttdeci">mesos::v1::scheduler::Call Call</div><div 
class="ttdef"><b>Definition:</b> mesos.hpp:2616</div></div>
 <div class="ttc" 
id="classmesos_1_1internal_1_1HttpConnectionProcess_html"><div 
class="ttname"><a 
href="classmesos_1_1internal_1_1HttpConnectionProcess.html">mesos::internal::HttpConnectionProcess</a></div><div
 class="ttdoc">HTTP connection handler. </div><div 
class="ttdef"><b>Definition:</b> resource_provider.hpp:41</div></div>
 <div class="ttc" 
id="classprocess_1_1Future_html_a4012f3faa6191fc13874dca62c14ced0"><div 
class="ttname"><a 
href="classprocess_1_1Future.html#a4012f3faa6191fc13874dca62c14ced0">process::Future::discard</a></div><div
 class="ttdeci">bool discard()</div><div class="ttdef"><b>Definition:</b> 
future.hpp:1160</div></div>
 <div class="ttc" id="dispatch_8hpp_html"><div class="ttname"><a 
href="dispatch_8hpp.html">dispatch.hpp</a></div></div>
@@ -84,7 +84,7 @@
 <div class="ttc" id="classOption_html_a4e3bf8416d95246f43c91f1b5c309323"><div 
class="ttname"><a 
href="classOption.html#a4e3bf8416d95246f43c91f1b5c309323">Option::isSome</a></div><div
 class="ttdeci">bool isSome() const </div><div class="ttdef"><b>Definition:</b> 
option.hpp:115</div></div>
 <div class="ttc" 
id="classmesos_1_1internal_1_1HttpConnectionProcess_html_a0e32a05c88072b7db23e87a384ffa1ea"><div
 class="ttname"><a 
href="classmesos_1_1internal_1_1HttpConnectionProcess.html#a0e32a05c88072b7db23e87a384ffa1ea">mesos::internal::HttpConnectionProcess::connect</a></div><div
 class="ttdeci">void connect(const id::UUID &amp;_connectionId)</div><div 
class="ttdef"><b>Definition:</b> http_connection.hpp:238</div></div>
 <div class="ttc" id="structprocess_1_1http_1_1Request_html"><div 
class="ttname"><a 
href="structprocess_1_1http_1_1Request.html">process::http::Request</a></div><div
 class="ttdef"><b>Definition:</b> http.hpp:517</div></div>
-<div class="ttc" 
id="namespacemesos_1_1internal_1_1tests_1_1v1_1_1scheduler_html_acd3fa8addac36f513726743665631d79"><div
 class="ttname"><a 
href="namespacemesos_1_1internal_1_1tests_1_1v1_1_1scheduler.html#acd3fa8addac36f513726743665631d79">mesos::internal::tests::v1::scheduler::Event</a></div><div
 class="ttdeci">mesos::v1::scheduler::Event Event</div><div 
class="ttdef"><b>Definition:</b> mesos.hpp:2612</div></div>
+<div class="ttc" 
id="namespacemesos_1_1internal_1_1tests_1_1v1_1_1scheduler_html_acd3fa8addac36f513726743665631d79"><div
 class="ttname"><a 
href="namespacemesos_1_1internal_1_1tests_1_1v1_1_1scheduler.html#acd3fa8addac36f513726743665631d79">mesos::internal::tests::v1::scheduler::Event</a></div><div
 class="ttdeci">mesos::v1::scheduler::Event Event</div><div 
class="ttdef"><b>Definition:</b> mesos.hpp:2617</div></div>
 <div class="ttc" 
id="structprocess_1_1http_1_1Response_html_aa3543eb8ecd36f5d6d91b2640d471359"><div
 class="ttname"><a 
href="structprocess_1_1http_1_1Response.html#aa3543eb8ecd36f5d6d91b2640d471359">process::http::Response::reader</a></div><div
 class="ttdeci">Option&lt; Pipe::Reader &gt; reader</div><div 
class="ttdef"><b>Definition:</b> http.hpp:655</div></div>
 <div class="ttc" 
id="classmesos_1_1internal_1_1HttpConnectionProcess_html_a15a7b927d5655f1e59ea1bd43d2fe8f9"><div
 class="ttname"><a 
href="classmesos_1_1internal_1_1HttpConnectionProcess.html#a15a7b927d5655f1e59ea1bd43d2fe8f9">mesos::internal::HttpConnectionProcess::Self</a></div><div
 class="ttdeci">HttpConnectionProcess&lt; Call, Event &gt; Self</div><div 
class="ttdef"><b>Definition:</b> http_connection.hpp:181</div></div>
 <div class="ttc" id="duration_8hpp_html"><div class="ttname"><a 
href="duration_8hpp.html">duration.hpp</a></div></div>

http://git-wip-us.apache.org/repos/asf/mesos-site/blob/cfbae833/content/api/latest/c++/include_2mesos_2allocator_2allocator_8hpp_source.html
----------------------------------------------------------------------
diff --git 
a/content/api/latest/c++/include_2mesos_2allocator_2allocator_8hpp_source.html 
b/content/api/latest/c++/include_2mesos_2allocator_2allocator_8hpp_source.html
index 525e34f..334fb6d 100644
--- 
a/content/api/latest/c++/include_2mesos_2allocator_2allocator_8hpp_source.html
+++ 
b/content/api/latest/c++/include_2mesos_2allocator_2allocator_8hpp_source.html
@@ -52,7 +52,7 @@
 <div class="title">allocator.hpp</div>  </div>
 </div><!--header-->
 <div class="contents">
-<a href="include_2mesos_2allocator_2allocator_8hpp.html">Go to the 
documentation of this file.</a><div class="fragment"><div class="line"><a 
name="l00001"></a><span class="lineno">    1</span>&#160;<span 
class="comment">// Licensed to the Apache Software Foundation (ASF) under 
one</span></div><div class="line"><a name="l00002"></a><span class="lineno">    
2</span>&#160;<span class="comment">// or more contributor license agreements.  
See the NOTICE file</span></div><div class="line"><a name="l00003"></a><span 
class="lineno">    3</span>&#160;<span class="comment">// distributed with this 
work for additional information</span></div><div class="line"><a 
name="l00004"></a><span class="lineno">    4</span>&#160;<span 
class="comment">// regarding copyright ownership.  The ASF licenses this 
file</span></div><div class="line"><a name="l00005"></a><span class="lineno">   
 5</span>&#160;<span class="comment">// to you under the Apache License, 
Version 2.0 (the</span></div><div class="line"><
 a name="l00006"></a><span class="lineno">    6</span>&#160;<span 
class="comment">// &quot;License&quot;); you may not use this file except in 
compliance</span></div><div class="line"><a name="l00007"></a><span 
class="lineno">    7</span>&#160;<span class="comment">// with the License.  
You may obtain a copy of the License at</span></div><div class="line"><a 
name="l00008"></a><span class="lineno">    8</span>&#160;<span 
class="comment">//</span></div><div class="line"><a name="l00009"></a><span 
class="lineno">    9</span>&#160;<span class="comment">//     
http://www.apache.org/licenses/LICENSE-2.0</span></div><div class="line"><a 
name="l00010"></a><span class="lineno">   10</span>&#160;<span 
class="comment">//</span></div><div class="line"><a name="l00011"></a><span 
class="lineno">   11</span>&#160;<span class="comment">// Unless required by 
applicable law or agreed to in writing, software</span></div><div 
class="line"><a name="l00012"></a><span class="lineno">   12</span>&#160;<span
  class="comment">// distributed under the License is distributed on an 
&quot;AS IS&quot; BASIS,</span></div><div class="line"><a 
name="l00013"></a><span class="lineno">   13</span>&#160;<span 
class="comment">// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express 
or implied.</span></div><div class="line"><a name="l00014"></a><span 
class="lineno">   14</span>&#160;<span class="comment">// See the License for 
the specific language governing permissions and</span></div><div 
class="line"><a name="l00015"></a><span class="lineno">   15</span>&#160;<span 
class="comment">// limitations under the License.</span></div><div 
class="line"><a name="l00016"></a><span class="lineno">   
16</span>&#160;</div><div class="line"><a name="l00017"></a><span 
class="lineno">   17</span>&#160;<span class="preprocessor">#ifndef 
__MESOS_ALLOCATOR_ALLOCATOR_HPP__</span></div><div class="line"><a 
name="l00018"></a><span class="lineno">   18</span>&#160;<span 
class="preprocessor">#define __MESOS_ALLOCATO
 R_ALLOCATOR_HPP__</span></div><div class="line"><a name="l00019"></a><span 
class="lineno">   19</span>&#160;</div><div class="line"><a 
name="l00020"></a><span class="lineno">   20</span>&#160;<span 
class="preprocessor">#include &lt;string&gt;</span></div><div class="line"><a 
name="l00021"></a><span class="lineno">   21</span>&#160;<span 
class="preprocessor">#include &lt;vector&gt;</span></div><div class="line"><a 
name="l00022"></a><span class="lineno">   22</span>&#160;</div><div 
class="line"><a name="l00023"></a><span class="lineno">   23</span>&#160;<span 
class="comment">// ONLY USEFUL AFTER RUNNING PROTOC.</span></div><div 
class="line"><a name="l00024"></a><span class="lineno">   24</span>&#160;<span 
class="preprocessor">#include 
&lt;mesos/allocator/allocator.pb.h&gt;</span></div><div class="line"><a 
name="l00025"></a><span class="lineno">   25</span>&#160;</div><div 
class="line"><a name="l00026"></a><span class="lineno">   26</span>&#160;<span 
class="preprocessor">#include &lt;<
 a class="code" 
href="include_2mesos_2maintenance_2maintenance_8hpp.html">mesos/maintenance/maintenance.hpp</a>&gt;</span></div><div
 class="line"><a name="l00027"></a><span class="lineno">   
27</span>&#160;</div><div class="line"><a name="l00028"></a><span 
class="lineno">   28</span>&#160;<span class="preprocessor">#include &lt;<a 
class="code" 
href="include_2mesos_2quota_2quota_8hpp.html">mesos/quota/quota.hpp</a>&gt;</span></div><div
 class="line"><a name="l00029"></a><span class="lineno">   
29</span>&#160;</div><div class="line"><a name="l00030"></a><span 
class="lineno">   30</span>&#160;<span class="preprocessor">#include &lt;<a 
class="code" 
href="resources_8hpp.html">mesos/resources.hpp</a>&gt;</span></div><div 
class="line"><a name="l00031"></a><span class="lineno">   
31</span>&#160;</div><div class="line"><a name="l00032"></a><span 
class="lineno">   32</span>&#160;<span class="preprocessor">#include &lt;<a 
class="code" href="future_8hpp.html">process/future.hpp</a>&gt;</span></di
 v><div class="line"><a name="l00033"></a><span class="lineno">   
33</span>&#160;</div><div class="line"><a name="l00034"></a><span 
class="lineno">   34</span>&#160;<span class="preprocessor">#include &lt;<a 
class="code" 
href="duration_8hpp.html">stout/duration.hpp</a>&gt;</span></div><div 
class="line"><a name="l00035"></a><span class="lineno">   35</span>&#160;<span 
class="preprocessor">#include &lt;<a class="code" 
href="hashmap_8hpp.html">stout/hashmap.hpp</a>&gt;</span></div><div 
class="line"><a name="l00036"></a><span class="lineno">   36</span>&#160;<span 
class="preprocessor">#include &lt;<a class="code" 
href="hashset_8hpp.html">stout/hashset.hpp</a>&gt;</span></div><div 
class="line"><a name="l00037"></a><span class="lineno">   37</span>&#160;<span 
class="preprocessor">#include &lt;<a class="code" 
href="lambda_8hpp.html">stout/lambda.hpp</a>&gt;</span></div><div 
class="line"><a name="l00038"></a><span class="lineno">   38</span>&#160;<span 
class="preprocessor">#include &lt;<a cl
 ass="code" href="option_8hpp.html">stout/option.hpp</a>&gt;</span></div><div 
class="line"><a name="l00039"></a><span class="lineno">   39</span>&#160;<span 
class="preprocessor">#include &lt;<a class="code" 
href="try_8hpp.html">stout/try.hpp</a>&gt;</span></div><div class="line"><a 
name="l00040"></a><span class="lineno">   40</span>&#160;</div><div 
class="line"><a name="l00041"></a><span class="lineno">   41</span>&#160;<span 
class="keyword">namespace </span><a class="code" 
href="namespacemesos.html">mesos</a> {</div><div class="line"><a 
name="l00042"></a><span class="lineno"><a class="line" 
href="namespacemesos_1_1allocator.html">   42</a></span>&#160;<span 
class="keyword">namespace </span>allocator {</div><div class="line"><a 
name="l00043"></a><span class="lineno">   43</span>&#160;</div><div 
class="line"><a name="l00055"></a><span class="lineno"><a class="line" 
href="classmesos_1_1allocator_1_1Allocator.html">   55</a></span>&#160;<span 
class="keyword">class </span><a class="code"
  href="classmesos_1_1allocator_1_1Allocator.html">Allocator</a></div><div 
class="line"><a name="l00056"></a><span class="lineno">   
56</span>&#160;{</div><div class="line"><a name="l00057"></a><span 
class="lineno">   57</span>&#160;<span class="keyword">public</span>:</div><div 
class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;  
<span class="keyword">static</span> <a class="code" 
href="classTry.html">Try&lt;Allocator*&gt;</a> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#ae5b969c74d1dc42b98b35a81d571b3fa">create</a>(</div><div
 class="line"><a name="l00069"></a><span class="lineno">   69</span>&#160;      
<span class="keyword">const</span> std::string&amp; <a class="code" 
href="namespaceos_1_1Shell.html#acfe16ef2b1146ad49a8651c0a457ce46">name</a>,</div><div
 class="line"><a name="l00070"></a><span class="lineno">   70</span>&#160;      
<span class="keyword">const</span> std::string&amp; roleSorter,</div><div 
class="line"><a name="l00071"></a><s
 pan class="lineno">   71</span>&#160;      <span class="keyword">const</span> 
std::string&amp; frameworkSorter);</div><div class="line"><a 
name="l00072"></a><span class="lineno">   72</span>&#160;</div><div 
class="line"><a name="l00073"></a><span class="lineno"><a class="line" 
href="classmesos_1_1allocator_1_1Allocator.html#aafc715605c23a31dcb511a6b5c2ac883">
   73</a></span>&#160;  <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#aafc715605c23a31dcb511a6b5c2ac883">Allocator</a>()
 {}</div><div class="line"><a name="l00074"></a><span class="lineno">   
74</span>&#160;</div><div class="line"><a name="l00075"></a><span 
class="lineno"><a class="line" 
href="classmesos_1_1allocator_1_1Allocator.html#a8b32e61251f0e0cbc9588c04e98347a3">
   75</a></span>&#160;  <span class="keyword">virtual</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a8b32e61251f0e0cbc9588c04e98347a3">~Allocator</a>()
 {}</div><div class="line"><a name="l00076"></a><span class="lineno"> 
   76</span>&#160;</div><div class="line"><a name="l00091"></a><span 
class="lineno">   91</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a339c1dd8fc2e84bb0b0939cdec7e2e6a">initialize</a>(</div><div
 class="line"><a name="l00092"></a><span class="lineno">   92</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classDuration.html">Duration</a>&amp; allocationInterval,</div><div 
class="line"><a name="l00093"></a><span class="lineno">   93</span>&#160;      
<span class="keyword">const</span> lambda::function&lt;</div><div 
class="line"><a name="l00094"></a><span class="lineno">   94</span>&#160;       
   <span class="keywordtype">void</span>(<span class="keyword">const</span> 
FrameworkID&amp;,</div><div class="line"><a name="l00095"></a><span 
class="lineno">   95</span>&#160;               <span 
class="keyword">const</span> <a class="code" href="classhashmap.htm
 l">hashmap</a>&lt;std::string, <a class="code" 
href="classhashmap.html">hashmap&lt;SlaveID, 
Resources&gt;</a>&gt;&amp;)&gt;&amp;</div><div class="line"><a 
name="l00096"></a><span class="lineno">   96</span>&#160;                   
offerCallback,</div><div class="line"><a name="l00097"></a><span 
class="lineno">   97</span>&#160;      <span class="keyword">const</span> 
lambda::function&lt;</div><div class="line"><a name="l00098"></a><span 
class="lineno">   98</span>&#160;          <span 
class="keywordtype">void</span>(<span class="keyword">const</span> 
FrameworkID&amp;,</div><div class="line"><a name="l00099"></a><span 
class="lineno">   99</span>&#160;               <span 
class="keyword">const</span> <a class="code" 
href="classhashmap.html">hashmap&lt;SlaveID, 
UnavailableResources&gt;</a>&amp;)&gt;&amp;</div><div class="line"><a 
name="l00100"></a><span class="lineno">  100</span>&#160;        
inverseOfferCallback,</div><div class="line"><a name="l00101"></a><span 
class="lineno">  101<
 /span>&#160;      <span class="keyword">const</span> <a class="code" 
href="classOption.html">Option</a>&lt;std::set&lt;std::string&gt;&gt;&amp;</div><div
 class="line"><a name="l00102"></a><span class="lineno">  102</span>&#160;      
  fairnessExcludeResourceNames = <a class="code" 
href="structNone.html">None</a>(),</div><div class="line"><a 
name="l00103"></a><span class="lineno">  103</span>&#160;      <span 
class="keywordtype">bool</span> filterGpuResources = <span 
class="keyword">true</span>,</div><div class="line"><a name="l00104"></a><span 
class="lineno">  104</span>&#160;      <span class="keyword">const</span> <a 
class="code" href="classOption.html">Option&lt;DomainInfo&gt;</a>&amp; domain = 
<a class="code" href="structNone.html">None</a>(),</div><div class="line"><a 
name="l00105"></a><span class="lineno">  105</span>&#160;      <span 
class="keyword">const</span> <a class="code" 
href="classOption.html">Option</a>&lt;std::vector&lt;Resources&gt;&gt;&amp;</div><div
 class="line">
 <a name="l00106"></a><span class="lineno">  106</span>&#160;        
minAllocatableResources = <a class="code" href="structNone.html">None</a>()) = 
0;</div><div class="line"><a name="l00107"></a><span class="lineno">  
107</span>&#160;</div><div class="line"><a name="l00121"></a><span 
class="lineno">  121</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#abe1f158adb9f7a6d7cc9f8afae44e859">recover</a>(</div><div
 class="line"><a name="l00122"></a><span class="lineno">  122</span>&#160;      
<span class="keyword">const</span> <span class="keywordtype">int</span> 
expectedAgentCount,</div><div class="line"><a name="l00123"></a><span 
class="lineno">  123</span>&#160;      <span class="keyword">const</span> <a 
class="code" href="classhashmap.html">hashmap&lt;std::string, 
Quota&gt;</a>&amp; quotas) = 0;</div><div class="line"><a 
name="l00124"></a><span class="lineno">  124</span>&#160;</div>
 <div class="line"><a name="l00139"></a><span class="lineno">  139</span>&#160; 
 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a681883278b64d1e45fc515a7899a3d99">addFramework</a>(</div><div
 class="line"><a name="l00140"></a><span class="lineno">  140</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00141"></a><span class="lineno">  141</span>&#160;      
<span class="keyword">const</span> FrameworkInfo&amp; frameworkInfo,</div><div 
class="line"><a name="l00142"></a><span class="lineno">  142</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classhashmap.html">hashmap&lt;SlaveID, Resources&gt;</a>&amp; 
used,</div><div class="line"><a name="l00143"></a><span class="lineno">  
143</span>&#160;      <span class="keywordtype">bool</span> active,</div><div 
class="line"><a name="l00144"></a><span class="lineno"
 >  144</span>&#160;      <span class="keyword">const</span> 
 > std::set&lt;std::string&gt;&amp; suppressedRoles) = 0;</div><div 
 > class="line"><a name="l00145"></a><span class="lineno">  
 > 145</span>&#160;</div><div class="line"><a name="l00151"></a><span 
 > class="lineno">  151</span>&#160;  <span class="keyword">virtual</span> 
 > <span class="keywordtype">void</span> <a class="code" 
 > href="classmesos_1_1allocator_1_1Allocator.html#ac58e3a3025d3887ab1ab9267c9093188">removeFramework</a>(</div><div
 >  class="line"><a name="l00152"></a><span class="lineno">  152</span>&#160;   
 >    <span class="keyword">const</span> FrameworkID&amp; frameworkId) = 
 > 0;</div><div class="line"><a name="l00153"></a><span class="lineno">  
 > 153</span>&#160;</div><div class="line"><a name="l00158"></a><span 
 > class="lineno">  158</span>&#160;  <span class="keyword">virtual</span> 
 > <span class="keywordtype">void</span> <a class="code" 
 > href="classmesos_1_1allocator_1_1Allocator.html#a60b5e4ab25ef87eb74763c10cfc21850">activateFramewor
 k</a>(</div><div class="line"><a name="l00159"></a><span class="lineno">  
159</span>&#160;      <span class="keyword">const</span> FrameworkID&amp; 
frameworkId) = 0;</div><div class="line"><a name="l00160"></a><span 
class="lineno">  160</span>&#160;</div><div class="line"><a 
name="l00165"></a><span class="lineno">  165</span>&#160;  <span 
class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#afe9d8fc901322dde7d91037930c77f72">deactivateFramework</a>(</div><div
 class="line"><a name="l00166"></a><span class="lineno">  166</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId) = 0;</div><div 
class="line"><a name="l00167"></a><span class="lineno">  
167</span>&#160;</div><div class="line"><a name="l00178"></a><span 
class="lineno">  178</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.h
 tml#a97eadff5ba5f1b25beeb2b99e7ed72bb">updateFramework</a>(</div><div 
class="line"><a name="l00179"></a><span class="lineno">  179</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00180"></a><span class="lineno">  180</span>&#160;      
<span class="keyword">const</span> FrameworkInfo&amp; frameworkInfo,</div><div 
class="line"><a name="l00181"></a><span class="lineno">  181</span>&#160;      
<span class="keyword">const</span> std::set&lt;std::string&gt;&amp; 
suppressedRoles) = 0;</div><div class="line"><a name="l00182"></a><span 
class="lineno">  182</span>&#160;</div><div class="line"><a 
name="l00198"></a><span class="lineno">  198</span>&#160;  <span 
class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a12346eed9894458805e180b9d6cb6424">addSlave</a>(</div><div
 class="line"><a name="l00199"></a><span class="lineno">  199</span>&#160;      
 <span class="keyword">const</span> SlaveID&amp; slaveId,</div><div 
class="line"><a name="l00200"></a><span class="lineno">  200</span>&#160;      
<span class="keyword">const</span> SlaveInfo&amp; slaveInfo,</div><div 
class="line"><a name="l00201"></a><span class="lineno">  201</span>&#160;      
<span class="keyword">const</span> 
std::vector&lt;SlaveInfo::Capability&gt;&amp; capabilities,</div><div 
class="line"><a name="l00202"></a><span class="lineno">  202</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;Unavailability&gt;</a>&amp; <a class="code" 
href="namespacemesos_1_1internal_1_1master_1_1maintenance_1_1validation.html#a766d3749f894fce457b084746f0ba868">unavailability</a>,</div><div
 class="line"><a name="l00203"></a><span class="lineno">  203</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classmesos_1_1Resources.html">Resources</a>&amp; total,</div><div 
class="line"><a name="l00204"></a><span clas
 s="lineno">  204</span>&#160;      <span class="keyword">const</span> <a 
class="code" href="classhashmap.html">hashmap&lt;FrameworkID, 
Resources&gt;</a>&amp; used) = 0;</div><div class="line"><a 
name="l00205"></a><span class="lineno">  205</span>&#160;</div><div 
class="line"><a name="l00210"></a><span class="lineno">  210</span>&#160;  
<span class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a7193bcacb52eaec201bf88e95f03acad">removeSlave</a>(</div><div
 class="line"><a name="l00211"></a><span class="lineno">  211</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId) = 0;</div><div 
class="line"><a name="l00212"></a><span class="lineno">  
212</span>&#160;</div><div class="line"><a name="l00222"></a><span 
class="lineno">  222</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#ad3027942
 0381616f523418812beb798f">updateSlave</a>(</div><div class="line"><a 
name="l00223"></a><span class="lineno">  223</span>&#160;      <span 
class="keyword">const</span> SlaveID&amp; slave,</div><div class="line"><a 
name="l00224"></a><span class="lineno">  224</span>&#160;      <span 
class="keyword">const</span> SlaveInfo&amp; slaveInfo,</div><div 
class="line"><a name="l00225"></a><span class="lineno">  225</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;Resources&gt;</a>&amp; total = <a 
class="code" href="structNone.html">None</a>(),</div><div class="line"><a 
name="l00226"></a><span class="lineno">  226</span>&#160;      <span 
class="keyword">const</span> <a class="code" 
href="classOption.html">Option</a>&lt;std::vector&lt;SlaveInfo::Capability&gt;&gt;&amp;</div><div
 class="line"><a name="l00227"></a><span class="lineno">  227</span>&#160;      
    capabilities = <a class="code" href="structNone.html">None</a>()) = 
0;</div><div cl
 ass="line"><a name="l00228"></a><span class="lineno">  
228</span>&#160;</div><div class="line"><a name="l00237"></a><span 
class="lineno">  237</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#ad873c196dc884fb2ccc116964157d7ff">addResourceProvider</a>(</div><div
 class="line"><a name="l00238"></a><span class="lineno">  238</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slave,</div><div 
class="line"><a name="l00239"></a><span class="lineno">  239</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classmesos_1_1Resources.html">Resources</a>&amp; total,</div><div 
class="line"><a name="l00240"></a><span class="lineno">  240</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classhashmap.html">hashmap&lt;FrameworkID, Resources&gt;</a>&amp; used) = 
0;</div><div class="line"><a name="l00241"></a><span class="lineno">  241</
 span>&#160;</div><div class="line"><a name="l00246"></a><span class="lineno">  
246</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a2469bc7c28ab20a86cd2d198dd99e2cd">activateSlave</a>(</div><div
 class="line"><a name="l00247"></a><span class="lineno">  247</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId) = 0;</div><div 
class="line"><a name="l00248"></a><span class="lineno">  
248</span>&#160;</div><div class="line"><a name="l00257"></a><span 
class="lineno">  257</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a4dff6ddc4983c5495eb2fc26e2842114">deactivateSlave</a>(</div><div
 class="line"><a name="l00258"></a><span class="lineno">  258</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId) = 0;</div><div 
class="line"><a name="l00259"><
 /a><span class="lineno">  259</span>&#160;</div><div class="line"><a 
name="l00268"></a><span class="lineno">  268</span>&#160;  <span 
class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a961049fd776211cc762ad0e1e1c99321">updateWhitelist</a>(</div><div
 class="line"><a name="l00269"></a><span class="lineno">  269</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option</a>&lt;<a class="code" 
href="classhashset.html">hashset&lt;std::string&gt;</a>&gt;&amp; whitelist) = 
0;</div><div class="line"><a name="l00270"></a><span class="lineno">  
270</span>&#160;</div><div class="line"><a name="l00278"></a><span 
class="lineno">  278</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a6d1124aace866719ed1e9ed45a068412">requestResources</a>(</div><div
 class="line"><a name="l0
 0279"></a><span class="lineno">  279</span>&#160;      <span 
class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00280"></a><span class="lineno">  280</span>&#160;      
<span class="keyword">const</span> std::vector&lt;Request&gt;&amp; requests) = 
0;</div><div class="line"><a name="l00281"></a><span class="lineno">  
281</span>&#160;</div><div class="line"><a name="l00292"></a><span 
class="lineno">  292</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#aa8ee61bea88a926c920e909571f836dd">updateAllocation</a>(</div><div
 class="line"><a name="l00293"></a><span class="lineno">  293</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00294"></a><span class="lineno">  294</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId,</div><div 
class="line"><a name="l00295"><
 /a><span class="lineno">  295</span>&#160;      <span 
class="keyword">const</span> <a class="code" 
href="classmesos_1_1Resources.html">Resources</a>&amp; 
offeredResources,</div><div class="line"><a name="l00296"></a><span 
class="lineno">  296</span>&#160;      <span class="keyword">const</span> 
std::vector&lt;ResourceConversion&gt;&amp; conversions) = 0;</div><div 
class="line"><a name="l00297"></a><span class="lineno">  
297</span>&#160;</div><div class="line"><a name="l00305"></a><span 
class="lineno">  305</span>&#160;  <span class="keyword">virtual</span> <a 
class="code" 
href="classprocess_1_1Future.html">process::Future&lt;Nothing&gt;</a> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a997ec43933a7659b683d83c164bdd6db">updateAvailable</a>(</div><div
 class="line"><a name="l00306"></a><span class="lineno">  306</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId,</div><div 
class="line"><a name="l00307"></a><span class="lineno">  307</span>&#160
 ;      <span class="keyword">const</span> 
std::vector&lt;Offer::Operation&gt;&amp; operations) = 0;</div><div 
class="line"><a name="l00308"></a><span class="lineno">  
308</span>&#160;</div><div class="line"><a name="l00317"></a><span 
class="lineno">  317</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a455bb50eb4548484969c42ada23cd8ff">updateUnavailability</a>(</div><div
 class="line"><a name="l00318"></a><span class="lineno">  318</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId,</div><div 
class="line"><a name="l00319"></a><span class="lineno">  319</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;Unavailability&gt;</a>&amp; unavailability) = 
0;</div><div class="line"><a name="l00320"></a><span class="lineno">  
320</span>&#160;</div><div class="line"><a name="l00339"></a><span 
class="lineno">  339</spa
 n>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a9b03a500abdf2f677f3fd9ea958d0690">updateInverseOffer</a>(</div><div
 class="line"><a name="l00340"></a><span class="lineno">  340</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId,</div><div 
class="line"><a name="l00341"></a><span class="lineno">  341</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00342"></a><span class="lineno">  342</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;UnavailableResources&gt;</a>&amp; 
unavailableResources,</div><div class="line"><a name="l00343"></a><span 
class="lineno">  343</span>&#160;      <span class="keyword">const</span> <a 
class="code" href="classOption.html">Option&lt;InverseOfferStatus&gt;</a>&amp; 
<a class="code" href="namespaceproc.html#a34396c6140a
 28f583dc13fee3c3c35d4">status</a>,</div><div class="line"><a 
name="l00344"></a><span class="lineno">  344</span>&#160;      <span 
class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;Filters&gt;</a>&amp; <a class="code" 
href="namespacerouting_1_1filter_1_1internal.html#a646d4e3238d83329525957b5a5586be2">filters</a>
 = <a class="code" href="structNone.html">None</a>()) = 0;</div><div 
class="line"><a name="l00345"></a><span class="lineno">  
345</span>&#160;</div><div class="line"><a name="l00349"></a><span 
class="lineno">  349</span>&#160;  <span class="keyword">virtual</span> <a 
class="code" 
href="classprocess_1_1Future.html">process::Future</a>&lt;</div><div 
class="line"><a name="l00350"></a><span class="lineno">  350</span>&#160;      
<a class="code" href="classhashmap.html">hashmap</a>&lt;SlaveID,</div><div 
class="line"><a name="l00351"></a><span class="lineno">  351</span>&#160;       
       <a class="code" href="classhashmap.html">hashmap&lt;FrameworkID,
  mesos::allocator::InverseOfferStatus&gt;</a>&gt;&gt;</div><div 
class="line"><a name="l00352"></a><span class="lineno">  352</span>&#160;    <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#af09ffe12fe6dce0bb115d9988ddb61d1">getInverseOfferStatuses</a>()
 = 0;</div><div class="line"><a name="l00353"></a><span class="lineno">  
353</span>&#160;</div><div class="line"><a name="l00367"></a><span 
class="lineno">  367</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a9719d532d6e866956062a3d8ad437781">recoverResources</a>(</div><div
 class="line"><a name="l00368"></a><span class="lineno">  368</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00369"></a><span class="lineno">  369</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId,</div><div 
class="line"><a name="l00370"></a><span class="
 lineno">  370</span>&#160;      <span class="keyword">const</span> <a 
class="code" href="classmesos_1_1Resources.html">Resources</a>&amp; 
resources,</div><div class="line"><a name="l00371"></a><span class="lineno">  
371</span>&#160;      <span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;Filters&gt;</a>&amp; <a class="code" 
href="namespacerouting_1_1filter_1_1internal.html#a646d4e3238d83329525957b5a5586be2">filters</a>)
 = 0;</div><div class="line"><a name="l00372"></a><span class="lineno">  
372</span>&#160;</div><div class="line"><a name="l00380"></a><span 
class="lineno">  380</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a491f49ba873d0b8c56d45526984cd4d9">suppressOffers</a>(</div><div
 class="line"><a name="l00381"></a><span class="lineno">  381</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="
 line"><a name="l00382"></a><span class="lineno">  382</span>&#160;      <span 
class="keyword">const</span> std::set&lt;std::string&gt;&amp; roles) = 
0;</div><div class="line"><a name="l00383"></a><span class="lineno">  
383</span>&#160;</div><div class="line"><a name="l00391"></a><span 
class="lineno">  391</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a0bf4c3ba18d950c34ef16de989155b0e">reviveOffers</a>(</div><div
 class="line"><a name="l00392"></a><span class="lineno">  392</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00393"></a><span class="lineno">  393</span>&#160;      
<span class="keyword">const</span> std::set&lt;std::string&gt;&amp; roles) = 
0;</div><div class="line"><a name="l00394"></a><span class="lineno">  
394</span>&#160;</div><div class="line"><a name="l00413"></a><span 
class="lineno">  413</span>
 &#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a06d46d24d46f7c9858ab58c027ecc7ca">setQuota</a>(</div><div
 class="line"><a name="l00414"></a><span class="lineno">  414</span>&#160;      
<span class="keyword">const</span> std::string&amp; role,</div><div 
class="line"><a name="l00415"></a><span class="lineno">  415</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="structQuota.html">Quota</a>&amp; quota) = 0;</div><div class="line"><a 
name="l00416"></a><span class="lineno">  416</span>&#160;</div><div 
class="line"><a name="l00431"></a><span class="lineno">  431</span>&#160;  
<span class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a7c4fb581525a58eaea748afaa87ccb40">removeQuota</a>(</div><div
 class="line"><a name="l00432"></a><span class="lineno">  432</span>&#160;      
<span class="k
 eyword">const</span> std::string&amp; role) = 0;</div><div class="line"><a 
name="l00433"></a><span class="lineno">  433</span>&#160;</div><div 
class="line"><a name="l00439"></a><span class="lineno">  439</span>&#160;  
<span class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a36ed11fe06b6565b72c57ee9a88439f5">updateWeights</a>(</div><div
 class="line"><a name="l00440"></a><span class="lineno">  440</span>&#160;      
<span class="keyword">const</span> std::vector&lt;WeightInfo&gt;&amp; 
weightInfos) = 0;</div><div class="line"><a name="l00441"></a><span 
class="lineno">  441</span>&#160;};</div><div class="line"><a 
name="l00442"></a><span class="lineno">  442</span>&#160;</div><div 
class="line"><a name="l00443"></a><span class="lineno">  443</span>&#160;} 
<span class="comment">// namespace allocator {</span></div><div class="line"><a 
name="l00444"></a><span class="lineno">  444</span>&#160;} <span class="co
 mment">// namespace mesos {</span></div><div class="line"><a 
name="l00445"></a><span class="lineno">  445</span>&#160;</div><div 
class="line"><a name="l00446"></a><span class="lineno">  446</span>&#160;<span 
class="preprocessor">#endif // __MESOS_MASTER_ALLOCATOR_HPP__</span></div><div 
class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_aafc715605c23a31dcb511a6b5c2ac883"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#aafc715605c23a31dcb511a6b5c2ac883">mesos::allocator::Allocator::Allocator</a></div><div
 class="ttdeci">Allocator()</div><div class="ttdef"><b>Definition:</b> 
allocator.hpp:73</div></div>
+<a href="include_2mesos_2allocator_2allocator_8hpp.html">Go to the 
documentation of this file.</a><div class="fragment"><div class="line"><a 
name="l00001"></a><span class="lineno">    1</span>&#160;<span 
class="comment">// Licensed to the Apache Software Foundation (ASF) under 
one</span></div><div class="line"><a name="l00002"></a><span class="lineno">    
2</span>&#160;<span class="comment">// or more contributor license agreements.  
See the NOTICE file</span></div><div class="line"><a name="l00003"></a><span 
class="lineno">    3</span>&#160;<span class="comment">// distributed with this 
work for additional information</span></div><div class="line"><a 
name="l00004"></a><span class="lineno">    4</span>&#160;<span 
class="comment">// regarding copyright ownership.  The ASF licenses this 
file</span></div><div class="line"><a name="l00005"></a><span class="lineno">   
 5</span>&#160;<span class="comment">// to you under the Apache License, 
Version 2.0 (the</span></div><div class="line"><
 a name="l00006"></a><span class="lineno">    6</span>&#160;<span 
class="comment">// &quot;License&quot;); you may not use this file except in 
compliance</span></div><div class="line"><a name="l00007"></a><span 
class="lineno">    7</span>&#160;<span class="comment">// with the License.  
You may obtain a copy of the License at</span></div><div class="line"><a 
name="l00008"></a><span class="lineno">    8</span>&#160;<span 
class="comment">//</span></div><div class="line"><a name="l00009"></a><span 
class="lineno">    9</span>&#160;<span class="comment">//     
http://www.apache.org/licenses/LICENSE-2.0</span></div><div class="line"><a 
name="l00010"></a><span class="lineno">   10</span>&#160;<span 
class="comment">//</span></div><div class="line"><a name="l00011"></a><span 
class="lineno">   11</span>&#160;<span class="comment">// Unless required by 
applicable law or agreed to in writing, software</span></div><div 
class="line"><a name="l00012"></a><span class="lineno">   12</span>&#160;<span
  class="comment">// distributed under the License is distributed on an 
&quot;AS IS&quot; BASIS,</span></div><div class="line"><a 
name="l00013"></a><span class="lineno">   13</span>&#160;<span 
class="comment">// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express 
or implied.</span></div><div class="line"><a name="l00014"></a><span 
class="lineno">   14</span>&#160;<span class="comment">// See the License for 
the specific language governing permissions and</span></div><div 
class="line"><a name="l00015"></a><span class="lineno">   15</span>&#160;<span 
class="comment">// limitations under the License.</span></div><div 
class="line"><a name="l00016"></a><span class="lineno">   
16</span>&#160;</div><div class="line"><a name="l00017"></a><span 
class="lineno">   17</span>&#160;<span class="preprocessor">#ifndef 
__MESOS_ALLOCATOR_ALLOCATOR_HPP__</span></div><div class="line"><a 
name="l00018"></a><span class="lineno">   18</span>&#160;<span 
class="preprocessor">#define __MESOS_ALLOCATO
 R_ALLOCATOR_HPP__</span></div><div class="line"><a name="l00019"></a><span 
class="lineno">   19</span>&#160;</div><div class="line"><a 
name="l00020"></a><span class="lineno">   20</span>&#160;<span 
class="preprocessor">#include &lt;string&gt;</span></div><div class="line"><a 
name="l00021"></a><span class="lineno">   21</span>&#160;<span 
class="preprocessor">#include &lt;vector&gt;</span></div><div class="line"><a 
name="l00022"></a><span class="lineno">   22</span>&#160;</div><div 
class="line"><a name="l00023"></a><span class="lineno">   23</span>&#160;<span 
class="comment">// ONLY USEFUL AFTER RUNNING PROTOC.</span></div><div 
class="line"><a name="l00024"></a><span class="lineno">   24</span>&#160;<span 
class="preprocessor">#include 
&lt;mesos/allocator/allocator.pb.h&gt;</span></div><div class="line"><a 
name="l00025"></a><span class="lineno">   25</span>&#160;</div><div 
class="line"><a name="l00026"></a><span class="lineno">   26</span>&#160;<span 
class="preprocessor">#include &lt;<
 a class="code" 
href="include_2mesos_2maintenance_2maintenance_8hpp.html">mesos/maintenance/maintenance.hpp</a>&gt;</span></div><div
 class="line"><a name="l00027"></a><span class="lineno">   
27</span>&#160;</div><div class="line"><a name="l00028"></a><span 
class="lineno">   28</span>&#160;<span class="preprocessor">#include &lt;<a 
class="code" 
href="include_2mesos_2quota_2quota_8hpp.html">mesos/quota/quota.hpp</a>&gt;</span></div><div
 class="line"><a name="l00029"></a><span class="lineno">   
29</span>&#160;</div><div class="line"><a name="l00030"></a><span 
class="lineno">   30</span>&#160;<span class="preprocessor">#include &lt;<a 
class="code" 
href="resources_8hpp.html">mesos/resources.hpp</a>&gt;</span></div><div 
class="line"><a name="l00031"></a><span class="lineno">   
31</span>&#160;</div><div class="line"><a name="l00032"></a><span 
class="lineno">   32</span>&#160;<span class="preprocessor">#include &lt;<a 
class="code" href="future_8hpp.html">process/future.hpp</a>&gt;</span></di
 v><div class="line"><a name="l00033"></a><span class="lineno">   
33</span>&#160;</div><div class="line"><a name="l00034"></a><span 
class="lineno">   34</span>&#160;<span class="preprocessor">#include &lt;<a 
class="code" 
href="duration_8hpp.html">stout/duration.hpp</a>&gt;</span></div><div 
class="line"><a name="l00035"></a><span class="lineno">   35</span>&#160;<span 
class="preprocessor">#include &lt;<a class="code" 
href="hashmap_8hpp.html">stout/hashmap.hpp</a>&gt;</span></div><div 
class="line"><a name="l00036"></a><span class="lineno">   36</span>&#160;<span 
class="preprocessor">#include &lt;<a class="code" 
href="hashset_8hpp.html">stout/hashset.hpp</a>&gt;</span></div><div 
class="line"><a name="l00037"></a><span class="lineno">   37</span>&#160;<span 
class="preprocessor">#include &lt;<a class="code" 
href="lambda_8hpp.html">stout/lambda.hpp</a>&gt;</span></div><div 
class="line"><a name="l00038"></a><span class="lineno">   38</span>&#160;<span 
class="preprocessor">#include &lt;<a cl
 ass="code" href="option_8hpp.html">stout/option.hpp</a>&gt;</span></div><div 
class="line"><a name="l00039"></a><span class="lineno">   39</span>&#160;<span 
class="preprocessor">#include &lt;<a class="code" 
href="try_8hpp.html">stout/try.hpp</a>&gt;</span></div><div class="line"><a 
name="l00040"></a><span class="lineno">   40</span>&#160;</div><div 
class="line"><a name="l00041"></a><span class="lineno">   41</span>&#160;<span 
class="keyword">namespace </span><a class="code" 
href="namespacemesos.html">mesos</a> {</div><div class="line"><a 
name="l00042"></a><span class="lineno"><a class="line" 
href="namespacemesos_1_1allocator.html">   42</a></span>&#160;<span 
class="keyword">namespace </span>allocator {</div><div class="line"><a 
name="l00043"></a><span class="lineno">   43</span>&#160;</div><div 
class="line"><a name="l00055"></a><span class="lineno"><a class="line" 
href="classmesos_1_1allocator_1_1Allocator.html">   55</a></span>&#160;<span 
class="keyword">class </span><a class="code"
  href="classmesos_1_1allocator_1_1Allocator.html">Allocator</a></div><div 
class="line"><a name="l00056"></a><span class="lineno">   
56</span>&#160;{</div><div class="line"><a name="l00057"></a><span 
class="lineno">   57</span>&#160;<span class="keyword">public</span>:</div><div 
class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;  
<span class="keyword">static</span> <a class="code" 
href="classTry.html">Try&lt;Allocator*&gt;</a> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#ae5b969c74d1dc42b98b35a81d571b3fa">create</a>(</div><div
 class="line"><a name="l00069"></a><span class="lineno">   69</span>&#160;      
<span class="keyword">const</span> std::string&amp; <a class="code" 
href="namespaceos_1_1Shell.html#acfe16ef2b1146ad49a8651c0a457ce46">name</a>,</div><div
 class="line"><a name="l00070"></a><span class="lineno">   70</span>&#160;      
<span class="keyword">const</span> std::string&amp; roleSorter,</div><div 
class="line"><a name="l00071"></a><s
 pan class="lineno">   71</span>&#160;      <span class="keyword">const</span> 
std::string&amp; frameworkSorter);</div><div class="line"><a 
name="l00072"></a><span class="lineno">   72</span>&#160;</div><div 
class="line"><a name="l00073"></a><span class="lineno"><a class="line" 
href="classmesos_1_1allocator_1_1Allocator.html#aafc715605c23a31dcb511a6b5c2ac883">
   73</a></span>&#160;  <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#aafc715605c23a31dcb511a6b5c2ac883">Allocator</a>()
 {}</div><div class="line"><a name="l00074"></a><span class="lineno">   
74</span>&#160;</div><div class="line"><a name="l00075"></a><span 
class="lineno"><a class="line" 
href="classmesos_1_1allocator_1_1Allocator.html#a8b32e61251f0e0cbc9588c04e98347a3">
   75</a></span>&#160;  <span class="keyword">virtual</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a8b32e61251f0e0cbc9588c04e98347a3">~Allocator</a>()
 {}</div><div class="line"><a name="l00076"></a><span class="lineno"> 
   76</span>&#160;</div><div class="line"><a name="l00091"></a><span 
class="lineno">   91</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a046d44b884a5213c8b96aaa1e1bd1882">initialize</a>(</div><div
 class="line"><a name="l00092"></a><span class="lineno">   92</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classDuration.html">Duration</a>&amp; allocationInterval,</div><div 
class="line"><a name="l00093"></a><span class="lineno">   93</span>&#160;      
<span class="keyword">const</span> lambda::function&lt;</div><div 
class="line"><a name="l00094"></a><span class="lineno">   94</span>&#160;       
   <span class="keywordtype">void</span>(<span class="keyword">const</span> 
FrameworkID&amp;,</div><div class="line"><a name="l00095"></a><span 
class="lineno">   95</span>&#160;               <span 
class="keyword">const</span> <a class="code" href="classhashmap.htm
 l">hashmap</a>&lt;std::string, <a class="code" 
href="classhashmap.html">hashmap&lt;SlaveID, 
Resources&gt;</a>&gt;&amp;)&gt;&amp;</div><div class="line"><a 
name="l00096"></a><span class="lineno">   96</span>&#160;                   
offerCallback,</div><div class="line"><a name="l00097"></a><span 
class="lineno">   97</span>&#160;      <span class="keyword">const</span> 
lambda::function&lt;</div><div class="line"><a name="l00098"></a><span 
class="lineno">   98</span>&#160;          <span 
class="keywordtype">void</span>(<span class="keyword">const</span> 
FrameworkID&amp;,</div><div class="line"><a name="l00099"></a><span 
class="lineno">   99</span>&#160;               <span 
class="keyword">const</span> <a class="code" 
href="classhashmap.html">hashmap&lt;SlaveID, 
UnavailableResources&gt;</a>&amp;)&gt;&amp;</div><div class="line"><a 
name="l00100"></a><span class="lineno">  100</span>&#160;        
inverseOfferCallback,</div><div class="line"><a name="l00101"></a><span 
class="lineno">  101<
 /span>&#160;      <span class="keyword">const</span> <a class="code" 
href="classOption.html">Option</a>&lt;std::set&lt;std::string&gt;&gt;&amp;</div><div
 class="line"><a name="l00102"></a><span class="lineno">  102</span>&#160;      
  fairnessExcludeResourceNames = <a class="code" 
href="structNone.html">None</a>(),</div><div class="line"><a 
name="l00103"></a><span class="lineno">  103</span>&#160;      <span 
class="keywordtype">bool</span> filterGpuResources = <span 
class="keyword">true</span>,</div><div class="line"><a name="l00104"></a><span 
class="lineno">  104</span>&#160;      <span class="keyword">const</span> <a 
class="code" href="classOption.html">Option&lt;DomainInfo&gt;</a>&amp; domain = 
<a class="code" href="structNone.html">None</a>(),</div><div class="line"><a 
name="l00105"></a><span class="lineno">  105</span>&#160;      <span 
class="keyword">const</span> <a class="code" 
href="classOption.html">Option</a>&lt;std::vector&lt;Resources&gt;&gt;&amp;</div><div
 class="line">
 <a name="l00106"></a><span class="lineno">  106</span>&#160;        
minAllocatableResources = <a class="code" 
href="structNone.html">None</a>(),</div><div class="line"><a 
name="l00107"></a><span class="lineno">  107</span>&#160;      <span 
class="keyword">const</span> <span class="keywordtype">size_t</span> 
maxCompletedFrameworks = 0) = 0;</div><div class="line"><a 
name="l00108"></a><span class="lineno">  108</span>&#160;</div><div 
class="line"><a name="l00122"></a><span class="lineno">  122</span>&#160;  
<span class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#abe1f158adb9f7a6d7cc9f8afae44e859">recover</a>(</div><div
 class="line"><a name="l00123"></a><span class="lineno">  123</span>&#160;      
<span class="keyword">const</span> <span class="keywordtype">int</span> 
expectedAgentCount,</div><div class="line"><a name="l00124"></a><span 
class="lineno">  124</span>&#160;      <span class="keyword">const</
 span> <a class="code" href="classhashmap.html">hashmap&lt;std::string, 
Quota&gt;</a>&amp; quotas) = 0;</div><div class="line"><a 
name="l00125"></a><span class="lineno">  125</span>&#160;</div><div 
class="line"><a name="l00140"></a><span class="lineno">  140</span>&#160;  
<span class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a681883278b64d1e45fc515a7899a3d99">addFramework</a>(</div><div
 class="line"><a name="l00141"></a><span class="lineno">  141</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00142"></a><span class="lineno">  142</span>&#160;      
<span class="keyword">const</span> FrameworkInfo&amp; frameworkInfo,</div><div 
class="line"><a name="l00143"></a><span class="lineno">  143</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classhashmap.html">hashmap&lt;SlaveID, Resources&gt;</a>&amp; 
used,</div><d
 iv class="line"><a name="l00144"></a><span class="lineno">  144</span>&#160;   
   <span class="keywordtype">bool</span> active,</div><div class="line"><a 
name="l00145"></a><span class="lineno">  145</span>&#160;      <span 
class="keyword">const</span> std::set&lt;std::string&gt;&amp; suppressedRoles) 
= 0;</div><div class="line"><a name="l00146"></a><span class="lineno">  
146</span>&#160;</div><div class="line"><a name="l00152"></a><span 
class="lineno">  152</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#ac58e3a3025d3887ab1ab9267c9093188">removeFramework</a>(</div><div
 class="line"><a name="l00153"></a><span class="lineno">  153</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId) = 0;</div><div 
class="line"><a name="l00154"></a><span class="lineno">  
154</span>&#160;</div><div class="line"><a name="l00159"></a><span 
class="lineno">  159</span>&#160;
   <span class="keyword">virtual</span> <span class="keywordtype">void</span> 
<a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a60b5e4ab25ef87eb74763c10cfc21850">activateFramework</a>(</div><div
 class="line"><a name="l00160"></a><span class="lineno">  160</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId) = 0;</div><div 
class="line"><a name="l00161"></a><span class="lineno">  
161</span>&#160;</div><div class="line"><a name="l00166"></a><span 
class="lineno">  166</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#afe9d8fc901322dde7d91037930c77f72">deactivateFramework</a>(</div><div
 class="line"><a name="l00167"></a><span class="lineno">  167</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId) = 0;</div><div 
class="line"><a name="l00168"></a><span class="lineno">  
168</span>&#160;</div><div class="line"><a na
 me="l00179"></a><span class="lineno">  179</span>&#160;  <span 
class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a97eadff5ba5f1b25beeb2b99e7ed72bb">updateFramework</a>(</div><div
 class="line"><a name="l00180"></a><span class="lineno">  180</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00181"></a><span class="lineno">  181</span>&#160;      
<span class="keyword">const</span> FrameworkInfo&amp; frameworkInfo,</div><div 
class="line"><a name="l00182"></a><span class="lineno">  182</span>&#160;      
<span class="keyword">const</span> std::set&lt;std::string&gt;&amp; 
suppressedRoles) = 0;</div><div class="line"><a name="l00183"></a><span 
class="lineno">  183</span>&#160;</div><div class="line"><a 
name="l00199"></a><span class="lineno">  199</span>&#160;  <span 
class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="
 code" 
href="classmesos_1_1allocator_1_1Allocator.html#a12346eed9894458805e180b9d6cb6424">addSlave</a>(</div><div
 class="line"><a name="l00200"></a><span class="lineno">  200</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId,</div><div 
class="line"><a name="l00201"></a><span class="lineno">  201</span>&#160;      
<span class="keyword">const</span> SlaveInfo&amp; slaveInfo,</div><div 
class="line"><a name="l00202"></a><span class="lineno">  202</span>&#160;      
<span class="keyword">const</span> 
std::vector&lt;SlaveInfo::Capability&gt;&amp; capabilities,</div><div 
class="line"><a name="l00203"></a><span class="lineno">  203</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;Unavailability&gt;</a>&amp; <a class="code" 
href="namespacemesos_1_1internal_1_1master_1_1maintenance_1_1validation.html#a766d3749f894fce457b084746f0ba868">unavailability</a>,</div><div
 class="line"><a name="l00204"></a><span class="lineno"
 >  204</span>&#160;      <span class="keyword">const</span> <a class="code" 
 > href="classmesos_1_1Resources.html">Resources</a>&amp; total,</div><div 
 > class="line"><a name="l00205"></a><span class="lineno">  205</span>&#160;    
 >   <span class="keyword">const</span> <a class="code" 
 > href="classhashmap.html">hashmap&lt;FrameworkID, Resources&gt;</a>&amp; 
 > used) = 0;</div><div class="line"><a name="l00206"></a><span class="lineno"> 
 >  206</span>&#160;</div><div class="line"><a name="l00211"></a><span 
 > class="lineno">  211</span>&#160;  <span class="keyword">virtual</span> 
 > <span class="keywordtype">void</span> <a class="code" 
 > href="classmesos_1_1allocator_1_1Allocator.html#a7193bcacb52eaec201bf88e95f03acad">removeSlave</a>(</div><div
 >  class="line"><a name="l00212"></a><span class="lineno">  212</span>&#160;   
 >    <span class="keyword">const</span> SlaveID&amp; slaveId) = 0;</div><div 
 > class="line"><a name="l00213"></a><span class="lineno">  
 > 213</span>&#160;</div><div class="line"><a name="l00223"><
 /a><span class="lineno">  223</span>&#160;  <span 
class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#ad30279420381616f523418812beb798f">updateSlave</a>(</div><div
 class="line"><a name="l00224"></a><span class="lineno">  224</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slave,</div><div 
class="line"><a name="l00225"></a><span class="lineno">  225</span>&#160;      
<span class="keyword">const</span> SlaveInfo&amp; slaveInfo,</div><div 
class="line"><a name="l00226"></a><span class="lineno">  226</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;Resources&gt;</a>&amp; total = <a 
class="code" href="structNone.html">None</a>(),</div><div class="line"><a 
name="l00227"></a><span class="lineno">  227</span>&#160;      <span 
class="keyword">const</span> <a class="code" 
href="classOption.html">Option</a>&lt;std::vector&lt;SlaveInfo::Capabili
 ty&gt;&gt;&amp;</div><div class="line"><a name="l00228"></a><span 
class="lineno">  228</span>&#160;          capabilities = <a class="code" 
href="structNone.html">None</a>()) = 0;</div><div class="line"><a 
name="l00229"></a><span class="lineno">  229</span>&#160;</div><div 
class="line"><a name="l00238"></a><span class="lineno">  238</span>&#160;  
<span class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#ad873c196dc884fb2ccc116964157d7ff">addResourceProvider</a>(</div><div
 class="line"><a name="l00239"></a><span class="lineno">  239</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slave,</div><div 
class="line"><a name="l00240"></a><span class="lineno">  240</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classmesos_1_1Resources.html">Resources</a>&amp; total,</div><div 
class="line"><a name="l00241"></a><span class="lineno">  241</span>&#160;      
<span class="k
 eyword">const</span> <a class="code" 
href="classhashmap.html">hashmap&lt;FrameworkID, Resources&gt;</a>&amp; used) = 
0;</div><div class="line"><a name="l00242"></a><span class="lineno">  
242</span>&#160;</div><div class="line"><a name="l00247"></a><span 
class="lineno">  247</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a2469bc7c28ab20a86cd2d198dd99e2cd">activateSlave</a>(</div><div
 class="line"><a name="l00248"></a><span class="lineno">  248</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId) = 0;</div><div 
class="line"><a name="l00249"></a><span class="lineno">  
249</span>&#160;</div><div class="line"><a name="l00258"></a><span 
class="lineno">  258</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a4dff6ddc4983c5495eb2fc26e2842114">deactivateSlave</a>(<
 /div><div class="line"><a name="l00259"></a><span class="lineno">  
259</span>&#160;      <span class="keyword">const</span> SlaveID&amp; slaveId) 
= 0;</div><div class="line"><a name="l00260"></a><span class="lineno">  
260</span>&#160;</div><div class="line"><a name="l00269"></a><span 
class="lineno">  269</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a961049fd776211cc762ad0e1e1c99321">updateWhitelist</a>(</div><div
 class="line"><a name="l00270"></a><span class="lineno">  270</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option</a>&lt;<a class="code" 
href="classhashset.html">hashset&lt;std::string&gt;</a>&gt;&amp; whitelist) = 
0;</div><div class="line"><a name="l00271"></a><span class="lineno">  
271</span>&#160;</div><div class="line"><a name="l00279"></a><span 
class="lineno">  279</span>&#160;  <span class="keyword">virtual</span> <
 span class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a6d1124aace866719ed1e9ed45a068412">requestResources</a>(</div><div
 class="line"><a name="l00280"></a><span class="lineno">  280</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00281"></a><span class="lineno">  281</span>&#160;      
<span class="keyword">const</span> std::vector&lt;Request&gt;&amp; requests) = 
0;</div><div class="line"><a name="l00282"></a><span class="lineno">  
282</span>&#160;</div><div class="line"><a name="l00293"></a><span 
class="lineno">  293</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#aa8ee61bea88a926c920e909571f836dd">updateAllocation</a>(</div><div
 class="line"><a name="l00294"></a><span class="lineno">  294</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; framewor
 kId,</div><div class="line"><a name="l00295"></a><span class="lineno">  
295</span>&#160;      <span class="keyword">const</span> SlaveID&amp; 
slaveId,</div><div class="line"><a name="l00296"></a><span class="lineno">  
296</span>&#160;      <span class="keyword">const</span> <a class="code" 
href="classmesos_1_1Resources.html">Resources</a>&amp; 
offeredResources,</div><div class="line"><a name="l00297"></a><span 
class="lineno">  297</span>&#160;      <span class="keyword">const</span> 
std::vector&lt;ResourceConversion&gt;&amp; conversions) = 0;</div><div 
class="line"><a name="l00298"></a><span class="lineno">  
298</span>&#160;</div><div class="line"><a name="l00306"></a><span 
class="lineno">  306</span>&#160;  <span class="keyword">virtual</span> <a 
class="code" 
href="classprocess_1_1Future.html">process::Future&lt;Nothing&gt;</a> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a997ec43933a7659b683d83c164bdd6db">updateAvailable</a>(</div><div
 class="line"><a name="l003
 07"></a><span class="lineno">  307</span>&#160;      <span 
class="keyword">const</span> SlaveID&amp; slaveId,</div><div class="line"><a 
name="l00308"></a><span class="lineno">  308</span>&#160;      <span 
class="keyword">const</span> std::vector&lt;Offer::Operation&gt;&amp; 
operations) = 0;</div><div class="line"><a name="l00309"></a><span 
class="lineno">  309</span>&#160;</div><div class="line"><a 
name="l00318"></a><span class="lineno">  318</span>&#160;  <span 
class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a455bb50eb4548484969c42ada23cd8ff">updateUnavailability</a>(</div><div
 class="line"><a name="l00319"></a><span class="lineno">  319</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId,</div><div 
class="line"><a name="l00320"></a><span class="lineno">  320</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;Unavailability&g
 t;</a>&amp; unavailability) = 0;</div><div class="line"><a 
name="l00321"></a><span class="lineno">  321</span>&#160;</div><div 
class="line"><a name="l00340"></a><span class="lineno">  340</span>&#160;  
<span class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a9b03a500abdf2f677f3fd9ea958d0690">updateInverseOffer</a>(</div><div
 class="line"><a name="l00341"></a><span class="lineno">  341</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId,</div><div 
class="line"><a name="l00342"></a><span class="lineno">  342</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
class="line"><a name="l00343"></a><span class="lineno">  343</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;UnavailableResources&gt;</a>&amp; 
unavailableResources,</div><div class="line"><a name="l00344"></a><span 
class="lineno">  
 344</span>&#160;      <span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;InverseOfferStatus&gt;</a>&amp; <a 
class="code" 
href="namespaceproc.html#a34396c6140a28f583dc13fee3c3c35d4">status</a>,</div><div
 class="line"><a name="l00345"></a><span class="lineno">  345</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;Filters&gt;</a>&amp; <a class="code" 
href="namespacerouting_1_1filter_1_1internal.html#a646d4e3238d83329525957b5a5586be2">filters</a>
 = <a class="code" href="structNone.html">None</a>()) = 0;</div><div 
class="line"><a name="l00346"></a><span class="lineno">  
346</span>&#160;</div><div class="line"><a name="l00350"></a><span 
class="lineno">  350</span>&#160;  <span class="keyword">virtual</span> <a 
class="code" 
href="classprocess_1_1Future.html">process::Future</a>&lt;</div><div 
class="line"><a name="l00351"></a><span class="lineno">  351</span>&#160;      
<a class="code" href="classhashmap
 .html">hashmap</a>&lt;SlaveID,</div><div class="line"><a 
name="l00352"></a><span class="lineno">  352</span>&#160;              <a 
class="code" href="classhashmap.html">hashmap&lt;FrameworkID, 
mesos::allocator::InverseOfferStatus&gt;</a>&gt;&gt;</div><div class="line"><a 
name="l00353"></a><span class="lineno">  353</span>&#160;    <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#af09ffe12fe6dce0bb115d9988ddb61d1">getInverseOfferStatuses</a>()
 = 0;</div><div class="line"><a name="l00354"></a><span class="lineno">  
354</span>&#160;</div><div class="line"><a name="l00368"></a><span 
class="lineno">  368</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a9719d532d6e866956062a3d8ad437781">recoverResources</a>(</div><div
 class="line"><a name="l00369"></a><span class="lineno">  369</span>&#160;      
<span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div c
 lass="line"><a name="l00370"></a><span class="lineno">  370</span>&#160;      
<span class="keyword">const</span> SlaveID&amp; slaveId,</div><div 
class="line"><a name="l00371"></a><span class="lineno">  371</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classmesos_1_1Resources.html">Resources</a>&amp; resources,</div><div 
class="line"><a name="l00372"></a><span class="lineno">  372</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="classOption.html">Option&lt;Filters&gt;</a>&amp; <a class="code" 
href="namespacerouting_1_1filter_1_1internal.html#a646d4e3238d83329525957b5a5586be2">filters</a>)
 = 0;</div><div class="line"><a name="l00373"></a><span class="lineno">  
373</span>&#160;</div><div class="line"><a name="l00381"></a><span 
class="lineno">  381</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a491f49ba873d0b8c56d45526984cd4d9"
 >suppressOffers</a>(</div><div class="line"><a name="l00382"></a><span 
 >class="lineno">  382</span>&#160;      <span class="keyword">const</span> 
 >FrameworkID&amp; frameworkId,</div><div class="line"><a 
 >name="l00383"></a><span class="lineno">  383</span>&#160;      <span 
 >class="keyword">const</span> std::set&lt;std::string&gt;&amp; roles) = 
 >0;</div><div class="line"><a name="l00384"></a><span class="lineno">  
 >384</span>&#160;</div><div class="line"><a name="l00392"></a><span 
 >class="lineno">  392</span>&#160;  <span class="keyword">virtual</span> <span 
 >class="keywordtype">void</span> <a class="code" 
 >href="classmesos_1_1allocator_1_1Allocator.html#a0bf4c3ba18d950c34ef16de989155b0e">reviveOffers</a>(</div><div
 > class="line"><a name="l00393"></a><span class="lineno">  393</span>&#160;    
 >  <span class="keyword">const</span> FrameworkID&amp; frameworkId,</div><div 
 >class="line"><a name="l00394"></a><span class="lineno">  394</span>&#160;     
 > <span class="keyword">const</span> std::set&lt;st
 d::string&gt;&amp; roles) = 0;</div><div class="line"><a 
name="l00395"></a><span class="lineno">  395</span>&#160;</div><div 
class="line"><a name="l00414"></a><span class="lineno">  414</span>&#160;  
<span class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a06d46d24d46f7c9858ab58c027ecc7ca">setQuota</a>(</div><div
 class="line"><a name="l00415"></a><span class="lineno">  415</span>&#160;      
<span class="keyword">const</span> std::string&amp; role,</div><div 
class="line"><a name="l00416"></a><span class="lineno">  416</span>&#160;      
<span class="keyword">const</span> <a class="code" 
href="structQuota.html">Quota</a>&amp; quota) = 0;</div><div class="line"><a 
name="l00417"></a><span class="lineno">  417</span>&#160;</div><div 
class="line"><a name="l00432"></a><span class="lineno">  432</span>&#160;  
<span class="keyword">virtual</span> <span class="keywordtype">void</span> <a 
class="code" href="class
 
mesos_1_1allocator_1_1Allocator.html#a7c4fb581525a58eaea748afaa87ccb40">removeQuota</a>(</div><div
 class="line"><a name="l00433"></a><span class="lineno">  433</span>&#160;      
<span class="keyword">const</span> std::string&amp; role) = 0;</div><div 
class="line"><a name="l00434"></a><span class="lineno">  
434</span>&#160;</div><div class="line"><a name="l00440"></a><span 
class="lineno">  440</span>&#160;  <span class="keyword">virtual</span> <span 
class="keywordtype">void</span> <a class="code" 
href="classmesos_1_1allocator_1_1Allocator.html#a36ed11fe06b6565b72c57ee9a88439f5">updateWeights</a>(</div><div
 class="line"><a name="l00441"></a><span class="lineno">  441</span>&#160;      
<span class="keyword">const</span> std::vector&lt;WeightInfo&gt;&amp; 
weightInfos) = 0;</div><div class="line"><a name="l00442"></a><span 
class="lineno">  442</span>&#160;};</div><div class="line"><a 
name="l00443"></a><span class="lineno">  443</span>&#160;</div><div 
class="line"><a name="l00444"></a><sp
 an class="lineno">  444</span>&#160;} <span class="comment">// namespace 
allocator {</span></div><div class="line"><a name="l00445"></a><span 
class="lineno">  445</span>&#160;} <span class="comment">// namespace mesos 
{</span></div><div class="line"><a name="l00446"></a><span class="lineno">  
446</span>&#160;</div><div class="line"><a name="l00447"></a><span 
class="lineno">  447</span>&#160;<span class="preprocessor">#endif // 
__MESOS_MASTER_ALLOCATOR_HPP__</span></div><div class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_aafc715605c23a31dcb511a6b5c2ac883"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#aafc715605c23a31dcb511a6b5c2ac883">mesos::allocator::Allocator::Allocator</a></div><div
 class="ttdeci">Allocator()</div><div class="ttdef"><b>Definition:</b> 
allocator.hpp:73</div></div>
 <div class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_a9719d532d6e866956062a3d8ad437781"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#a9719d532d6e866956062a3d8ad437781">mesos::allocator::Allocator::recoverResources</a></div><div
 class="ttdeci">virtual void recoverResources(const FrameworkID 
&amp;frameworkId, const SlaveID &amp;slaveId, const Resources &amp;resources, 
const Option&lt; Filters &gt; &amp;filters)=0</div><div class="ttdoc">Recovers 
resources. </div></div>
 <div class="ttc" id="resources_8hpp_html"><div class="ttname"><a 
href="resources_8hpp.html">resources.hpp</a></div></div>
 <div class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_a7c4fb581525a58eaea748afaa87ccb40"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#a7c4fb581525a58eaea748afaa87ccb40">mesos::allocator::Allocator::removeQuota</a></div><div
 class="ttdeci">virtual void removeQuota(const std::string 
&amp;role)=0</div><div class="ttdoc">Informs the allocator to remove quota for 
the given role. </div></div>
@@ -75,12 +75,12 @@
 <div class="ttc" id="classhashmap_html"><div class="ttname"><a 
href="classhashmap.html">hashmap</a></div><div class="ttdef"><b>Definition:</b> 
hashmap.hpp:38</div></div>
 <div class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_a36ed11fe06b6565b72c57ee9a88439f5"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#a36ed11fe06b6565b72c57ee9a88439f5">mesos::allocator::Allocator::updateWeights</a></div><div
 class="ttdeci">virtual void updateWeights(const std::vector&lt; WeightInfo 
&gt; &amp;weightInfos)=0</div><div class="ttdoc">Updates the weight associated 
with one or more roles. </div></div>
 <div class="ttc" id="duration_8hpp_html"><div class="ttname"><a 
href="duration_8hpp.html">duration.hpp</a></div></div>
+<div class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_a046d44b884a5213c8b96aaa1e1bd1882"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#a046d44b884a5213c8b96aaa1e1bd1882">mesos::allocator::Allocator::initialize</a></div><div
 class="ttdeci">virtual void initialize(const Duration &amp;allocationInterval, 
const lambda::function&lt; void(const FrameworkID &amp;, const hashmap&lt; 
std::string, hashmap&lt; SlaveID, Resources &gt;&gt; &amp;)&gt; 
&amp;offerCallback, const lambda::function&lt; void(const FrameworkID &amp;, 
const hashmap&lt; SlaveID, UnavailableResources &gt; &amp;)&gt; 
&amp;inverseOfferCallback, const Option&lt; std::set&lt; std::string &gt;&gt; 
&amp;fairnessExcludeResourceNames=None(), bool filterGpuResources=true, const 
Option&lt; DomainInfo &gt; &amp;domain=None(), const Option&lt; std::vector&lt; 
Resources &gt;&gt; &amp;minAllocatableResources=None(), const size_t 
maxCompletedFrameworks=0)=0</div><div class="ttdoc">Initializes the allocat
 or when the master starts up. </div></div>
 <div class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_a7193bcacb52eaec201bf88e95f03acad"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#a7193bcacb52eaec201bf88e95f03acad">mesos::allocator::Allocator::removeSlave</a></div><div
 class="ttdeci">virtual void removeSlave(const SlaveID 
&amp;slaveId)=0</div><div class="ttdoc">Removes an agent from the Mesos 
cluster. </div></div>
 <div class="ttc" id="structQuota_html"><div class="ttname"><a 
href="structQuota.html">Quota</a></div><div class="ttdef"><b>Definition:</b> 
quota.hpp:25</div></div>
 <div class="ttc" 
id="namespacemesos_1_1internal_1_1master_1_1maintenance_1_1validation_html_a766d3749f894fce457b084746f0ba868"><div
 class="ttname"><a 
href="namespacemesos_1_1internal_1_1master_1_1maintenance_1_1validation.html#a766d3749f894fce457b084746f0ba868">mesos::internal::master::maintenance::validation::unavailability</a></div><div
 class="ttdeci">Try&lt; Nothing &gt; unavailability(const Unavailability 
&amp;unavailability)</div></div>
 <div class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_a60b5e4ab25ef87eb74763c10cfc21850"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#a60b5e4ab25ef87eb74763c10cfc21850">mesos::allocator::Allocator::activateFramework</a></div><div
 class="ttdeci">virtual void activateFramework(const FrameworkID 
&amp;frameworkId)=0</div><div class="ttdoc">Activates a framework in the Mesos 
cluster. </div></div>
 <div class="ttc" 
id="namespacerouting_1_1filter_1_1internal_html_a646d4e3238d83329525957b5a5586be2"><div
 class="ttname"><a 
href="namespacerouting_1_1filter_1_1internal.html#a646d4e3238d83329525957b5a5586be2">routing::filter::internal::filters</a></div><div
 class="ttdeci">Result&lt; std::vector&lt; Filter&lt; Classifier &gt; &gt; &gt; 
filters(const std::string &amp;_link, const Handle &amp;parent)</div><div 
class="ttdef"><b>Definition:</b> internal.hpp:776</div></div>
-<div class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_a339c1dd8fc2e84bb0b0939cdec7e2e6a"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#a339c1dd8fc2e84bb0b0939cdec7e2e6a">mesos::allocator::Allocator::initialize</a></div><div
 class="ttdeci">virtual void initialize(const Duration &amp;allocationInterval, 
const lambda::function&lt; void(const FrameworkID &amp;, const hashmap&lt; 
std::string, hashmap&lt; SlaveID, Resources &gt;&gt; &amp;)&gt; 
&amp;offerCallback, const lambda::function&lt; void(const FrameworkID &amp;, 
const hashmap&lt; SlaveID, UnavailableResources &gt; &amp;)&gt; 
&amp;inverseOfferCallback, const Option&lt; std::set&lt; std::string &gt;&gt; 
&amp;fairnessExcludeResourceNames=None(), bool filterGpuResources=true, const 
Option&lt; DomainInfo &gt; &amp;domain=None(), const Option&lt; std::vector&lt; 
Resources &gt;&gt; &amp;minAllocatableResources=None())=0</div><div 
class="ttdoc">Initializes the allocator when the master starts up. </div></d
 iv>
 <div class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_a97eadff5ba5f1b25beeb2b99e7ed72bb"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#a97eadff5ba5f1b25beeb2b99e7ed72bb">mesos::allocator::Allocator::updateFramework</a></div><div
 class="ttdeci">virtual void updateFramework(const FrameworkID 
&amp;frameworkId, const FrameworkInfo &amp;frameworkInfo, const std::set&lt; 
std::string &gt; &amp;suppressedRoles)=0</div><div class="ttdoc">Updates 
capabilities of a framework in the Mesos cluster. </div></div>
 <div class="ttc" 
id="classmesos_1_1allocator_1_1Allocator_html_a06d46d24d46f7c9858ab58c027ecc7ca"><div
 class="ttname"><a 
href="classmesos_1_1allocator_1_1Allocator.html#a06d46d24d46f7c9858ab58c027ecc7ca">mesos::allocator::Allocator::setQuota</a></div><div
 class="ttdeci">virtual void setQuota(const std::string &amp;role, const Quota 
&amp;quota)=0</div><div class="ttdoc">Informs the allocator to set quota for 
the given role. </div></div>
 <div class="ttc" id="namespacemesos_html"><div class="ttname"><a 
href="namespacemesos.html">mesos</a></div><div class="ttdef"><b>Definition:</b> 
spec.hpp:30</div></div>

Reply via email to