blob: 42fa58249cbdcf2bf91e7b765346bda2c2111679 [file] [log] [blame]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.5"/>
<title>Apache Mesos: 3rdparty/libprocess/include/process/process.hpp File Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td style="padding-left: 0.5em;">
<div id="projectname">Apache Mesos
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.5 -->
<div id="navrow1" class="tabs">
<ul class="tablist">
<li><a href="index.html"><span>Main&#160;Page</span></a></li>
<li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
<li><a href="annotated.html"><span>Classes</span></a></li>
<li class="current"><a href="files.html"><span>Files</span></a></li>
<li><a href="examples.html"><span>Examples</span></a></li>
</ul>
</div>
<div id="navrow2" class="tabs2">
<ul class="tablist">
<li><a href="files.html"><span>File&#160;List</span></a></li>
<li><a href="globals.html"><span>File&#160;Members</span></a></li>
</ul>
</div>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="dir_8cab8f464681f7cc51cee77e79a434cd.html">3rdparty</a></li><li class="navelem"><a class="el" href="dir_043a76de98701f9bddf61b5e98f305ff.html">libprocess</a></li><li class="navelem"><a class="el" href="dir_eac18f7a64f6f8afbd1493ef4e09abdb.html">include</a></li><li class="navelem"><a class="el" href="dir_1894286df79cf582d947dbc4268b06cf.html">process</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="summary">
<a href="#nested-classes">Classes</a> &#124;
<a href="#namespaces">Namespaces</a> &#124;
<a href="#func-members">Functions</a> &#124;
<a href="#var-members">Variables</a> </div>
<div class="headertitle">
<div class="title">process.hpp File Reference</div> </div>
</div><!--header-->
<div class="contents">
<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br/>
<code>#include &lt;map&gt;</code><br/>
<code>#include &lt;queue&gt;</code><br/>
<code>#include &lt;vector&gt;</code><br/>
<code>#include &lt;<a class="el" href="address_8hpp_source.html">process/address.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="3rdparty_2libprocess_2include_2process_2authenticator_8hpp_source.html">process/authenticator.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="clock_8hpp_source.html">process/clock.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="event_8hpp_source.html">process/event.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="3rdparty_2libprocess_2include_2process_2filter_8hpp_source.html">process/filter.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="firewall_8hpp_source.html">process/firewall.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="3rdparty_2libprocess_2include_2process_2http_8hpp_source.html">process/http.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="3rdparty_2libprocess_2include_2process_2message_8hpp_source.html">process/message.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="mime_8hpp_source.html">process/mime.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="owned_8hpp_source.html">process/owned.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="3rdparty_2libprocess_2include_2process_2pid_8hpp_source.html">process/pid.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="duration_8hpp_source.html">stout/duration.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="lambda_8hpp_source.html">stout/lambda.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="option_8hpp_source.html">stout/option.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="synchronized_8hpp_source.html">stout/synchronized.hpp</a>&gt;</code><br/>
<code>#include &lt;<a class="el" href="thread__local_8hpp_source.html">stout/thread_local.hpp</a>&gt;</code><br/>
</div>
<p><a href="libprocess_2include_2process_2process_8hpp_source.html">Go to the source code of this file.</a></p>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="nested-classes"></a>
Classes</h2></td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classprocess_1_1ProcessBase.html">process::ProcessBase</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structprocess_1_1ProcessBase_1_1RouteOptions.html">process::ProcessBase::RouteOptions</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classprocess_1_1Process.html">process::Process&lt; T &gt;</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="namespaces"></a>
Namespaces</h2></td></tr>
<tr class="memitem:namespaceprocess"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html">process</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:namespaceprocess_1_1firewall"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess_1_1firewall.html">process::firewall</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:namespaceprocess_1_1inject"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess_1_1inject.html">process::inject</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
Functions</h2></td></tr>
<tr class="memitem:a99a70c4d8e775bb1692693ec278d0877"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess_1_1firewall.html#a99a70c4d8e775bb1692693ec278d0877">process::firewall::install</a> (std::vector&lt; Owned&lt; FirewallRule &gt;&gt; &amp;&amp;rules)</td></tr>
<tr class="memdesc:a99a70c4d8e775bb1692693ec278d0877"><td class="mdescLeft">&#160;</td><td class="mdescRight">Install a list of firewall rules which are used to forbid incoming HTTP requests. <a href="#a99a70c4d8e775bb1692693ec278d0877">More...</a><br/></td></tr>
<tr class="separator:a99a70c4d8e775bb1692693ec278d0877"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6c9cd01950a98038b2a6df3e5066418f"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a6c9cd01950a98038b2a6df3e5066418f">process::initialize</a> (const <a class="el" href="classOption.html">Option</a>&lt; std::string &gt; &amp;delegate=<a class="el" href="structNone.html">None</a>(), const <a class="el" href="classOption.html">Option</a>&lt; std::string &gt; &amp;readwriteAuthenticationRealm=<a class="el" href="structNone.html">None</a>(), const <a class="el" href="classOption.html">Option</a>&lt; std::string &gt; &amp;readonlyAuthenticationRealm=<a class="el" href="structNone.html">None</a>())</td></tr>
<tr class="memdesc:a6c9cd01950a98038b2a6df3e5066418f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Initialize the library. <a href="#a6c9cd01950a98038b2a6df3e5066418f">More...</a><br/></td></tr>
<tr class="separator:a6c9cd01950a98038b2a6df3e5066418f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a238371634a6637198c58ea740b0890ca"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a238371634a6637198c58ea740b0890ca">process::finalize</a> (bool finalize_wsa=false)</td></tr>
<tr class="memdesc:a238371634a6637198c58ea740b0890ca"><td class="mdescLeft">&#160;</td><td class="mdescRight">Clean up the library. <a href="#a238371634a6637198c58ea740b0890ca">More...</a><br/></td></tr>
<tr class="separator:a238371634a6637198c58ea740b0890ca"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a112cf0f14ff608d490b910aab93d8e0d"><td class="memItemLeft" align="right" valign="top">std::string&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a112cf0f14ff608d490b910aab93d8e0d">process::absolutePath</a> (const std::string &amp;path)</td></tr>
<tr class="memdesc:a112cf0f14ff608d490b910aab93d8e0d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Get the request absolutePath path with delegate prefix. <a href="#a112cf0f14ff608d490b910aab93d8e0d">More...</a><br/></td></tr>
<tr class="separator:a112cf0f14ff608d490b910aab93d8e0d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:afdecc57ab065ab5d354e728d0ef0ff34"><td class="memItemLeft" align="right" valign="top">network::inet::Address&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#afdecc57ab065ab5d354e728d0ef0ff34">process::address</a> ()</td></tr>
<tr class="memdesc:afdecc57ab065ab5d354e728d0ef0ff34"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the socket address associated with this instance of the library. <a href="#afdecc57ab065ab5d354e728d0ef0ff34">More...</a><br/></td></tr>
<tr class="separator:afdecc57ab065ab5d354e728d0ef0ff34"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a283af87525d9611f5d27b9a7dd6b967e"><td class="memItemLeft" align="right" valign="top">PID&lt; Logging &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a283af87525d9611f5d27b9a7dd6b967e">process::logging</a> ()</td></tr>
<tr class="memdesc:a283af87525d9611f5d27b9a7dd6b967e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Return the <a class="el" href="structprocess_1_1PID.html" title="A &quot;process identifier&quot; used to uniquely identify a process when dispatching messages. ">PID</a> associated with the global logging process. <a href="#a283af87525d9611f5d27b9a7dd6b967e">More...</a><br/></td></tr>
<tr class="separator:a283af87525d9611f5d27b9a7dd6b967e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aff22904a83567125d3b4d0d88e5a2270"><td class="memItemLeft" align="right" valign="top">UPID&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#aff22904a83567125d3b4d0d88e5a2270">process::spawn</a> (ProcessBase *process, bool manage=false)</td></tr>
<tr class="memdesc:aff22904a83567125d3b4d0d88e5a2270"><td class="mdescLeft">&#160;</td><td class="mdescRight">Spawn a new process. <a href="#aff22904a83567125d3b4d0d88e5a2270">More...</a><br/></td></tr>
<tr class="separator:aff22904a83567125d3b4d0d88e5a2270"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa3e3f539080a94857e07401dd26b2f8f"><td class="memItemLeft" align="right" valign="top">UPID&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#aa3e3f539080a94857e07401dd26b2f8f">process::spawn</a> (ProcessBase &amp;process, bool manage=false)</td></tr>
<tr class="separator:aa3e3f539080a94857e07401dd26b2f8f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a271f92d7aab3c157b237ac5c48a0f6be"><td class="memTemplParams" colspan="2">template&lt;typename T &gt; </td></tr>
<tr class="memitem:a271f92d7aab3c157b237ac5c48a0f6be"><td class="memTemplItemLeft" align="right" valign="top">PID&lt; T &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a271f92d7aab3c157b237ac5c48a0f6be">process::spawn</a> (T *t, bool manage=false)</td></tr>
<tr class="separator:a271f92d7aab3c157b237ac5c48a0f6be"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0458ac577eb50d91c829967c1d7ca3dd"><td class="memTemplParams" colspan="2">template&lt;typename T &gt; </td></tr>
<tr class="memitem:a0458ac577eb50d91c829967c1d7ca3dd"><td class="memTemplItemLeft" align="right" valign="top">PID&lt; T &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a0458ac577eb50d91c829967c1d7ca3dd">process::spawn</a> (T &amp;t, bool manage=false)</td></tr>
<tr class="separator:a0458ac577eb50d91c829967c1d7ca3dd"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a20443908afa3212215166e26065349e5"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a20443908afa3212215166e26065349e5">process::terminate</a> (const UPID &amp;pid, bool inject=true)</td></tr>
<tr class="memdesc:a20443908afa3212215166e26065349e5"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sends a <code><a class="el" href="structprocess_1_1TerminateEvent.html">TerminateEvent</a></code> to the given process. <a href="#a20443908afa3212215166e26065349e5">More...</a><br/></td></tr>
<tr class="separator:a20443908afa3212215166e26065349e5"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab170f191c9401ac8aebe6c998f037e05"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#ab170f191c9401ac8aebe6c998f037e05">process::terminate</a> (const ProcessBase &amp;process, bool inject)</td></tr>
<tr class="memdesc:ab170f191c9401ac8aebe6c998f037e05"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sends a <code><a class="el" href="structprocess_1_1TerminateEvent.html">TerminateEvent</a></code> to the given process. <a href="#ab170f191c9401ac8aebe6c998f037e05">More...</a><br/></td></tr>
<tr class="separator:ab170f191c9401ac8aebe6c998f037e05"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad221ec78e643363af8ef18d303a2bd62"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#ad221ec78e643363af8ef18d303a2bd62">process::terminate</a> (const ProcessBase *process, bool inject)</td></tr>
<tr class="memdesc:ad221ec78e643363af8ef18d303a2bd62"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sends a <code><a class="el" href="structprocess_1_1TerminateEvent.html">TerminateEvent</a></code> to the given process. <a href="#ad221ec78e643363af8ef18d303a2bd62">More...</a><br/></td></tr>
<tr class="separator:ad221ec78e643363af8ef18d303a2bd62"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a07833fb41a8b0c1f18fa5485ca8c18d4"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a07833fb41a8b0c1f18fa5485ca8c18d4">process::wait</a> (const UPID &amp;pid, const <a class="el" href="classDuration.html">Duration</a> &amp;duration=<a class="el" href="classSeconds.html">Seconds</a>(-1))</td></tr>
<tr class="memdesc:a07833fb41a8b0c1f18fa5485ca8c18d4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wait for the process to exit for no more than the specified seconds. <a href="#a07833fb41a8b0c1f18fa5485ca8c18d4">More...</a><br/></td></tr>
<tr class="separator:a07833fb41a8b0c1f18fa5485ca8c18d4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae8b73cb98b07f3db5ebda5086a16ca37"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#ae8b73cb98b07f3db5ebda5086a16ca37">process::wait</a> (const ProcessBase &amp;process, const <a class="el" href="classDuration.html">Duration</a> &amp;duration)</td></tr>
<tr class="memdesc:ae8b73cb98b07f3db5ebda5086a16ca37"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wait for the process to exit for no more than the specified seconds. <a href="#ae8b73cb98b07f3db5ebda5086a16ca37">More...</a><br/></td></tr>
<tr class="separator:ae8b73cb98b07f3db5ebda5086a16ca37"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a40ab1ce6cd5b7a2d4aebbeae60987bb1"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a40ab1ce6cd5b7a2d4aebbeae60987bb1">process::wait</a> (const ProcessBase *process, const <a class="el" href="classDuration.html">Duration</a> &amp;duration)</td></tr>
<tr class="memdesc:a40ab1ce6cd5b7a2d4aebbeae60987bb1"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wait for the process to exit for no more than the specified seconds. <a href="#a40ab1ce6cd5b7a2d4aebbeae60987bb1">More...</a><br/></td></tr>
<tr class="separator:a40ab1ce6cd5b7a2d4aebbeae60987bb1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2b0f5478fa6a52497167aa994ff600d9"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a2b0f5478fa6a52497167aa994ff600d9">process::post</a> (const UPID &amp;to, const std::string &amp;name, const char *data=nullptr, size_t length=0)</td></tr>
<tr class="memdesc:a2b0f5478fa6a52497167aa994ff600d9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sends a message with data without a return address. <a href="#a2b0f5478fa6a52497167aa994ff600d9">More...</a><br/></td></tr>
<tr class="separator:a2b0f5478fa6a52497167aa994ff600d9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a39beeddfda71dd96bf6a5c4b59481c5d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a39beeddfda71dd96bf6a5c4b59481c5d">process::post</a> (const UPID &amp;from, const UPID &amp;to, const std::string &amp;name, const char *data=nullptr, size_t length=0)</td></tr>
<tr class="separator:a39beeddfda71dd96bf6a5c4b59481c5d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a17e94a83c103ebde55dfd48d9a6e4988"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess_1_1inject.html#a17e94a83c103ebde55dfd48d9a6e4988">process::inject::exited</a> (const UPID &amp;from, const UPID &amp;to)</td></tr>
<tr class="memdesc:a17e94a83c103ebde55dfd48d9a6e4988"><td class="mdescLeft">&#160;</td><td class="mdescRight">Simulates disconnection of the link between 'from' and 'to' by sending an <code><a class="el" href="structprocess_1_1ExitedEvent.html">ExitedEvent</a></code> to 'to'. <a href="#a17e94a83c103ebde55dfd48d9a6e4988">More...</a><br/></td></tr>
<tr class="separator:a17e94a83c103ebde55dfd48d9a6e4988"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="var-members"></a>
Variables</h2></td></tr>
<tr class="memitem:a489e728ffa4c8ab42fcca20c933e3604"><td class="memItemLeft" align="right" valign="top"><a class="el" href="thread__local_8hpp.html#af8556c37f3acfa45992b8697930c501b">THREAD_LOCAL</a> ProcessBase *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceprocess.html#a489e728ffa4c8ab42fcca20c933e3604">process::__process__</a></td></tr>
<tr class="separator:a489e728ffa4c8ab42fcca20c933e3604"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
</div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.5
</small></address>
</body>
</html>