Sophie

Sophie

distrib > Mandriva > 2010.0 > i586 > media > contrib-release > by-pkgid > dc51c7d3f8a5588a609f484ef81504ee > files > 47

libfastcgipp-devel-1.1-2mdv2010.0.i586.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>fastcgi++: Fastcgipp::Manager&lt; T &gt; Class Template Reference</title>
<link href="doxygen.css" rel="stylesheet" type="text/css">
<link href="tabs.css" rel="stylesheet" type="text/css">
</head><body>
<!-- Generated by Doxygen 1.5.6 -->
<div class="navigation" id="top">
  <div class="tabs">
    <ul>
      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
      <li><a href="namespaces.html"><span>Namespaces</span></a></li>
      <li class="current"><a href="annotated.html"><span>Classes</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
    </ul>
  </div>
  <div class="tabs">
    <ul>
      <li><a href="annotated.html"><span>Class&nbsp;List</span></a></li>
      <li><a href="hierarchy.html"><span>Class&nbsp;Hierarchy</span></a></li>
      <li><a href="functions.html"><span>Class&nbsp;Members</span></a></li>
    </ul>
  </div>
  <div class="navpath"><a class="el" href="namespaceFastcgipp.html">Fastcgipp</a>::<a class="el" href="classFastcgipp_1_1Manager.html">Manager</a>
  </div>
</div>
<div class="contents">
<h1>Fastcgipp::Manager&lt; T &gt; Class Template Reference</h1><!-- doxytag: class="Fastcgipp::Manager" -->General task and protocol management class.  
<a href="#_details">More...</a>
<p>
<code>#include &lt;<a class="el" href="manager_8hpp-source.html">manager.hpp</a>&gt;</code>
<p>

<p>
<a href="classFastcgipp_1_1Manager-members.html">List of all members.</a><table border="0" cellpadding="0" cellspacing="0">
<tr><td></td></tr>
<tr><td colspan="2"><br><h2>Public Member Functions</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#f057070411ce5f5a25575218aaa8939c">Manager</a> (int fd=0)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Construct from a file descriptor.  <a href="#f057070411ce5f5a25575218aaa8939c"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#f981c2197efc3fd9e464ae66b1868837">~Manager</a> ()</td></tr>

<tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">handler</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">General handling function to be called after construction.  <a href="#578c8468166d892d1858ad6f4d953d8d"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">push</a> (<a class="el" href="structFastcgipp_1_1Protocol_1_1FullId.html">Protocol::FullId</a> id, <a class="el" href="structFastcgipp_1_1Message.html">Message</a> message)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Passes messages to requests.  <a href="#33fabd7f6c5eab389ef766fe67f4f870"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#248ec9febea8b11f4c168b811be583e6">stop</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Halter for the <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> function.  <a href="#248ec9febea8b11f4c168b811be583e6"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#9688df29d660edef9c56032986257821">setupSignals</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Configure the handlers for POSIX signals.  <a href="#9688df29d660edef9c56032986257821"></a><br></td></tr>
<tr><td colspan="2"><br><h2>Private Member Functions</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#cefd3c86045b2663e9529dd4109268e1">localHandler</a> (<a class="el" href="structFastcgipp_1_1Protocol_1_1FullId.html">Protocol::FullId</a> id)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Handles management messages.  <a href="#cefd3c86045b2663e9529dd4109268e1"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#6b07f268ade71b1b6b4a518ec6817164">terminate</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Terminator for the <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> function.  <a href="#6b07f268ade71b1b6b4a518ec6817164"></a><br></td></tr>
<tr><td colspan="2"><br><h2>Static Private Member Functions</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#cd92f71250a911fe74269286e3ab4356">signalHandler</a> (int signum)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">General function to handler POSIX signals.  <a href="#cd92f71250a911fe74269286e3ab4356"></a><br></td></tr>
<tr><td colspan="2"><br><h2>Private Attributes</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="classFastcgipp_1_1Transceiver.html">Transceiver</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#fe95fbcb1a859c4a6ece9a6a03da6d91">transceiver</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Handles low level communication with the other side.  <a href="#fe95fbcb1a859c4a6ece9a6a03da6d91"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="classFastcgipp_1_1Manager_1_1Tasks.html">Tasks</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#dee7f78b3965d28daeb4d937ea072ebd">tasks</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Queue for pending tasks.  <a href="#dee7f78b3965d28daeb4d937ea072ebd"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="classFastcgipp_1_1Manager_1_1Requests.html">Requests</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#bf6e08dba77676559ecc3e4bc9772caa">requests</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Associative container type for active requests.  <a href="#bf6e08dba77676559ecc3e4bc9772caa"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">std::queue&lt; <a class="el" href="structFastcgipp_1_1Message.html">Message</a> &gt;&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#e748d0982ce2fd204a340a92e73f00d3">messages</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">A queue of messages for the manager itself.  <a href="#e748d0982ce2fd204a340a92e73f00d3"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">bool&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#bb5d17f462ab5dab6a98898142fc3351">asleep</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Indicated whether or not the manager is currently in sleep mode.  <a href="#bb5d17f462ab5dab6a98898142fc3351"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">boost::mutex&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#f5bfeb94037f476ca1a34cffed01e3ae">sleepMutex</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Mutex to make accessing asleep thread safe.  <a href="#f5bfeb94037f476ca1a34cffed01e3ae"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">pthread_t&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#f40f8872ecd432cba927c42945b7422c">threadId</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The pthread id of the thread the <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> function is operating in.  <a href="#f40f8872ecd432cba927c42945b7422c"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">bool&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#db6652cb3b93aa630a0458efee6bf91d">stopBool</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Boolean value indicating that <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> should halt.  <a href="#db6652cb3b93aa630a0458efee6bf91d"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">boost::mutex&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#388da5616fe7cb65a0de6b6d61472470">stopMutex</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Mutex to make stopBool thread safe.  <a href="#388da5616fe7cb65a0de6b6d61472470"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">bool&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#d73c937bef11b4466e967e1abc5534a0">terminateBool</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Boolean value indication that <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> should terminate.  <a href="#d73c937bef11b4466e967e1abc5534a0"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">boost::mutex&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#7d14d73cfc08602d7ee926fafe95df46">terminateMutex</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Mutex to make terminateMutex thread safe.  <a href="#7d14d73cfc08602d7ee926fafe95df46"></a><br></td></tr>
<tr><td colspan="2"><br><h2>Static Private Attributes</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classFastcgipp_1_1Manager.html">Manager</a>&lt; T &gt; *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#40e5c99817463bccda2cac9299506e79">instance</a> = 0</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Pointer to the Manager object.  <a href="#40e5c99817463bccda2cac9299506e79"></a><br></td></tr>
<tr><td colspan="2"><br><h2>Classes</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">class &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager_1_1Requests.html">Requests</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Associative container type for active requests.  <a href="classFastcgipp_1_1Manager_1_1Requests.html#_details">More...</a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">class &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager_1_1Tasks.html">Tasks</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Queue type for pending tasks.  <a href="classFastcgipp_1_1Manager_1_1Tasks.html#_details">More...</a><br></td></tr>
</table>
<hr><a name="_details"></a><h2>Detailed Description</h2>
<h3>template&lt;typename T&gt;<br>
 class Fastcgipp::Manager&lt; T &gt;</h3>

General task and protocol management class. 
<p>
Handles all task and protocol management, creation/destruction of requests and passing of messages to requests. The template argument should be a class type derived from the <a class="el" href="classFastcgipp_1_1Request.html" title="Request handling class">Request</a> class with at least the response() function defined. To operate this class all that needs to be done is creating an object and calling <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> on it.<p>
<dl compact><dt><b>Template Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>T</em>&nbsp;</td><td>Class that will handle individual requests. Should be derived from the <a class="el" href="classFastcgipp_1_1Request.html" title="Request handling class">Request</a> class. </td></tr>
  </table>
</dl>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00058">58</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>
<hr><h2>Constructor &amp; Destructor Documentation</h2>
<a class="anchor" name="f057070411ce5f5a25575218aaa8939c"></a><!-- doxytag: member="Fastcgipp::Manager::Manager" ref="f057070411ce5f5a25575218aaa8939c" args="(int fd=0)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html">Manager</a>           </td>
          <td>(</td>
          <td class="paramtype">int&nbsp;</td>
          <td class="paramname"> <em>fd</em> = <code>0</code>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Construct from a file descriptor. 
<p>
The only piece of data required to construct a Manager object is a file descriptor to listen on for incoming connections. By default mod_fastcgi sets up file descriptor 0 to do this so it is the value passed by default to the constructor. The only time it would be another value is if an external FastCGI server was defined.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"><tt>[in]</tt>&nbsp;</td><td valign="top"><em>fd</em>&nbsp;</td><td>File descriptor to listen on. </td></tr>
  </table>
</dl>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00071">71</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>References <a class="el" href="classFastcgipp_1_1Manager.html#40e5c99817463bccda2cac9299506e79">Fastcgipp::Manager&lt; T &gt;::instance</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#9688df29d660edef9c56032986257821">Fastcgipp::Manager&lt; T &gt;::setupSignals()</a>.</p>

</div>
</div><p>
<a class="anchor" name="f981c2197efc3fd9e464ae66b1868837"></a><!-- doxytag: member="Fastcgipp::Manager::~Manager" ref="f981c2197efc3fd9e464ae66b1868837" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::~<a class="el" href="classFastcgipp_1_1Manager.html">Manager</a>           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00073">73</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>References <a class="el" href="classFastcgipp_1_1Manager.html#40e5c99817463bccda2cac9299506e79">Fastcgipp::Manager&lt; T &gt;::instance</a>.</p>

</div>
</div><p>
<hr><h2>Member Function Documentation</h2>
<a class="anchor" name="578c8468166d892d1858ad6f4d953d8d"></a><!-- doxytag: member="Fastcgipp::Manager::handler" ref="578c8468166d892d1858ad6f4d953d8d" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::handler           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
General handling function to be called after construction. 
<p>
This function will loop continuously manager tasks and FastCGI requests until either the <a class="el" href="classFastcgipp_1_1Manager.html#248ec9febea8b11f4c168b811be583e6" title="Halter for the handler() function.">stop()</a> function is called (obviously from another thread) or the appropriate signals are caught.<p>
<dl class="see" compact><dt><b>See also:</b></dt><dd><a class="el" href="classFastcgipp_1_1Manager.html#9688df29d660edef9c56032986257821" title="Configure the handlers for POSIX signals.">setupSignals()</a> </dd></dl>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00302">302</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>References <a class="el" href="classFastcgipp_1_1Manager.html#bb5d17f462ab5dab6a98898142fc3351">Fastcgipp::Manager&lt; T &gt;::asleep</a>, <a class="el" href="classFastcgipp_1_1Transceiver.html#f06e586f5a49dd694f2ae98398870721">Fastcgipp::Transceiver::handler()</a>, <a class="el" href="classFastcgipp_1_1Manager.html#cefd3c86045b2663e9529dd4109268e1">Fastcgipp::Manager&lt; T &gt;::localHandler()</a>, <a class="el" href="classFastcgipp_1_1Manager.html#bf6e08dba77676559ecc3e4bc9772caa">Fastcgipp::Manager&lt; T &gt;::requests</a>, <a class="el" href="classFastcgipp_1_1Transceiver.html#5c1bafc977eaa9e4c3e94a5b9eab59eb">Fastcgipp::Transceiver::sleep()</a>, <a class="el" href="classFastcgipp_1_1Manager.html#f5bfeb94037f476ca1a34cffed01e3ae">Fastcgipp::Manager&lt; T &gt;::sleepMutex</a>, <a class="el" href="classFastcgipp_1_1Manager.html#db6652cb3b93aa630a0458efee6bf91d">Fastcgipp::Manager&lt; T &gt;::stopBool</a>, <a class="el" href="classFastcgipp_1_1Manager.html#388da5616fe7cb65a0de6b6d61472470">Fastcgipp::Manager&lt; T &gt;::stopMutex</a>, <a class="el" href="classFastcgipp_1_1Manager.html#dee7f78b3965d28daeb4d937ea072ebd">Fastcgipp::Manager&lt; T &gt;::tasks</a>, <a class="el" href="classFastcgipp_1_1Manager.html#d73c937bef11b4466e967e1abc5534a0">Fastcgipp::Manager&lt; T &gt;::terminateBool</a>, <a class="el" href="classFastcgipp_1_1Manager.html#7d14d73cfc08602d7ee926fafe95df46">Fastcgipp::Manager&lt; T &gt;::terminateMutex</a>, <a class="el" href="classFastcgipp_1_1Manager.html#f40f8872ecd432cba927c42945b7422c">Fastcgipp::Manager&lt; T &gt;::threadId</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#fe95fbcb1a859c4a6ece9a6a03da6d91">Fastcgipp::Manager&lt; T &gt;::transceiver</a>.</p>

</div>
</div><p>
<a class="anchor" name="33fabd7f6c5eab389ef766fe67f4f870"></a><!-- doxytag: member="Fastcgipp::Manager::push" ref="33fabd7f6c5eab389ef766fe67f4f870" args="(Protocol::FullId id, Message message)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::push           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="structFastcgipp_1_1Protocol_1_1FullId.html">Protocol::FullId</a>&nbsp;</td>
          <td class="paramname"> <em>id</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="structFastcgipp_1_1Message.html">Message</a>&nbsp;</td>
          <td class="paramname"> <em>message</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Passes messages to requests. 
<p>
Whenever a message needs to be passed to a request, it must be done through this function. Requests are associated with their <a class="el" href="structFastcgipp_1_1Protocol_1_1FullId.html" title="A full ID value for a FastCGI request.">Protocol::FullId</a> value so that and the message itself is all that is needed. Calling this function from another thread is safe. Although this function can be called from outside the fastcgi++ library, the <a class="el" href="classFastcgipp_1_1Request.html" title="Request handling class">Request</a> class contains a callback function based on this that is more usable. An id with a <a class="el" href="namespaceFastcgipp_1_1Protocol.html#d13bef0f4b827d3f981b8c6ca98bd4e4" title="The request ID of a FastCGI request.">Protocol::RequestId</a> of 0 means the message is destined for the Manager itself. Should a message by passed with an id that doesn't exist, it will be discarded.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"><tt>[in]</tt>&nbsp;</td><td valign="top"><em>id</em>&nbsp;</td><td>The id of the request the message should go to </td></tr>
    <tr><td valign="top"><tt>[in]</tt>&nbsp;</td><td valign="top"><em>message</em>&nbsp;</td><td>The message itself</td></tr>
  </table>
</dl>
<dl class="see" compact><dt><b>See also:</b></dt><dd><a class="el" href="classFastcgipp_1_1Request.html#e3624e083a77cb21401d3c5ac97205b6" title="Callback function for dealings outside the fastcgi++ library.">Request::callback</a> </dd></dl>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00258">258</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>References <a class="el" href="classFastcgipp_1_1Manager.html#bb5d17f462ab5dab6a98898142fc3351">Fastcgipp::Manager&lt; T &gt;::asleep</a>, <a class="el" href="namespaceFastcgipp_1_1Protocol.html#79e41b489a9b2c0374eee108d375b6462fa87fd35208ef6d3c54733c4fcb930f">Fastcgipp::Protocol::BEGIN_REQUEST</a>, <a class="el" href="structFastcgipp_1_1Message.html#4467d1b63f295c224943dc1a1ef112ff">Fastcgipp::Message::data</a>, <a class="el" href="classFastcgipp_1_1Manager.html#e748d0982ce2fd204a340a92e73f00d3">Fastcgipp::Manager&lt; T &gt;::messages</a>, <a class="el" href="classFastcgipp_1_1Manager.html#bf6e08dba77676559ecc3e4bc9772caa">Fastcgipp::Manager&lt; T &gt;::requests</a>, <a class="el" href="classFastcgipp_1_1Manager.html#f5bfeb94037f476ca1a34cffed01e3ae">Fastcgipp::Manager&lt; T &gt;::sleepMutex</a>, <a class="el" href="classFastcgipp_1_1Manager.html#dee7f78b3965d28daeb4d937ea072ebd">Fastcgipp::Manager&lt; T &gt;::tasks</a>, <a class="el" href="classFastcgipp_1_1Manager.html#fe95fbcb1a859c4a6ece9a6a03da6d91">Fastcgipp::Manager&lt; T &gt;::transceiver</a>, <a class="el" href="structFastcgipp_1_1Message.html#ba5936b4703cc3c398bbf0bb9eb6bd4f">Fastcgipp::Message::type</a>, and <a class="el" href="classFastcgipp_1_1Transceiver.html#4dfd5de627b92f6bb5a834a68b20bb85">Fastcgipp::Transceiver::wake()</a>.</p>

</div>
</div><p>
<a class="anchor" name="248ec9febea8b11f4c168b811be583e6"></a><!-- doxytag: member="Fastcgipp::Manager::stop" ref="248ec9febea8b11f4c168b811be583e6" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::stop           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Halter for the <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> function. 
<p>
This function is intended to be called from a thread separate from the <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> in order to halt it. It should also be called by a signal handler in the case of of a SIGTERM. Once handler() has been halted it may be re-called to pick up exactly where it left off without any data loss.<p>
<dl class="see" compact><dt><b>See also:</b></dt><dd><a class="el" href="classFastcgipp_1_1Manager.html#9688df29d660edef9c56032986257821" title="Configure the handlers for POSIX signals.">setupSignals()</a> <p>
<a class="el" href="classFastcgipp_1_1Manager.html#cd92f71250a911fe74269286e3ab4356" title="General function to handler POSIX signals.">signalHandler()</a> </dd></dl>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00222">222</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>References <a class="el" href="classFastcgipp_1_1Manager.html#db6652cb3b93aa630a0458efee6bf91d">Fastcgipp::Manager&lt; T &gt;::stopBool</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#388da5616fe7cb65a0de6b6d61472470">Fastcgipp::Manager&lt; T &gt;::stopMutex</a>.</p>

</div>
</div><p>
<a class="anchor" name="9688df29d660edef9c56032986257821"></a><!-- doxytag: member="Fastcgipp::Manager::setupSignals" ref="9688df29d660edef9c56032986257821" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::setupSignals           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Configure the handlers for POSIX signals. 
<p>
By calling this function appropriate handlers will be set up for SIGPIPE, SIGUSR1 and SIGTERM. It is called by default upon construction of a <a class="el" href="classFastcgipp_1_1Manager.html" title="General task and protocol management class.">Manager</a> object. Should the user want to override these handlers, it should be done post-construction.<p>
<dl class="see" compact><dt><b>See also:</b></dt><dd><a class="el" href="classFastcgipp_1_1Manager.html#cd92f71250a911fe74269286e3ab4356" title="General function to handler POSIX signals.">signalHandler()</a> </dd></dl>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00247">247</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#f057070411ce5f5a25575218aaa8939c">Fastcgipp::Manager&lt; T &gt;::Manager()</a>.</p>

</div>
</div><p>
<a class="anchor" name="cefd3c86045b2663e9529dd4109268e1"></a><!-- doxytag: member="Fastcgipp::Manager::localHandler" ref="cefd3c86045b2663e9529dd4109268e1" args="(Protocol::FullId id)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::localHandler           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="structFastcgipp_1_1Protocol_1_1FullId.html">Protocol::FullId</a>&nbsp;</td>
          <td class="paramname"> <em>id</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [inline, private]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Handles management messages. 
<p>
This function is called by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> in the case that a management message is recieved. Although the request id of a management record is always 0, the <a class="el" href="structFastcgipp_1_1Protocol_1_1FullId.html" title="A full ID value for a FastCGI request.">Protocol::FullId</a> associated with the message is passed to this function to keep track of it's associated file descriptor.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"><tt>[in]</tt>&nbsp;</td><td valign="top"><em>id</em>&nbsp;</td><td>FullId associated with the messsage. </td></tr>
  </table>
</dl>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00376">376</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>References <a class="el" href="namespaceFastcgipp_1_1Protocol.html#79e41b489a9b2c0374eee108d375b646400b2c68539eb222bfcc432d45925986">Fastcgipp::Protocol::GET_VALUES</a>, <a class="el" href="namespaceFastcgipp_1_1Protocol.html#9d9bd30c0dc267d583c9b0f63e31c7df">Fastcgipp::Protocol::maxConnsReply()</a>, <a class="el" href="namespaceFastcgipp_1_1Protocol.html#4d064af885129e9eb829c8dd0bcb3bb5">Fastcgipp::Protocol::maxReqsReply()</a>, <a class="el" href="classFastcgipp_1_1Manager.html#e748d0982ce2fd204a340a92e73f00d3">Fastcgipp::Manager&lt; T &gt;::messages</a>, <a class="el" href="namespaceFastcgipp_1_1Protocol.html#497a279b617558c3dc5331a68c0c7de7">Fastcgipp::Protocol::mpxsConnsReply()</a>, <a class="el" href="namespaceFastcgipp_1_1Protocol.html#80e734e52d8784e63af2d45e4489ba60">Fastcgipp::Protocol::processParamHeader()</a>, <a class="el" href="classFastcgipp_1_1Transceiver.html#5019405a5a05d60fdaa73d349cca58c0">Fastcgipp::Transceiver::requestWrite()</a>, <a class="el" href="classFastcgipp_1_1Transceiver.html#1a720bf113ad9781e59b0fc021988d29">Fastcgipp::Transceiver::secureWrite()</a>, <a class="el" href="classFastcgipp_1_1Manager.html#fe95fbcb1a859c4a6ece9a6a03da6d91">Fastcgipp::Manager&lt; T &gt;::transceiver</a>, <a class="el" href="namespaceFastcgipp_1_1Protocol.html#79e41b489a9b2c0374eee108d375b64619539e3c86cc082596ee265ee9daf103">Fastcgipp::Protocol::UNKNOWN_TYPE</a>, and <a class="el" href="namespaceFastcgipp_1_1Protocol.html#1f2b069bfe52a9d5cb9e84dacf85aec0">Fastcgipp::Protocol::version</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>.</p>

</div>
</div><p>
<a class="anchor" name="cd92f71250a911fe74269286e3ab4356"></a><!-- doxytag: member="Fastcgipp::Manager::signalHandler" ref="cd92f71250a911fe74269286e3ab4356" args="(int signum)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::signalHandler           </td>
          <td>(</td>
          <td class="paramtype">int&nbsp;</td>
          <td class="paramname"> <em>signum</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [inline, static, private]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
General function to handler POSIX signals. 
<p>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00229">229</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>References <a class="el" href="classFastcgipp_1_1Manager.html#40e5c99817463bccda2cac9299506e79">Fastcgipp::Manager&lt; T &gt;::instance</a>.</p>

</div>
</div><p>
<a class="anchor" name="6b07f268ade71b1b6b4a518ec6817164"></a><!-- doxytag: member="Fastcgipp::Manager::terminate" ref="6b07f268ade71b1b6b4a518ec6817164" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::terminate           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [inline, private]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Terminator for the <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> function. 
<p>
This function is intended to be called from a signal handler in the case of of a SIGUSR1. It is similar to <a class="el" href="classFastcgipp_1_1Manager.html#248ec9febea8b11f4c168b811be583e6" title="Halter for the handler() function.">stop()</a> except that <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> will wait until all requests are complete before halting.<p>
<dl class="see" compact><dt><b>See also:</b></dt><dd><a class="el" href="classFastcgipp_1_1Manager.html#9688df29d660edef9c56032986257821" title="Configure the handlers for POSIX signals.">setupSignals()</a> <p>
<a class="el" href="classFastcgipp_1_1Manager.html#cd92f71250a911fe74269286e3ab4356" title="General function to handler POSIX signals.">signalHandler()</a> </dd></dl>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00215">215</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>References <a class="el" href="classFastcgipp_1_1Manager.html#d73c937bef11b4466e967e1abc5534a0">Fastcgipp::Manager&lt; T &gt;::terminateBool</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#7d14d73cfc08602d7ee926fafe95df46">Fastcgipp::Manager&lt; T &gt;::terminateMutex</a>.</p>

</div>
</div><p>
<hr><h2>Member Data Documentation</h2>
<a class="anchor" name="fe95fbcb1a859c4a6ece9a6a03da6d91"></a><!-- doxytag: member="Fastcgipp::Manager::transceiver" ref="fe95fbcb1a859c4a6ece9a6a03da6d91" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classFastcgipp_1_1Transceiver.html">Transceiver</a> <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#fe95fbcb1a859c4a6ece9a6a03da6d91">transceiver</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Handles low level communication with the other side. 
<p>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00127">127</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>, <a class="el" href="classFastcgipp_1_1Manager.html#cefd3c86045b2663e9529dd4109268e1">Fastcgipp::Manager&lt; T &gt;::localHandler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager&lt; T &gt;::push()</a>.</p>

</div>
</div><p>
<a class="anchor" name="dee7f78b3965d28daeb4d937ea072ebd"></a><!-- doxytag: member="Fastcgipp::Manager::tasks" ref="dee7f78b3965d28daeb4d937ea072ebd" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classFastcgipp_1_1Manager_1_1Tasks.html">Tasks</a> <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#dee7f78b3965d28daeb4d937ea072ebd">tasks</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Queue for pending tasks. 
<p>
This contains a queue of <a class="el" href="structFastcgipp_1_1Protocol_1_1FullId.html" title="A full ID value for a FastCGI request.">Protocol::FullId</a> that need their handlers called. 
<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00139">139</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager&lt; T &gt;::push()</a>.</p>

</div>
</div><p>
<a class="anchor" name="bf6e08dba77676559ecc3e4bc9772caa"></a><!-- doxytag: member="Fastcgipp::Manager::requests" ref="bf6e08dba77676559ecc3e4bc9772caa" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classFastcgipp_1_1Manager_1_1Requests.html">Requests</a> <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#bf6e08dba77676559ecc3e4bc9772caa">requests</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Associative container type for active requests. 
<p>
This container associated the <a class="el" href="structFastcgipp_1_1Protocol_1_1FullId.html" title="A full ID value for a FastCGI request.">Protocol::FullId</a> of each active request with a pointer to the actual <a class="el" href="classFastcgipp_1_1Request.html" title="Request handling class">Request</a> object. 
<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00152">152</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager&lt; T &gt;::push()</a>.</p>

</div>
</div><p>
<a class="anchor" name="e748d0982ce2fd204a340a92e73f00d3"></a><!-- doxytag: member="Fastcgipp::Manager::messages" ref="e748d0982ce2fd204a340a92e73f00d3" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">std::queue&lt;<a class="el" href="structFastcgipp_1_1Message.html">Message</a>&gt; <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#e748d0982ce2fd204a340a92e73f00d3">messages</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
A queue of messages for the manager itself. 
<p>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00155">155</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#cefd3c86045b2663e9529dd4109268e1">Fastcgipp::Manager&lt; T &gt;::localHandler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager&lt; T &gt;::push()</a>.</p>

</div>
</div><p>
<a class="anchor" name="bb5d17f462ab5dab6a98898142fc3351"></a><!-- doxytag: member="Fastcgipp::Manager::asleep" ref="bb5d17f462ab5dab6a98898142fc3351" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">bool <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#bb5d17f462ab5dab6a98898142fc3351">asleep</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Indicated whether or not the manager is currently in sleep mode. 
<p>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00169">169</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager&lt; T &gt;::push()</a>.</p>

</div>
</div><p>
<a class="anchor" name="f5bfeb94037f476ca1a34cffed01e3ae"></a><!-- doxytag: member="Fastcgipp::Manager::sleepMutex" ref="f5bfeb94037f476ca1a34cffed01e3ae" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">boost::mutex <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#f5bfeb94037f476ca1a34cffed01e3ae">sleepMutex</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Mutex to make accessing asleep thread safe. 
<p>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00171">171</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager&lt; T &gt;::push()</a>.</p>

</div>
</div><p>
<a class="anchor" name="f40f8872ecd432cba927c42945b7422c"></a><!-- doxytag: member="Fastcgipp::Manager::threadId" ref="f40f8872ecd432cba927c42945b7422c" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">pthread_t <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#f40f8872ecd432cba927c42945b7422c">threadId</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
The pthread id of the thread the <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> function is operating in. 
<p>
Although this library is intended to be used with boost::thread and not pthread, the underlying pthread id of the handler() function is needed to call pthread_kill() when sleep is to be interrupted. 
<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00177">177</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>.</p>

</div>
</div><p>
<a class="anchor" name="db6652cb3b93aa630a0458efee6bf91d"></a><!-- doxytag: member="Fastcgipp::Manager::stopBool" ref="db6652cb3b93aa630a0458efee6bf91d" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">bool <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#db6652cb3b93aa630a0458efee6bf91d">stopBool</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Boolean value indicating that <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> should halt. 
<p>
<dl class="see" compact><dt><b>See also:</b></dt><dd><a class="el" href="classFastcgipp_1_1Manager.html#248ec9febea8b11f4c168b811be583e6" title="Halter for the handler() function.">stop()</a> </dd></dl>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00183">183</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#248ec9febea8b11f4c168b811be583e6">Fastcgipp::Manager&lt; T &gt;::stop()</a>.</p>

</div>
</div><p>
<a class="anchor" name="388da5616fe7cb65a0de6b6d61472470"></a><!-- doxytag: member="Fastcgipp::Manager::stopMutex" ref="388da5616fe7cb65a0de6b6d61472470" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">boost::mutex <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#388da5616fe7cb65a0de6b6d61472470">stopMutex</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Mutex to make stopBool thread safe. 
<p>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00185">185</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#248ec9febea8b11f4c168b811be583e6">Fastcgipp::Manager&lt; T &gt;::stop()</a>.</p>

</div>
</div><p>
<a class="anchor" name="d73c937bef11b4466e967e1abc5534a0"></a><!-- doxytag: member="Fastcgipp::Manager::terminateBool" ref="d73c937bef11b4466e967e1abc5534a0" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">bool <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#d73c937bef11b4466e967e1abc5534a0">terminateBool</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Boolean value indication that <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d" title="General handling function to be called after construction.">handler()</a> should terminate. 
<p>
<dl class="see" compact><dt><b>See also:</b></dt><dd><a class="el" href="classFastcgipp_1_1Manager.html#6b07f268ade71b1b6b4a518ec6817164" title="Terminator for the handler() function.">terminate()</a> </dd></dl>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00190">190</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#6b07f268ade71b1b6b4a518ec6817164">Fastcgipp::Manager&lt; T &gt;::terminate()</a>.</p>

</div>
</div><p>
<a class="anchor" name="7d14d73cfc08602d7ee926fafe95df46"></a><!-- doxytag: member="Fastcgipp::Manager::terminateMutex" ref="7d14d73cfc08602d7ee926fafe95df46" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">boost::mutex <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#7d14d73cfc08602d7ee926fafe95df46">terminateMutex</a><code> [private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Mutex to make terminateMutex thread safe. 
<p>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00192">192</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">Fastcgipp::Manager&lt; T &gt;::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#6b07f268ade71b1b6b4a518ec6817164">Fastcgipp::Manager&lt; T &gt;::terminate()</a>.</p>

</div>
</div><p>
<a class="anchor" name="40e5c99817463bccda2cac9299506e79"></a><!-- doxytag: member="Fastcgipp::Manager::instance" ref="40e5c99817463bccda2cac9299506e79" args="" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt; * <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>&lt; T &gt;::<a class="el" href="classFastcgipp_1_1Manager.html#40e5c99817463bccda2cac9299506e79">instance</a> = 0<code> [inline, static, private]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Pointer to the Manager object. 
<p>

<p>Definition at line <a class="el" href="manager_8hpp-source.html#l00197">197</a> of file <a class="el" href="manager_8hpp-source.html">manager.hpp</a>.</p>

<p>Referenced by <a class="el" href="classFastcgipp_1_1Manager.html#f057070411ce5f5a25575218aaa8939c">Fastcgipp::Manager&lt; T &gt;::Manager()</a>, <a class="el" href="classFastcgipp_1_1Manager.html#cd92f71250a911fe74269286e3ab4356">Fastcgipp::Manager&lt; T &gt;::signalHandler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#f981c2197efc3fd9e464ae66b1868837">Fastcgipp::Manager&lt; T &gt;::~Manager()</a>.</p>

</div>
</div><p>
<hr>The documentation for this class was generated from the following file:<ul>
<li><a class="el" href="manager_8hpp-source.html">manager.hpp</a></ul>
</div>
<hr size="1"><address style="text-align: right;"><small>Generated on Tue Sep 16 15:17:47 2008 for fastcgi++ by&nbsp;
<a href="http://www.doxygen.org/index.html">
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.6 </small></address>
</body>
</html>