<!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< T > 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 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 List</span></a></li> <li><a href="hierarchy.html"><span>Class Hierarchy</span></a></li> <li><a href="functions.html"><span>Class 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< T > Class Template Reference</h1><!-- doxytag: class="Fastcgipp::Manager" -->General task and protocol management class. <a href="#_details">More...</a> <p> <code>#include <<a class="el" href="manager_8hpp-source.html">manager.hpp</a>></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"> </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"> </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"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#578c8468166d892d1858ad6f4d953d8d">handler</a> ()</td></tr> <tr><td class="mdescLeft"> </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 </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"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#248ec9febea8b11f4c168b811be583e6">stop</a> ()</td></tr> <tr><td class="mdescLeft"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#9688df29d660edef9c56032986257821">setupSignals</a> ()</td></tr> <tr><td class="mdescLeft"> </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 </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"> </td><td class="mdescRight">Handles management messages. <a href="#cefd3c86045b2663e9529dd4109268e1"></a><br></td></tr> <tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#6b07f268ade71b1b6b4a518ec6817164">terminate</a> ()</td></tr> <tr><td class="mdescLeft"> </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 </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"> </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> </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#fe95fbcb1a859c4a6ece9a6a03da6d91">transceiver</a></td></tr> <tr><td class="mdescLeft"> </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> </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#dee7f78b3965d28daeb4d937ea072ebd">tasks</a></td></tr> <tr><td class="mdescLeft"> </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> </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#bf6e08dba77676559ecc3e4bc9772caa">requests</a></td></tr> <tr><td class="mdescLeft"> </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< <a class="el" href="structFastcgipp_1_1Message.html">Message</a> > </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#e748d0982ce2fd204a340a92e73f00d3">messages</a></td></tr> <tr><td class="mdescLeft"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#bb5d17f462ab5dab6a98898142fc3351">asleep</a></td></tr> <tr><td class="mdescLeft"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#f5bfeb94037f476ca1a34cffed01e3ae">sleepMutex</a></td></tr> <tr><td class="mdescLeft"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#f40f8872ecd432cba927c42945b7422c">threadId</a></td></tr> <tr><td class="mdescLeft"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#db6652cb3b93aa630a0458efee6bf91d">stopBool</a></td></tr> <tr><td class="mdescLeft"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#388da5616fe7cb65a0de6b6d61472470">stopMutex</a></td></tr> <tr><td class="mdescLeft"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#d73c937bef11b4466e967e1abc5534a0">terminateBool</a></td></tr> <tr><td class="mdescLeft"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#7d14d73cfc08602d7ee926fafe95df46">terminateMutex</a></td></tr> <tr><td class="mdescLeft"> </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>< T > * </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager.html#40e5c99817463bccda2cac9299506e79">instance</a> = 0</td></tr> <tr><td class="mdescLeft"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager_1_1Requests.html">Requests</a></td></tr> <tr><td class="mdescLeft"> </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classFastcgipp_1_1Manager_1_1Tasks.html">Tasks</a></td></tr> <tr><td class="mdescLeft"> </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<typename T><br> class Fastcgipp::Manager< T ></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> </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 & 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<typename T> </div> <table class="memname"> <tr> <td class="memname"><a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::<a class="el" href="classFastcgipp_1_1Manager.html">Manager</a> </td> <td>(</td> <td class="paramtype">int </td> <td class="paramname"> <em>fd</em> = <code>0</code> </td> <td> ) </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> </td><td valign="top"><em>fd</em> </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< T >::instance</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#9688df29d660edef9c56032986257821">Fastcgipp::Manager< T >::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<typename T> </div> <table class="memname"> <tr> <td class="memname"><a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::~<a class="el" href="classFastcgipp_1_1Manager.html">Manager</a> </td> <td>(</td> <td class="paramname"> </td> <td> ) </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< T >::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<class T> </div> <table class="memname"> <tr> <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::handler </td> <td>(</td> <td class="paramname"> </td> <td> ) </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< T >::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< T >::localHandler()</a>, <a class="el" href="classFastcgipp_1_1Manager.html#bf6e08dba77676559ecc3e4bc9772caa">Fastcgipp::Manager< T >::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< T >::sleepMutex</a>, <a class="el" href="classFastcgipp_1_1Manager.html#db6652cb3b93aa630a0458efee6bf91d">Fastcgipp::Manager< T >::stopBool</a>, <a class="el" href="classFastcgipp_1_1Manager.html#388da5616fe7cb65a0de6b6d61472470">Fastcgipp::Manager< T >::stopMutex</a>, <a class="el" href="classFastcgipp_1_1Manager.html#dee7f78b3965d28daeb4d937ea072ebd">Fastcgipp::Manager< T >::tasks</a>, <a class="el" href="classFastcgipp_1_1Manager.html#d73c937bef11b4466e967e1abc5534a0">Fastcgipp::Manager< T >::terminateBool</a>, <a class="el" href="classFastcgipp_1_1Manager.html#7d14d73cfc08602d7ee926fafe95df46">Fastcgipp::Manager< T >::terminateMutex</a>, <a class="el" href="classFastcgipp_1_1Manager.html#f40f8872ecd432cba927c42945b7422c">Fastcgipp::Manager< T >::threadId</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#fe95fbcb1a859c4a6ece9a6a03da6d91">Fastcgipp::Manager< T >::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<class T> </div> <table class="memname"> <tr> <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::push </td> <td>(</td> <td class="paramtype"><a class="el" href="structFastcgipp_1_1Protocol_1_1FullId.html">Protocol::FullId</a> </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> </td> <td class="paramname"> <em>message</em></td><td> </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> </td><td valign="top"><em>id</em> </td><td>The id of the request the message should go to </td></tr> <tr><td valign="top"><tt>[in]</tt> </td><td valign="top"><em>message</em> </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< T >::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< T >::messages</a>, <a class="el" href="classFastcgipp_1_1Manager.html#bf6e08dba77676559ecc3e4bc9772caa">Fastcgipp::Manager< T >::requests</a>, <a class="el" href="classFastcgipp_1_1Manager.html#f5bfeb94037f476ca1a34cffed01e3ae">Fastcgipp::Manager< T >::sleepMutex</a>, <a class="el" href="classFastcgipp_1_1Manager.html#dee7f78b3965d28daeb4d937ea072ebd">Fastcgipp::Manager< T >::tasks</a>, <a class="el" href="classFastcgipp_1_1Manager.html#fe95fbcb1a859c4a6ece9a6a03da6d91">Fastcgipp::Manager< T >::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<class T> </div> <table class="memname"> <tr> <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::stop </td> <td>(</td> <td class="paramname"> </td> <td> ) </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< T >::stopBool</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#388da5616fe7cb65a0de6b6d61472470">Fastcgipp::Manager< T >::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<class T> </div> <table class="memname"> <tr> <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::setupSignals </td> <td>(</td> <td class="paramname"> </td> <td> ) </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< T >::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<class T> </div> <table class="memname"> <tr> <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::localHandler </td> <td>(</td> <td class="paramtype"><a class="el" href="structFastcgipp_1_1Protocol_1_1FullId.html">Protocol::FullId</a> </td> <td class="paramname"> <em>id</em> </td> <td> ) </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> </td><td valign="top"><em>id</em> </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< T >::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< T >::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< T >::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<class T> </div> <table class="memname"> <tr> <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::signalHandler </td> <td>(</td> <td class="paramtype">int </td> <td class="paramname"> <em>signum</em> </td> <td> ) </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< T >::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<class T> </div> <table class="memname"> <tr> <td class="memname">void <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::terminate </td> <td>(</td> <td class="paramname"> </td> <td> ) </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< T >::terminateBool</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#7d14d73cfc08602d7ee926fafe95df46">Fastcgipp::Manager< T >::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<typename T> </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>< T >::<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< T >::handler()</a>, <a class="el" href="classFastcgipp_1_1Manager.html#cefd3c86045b2663e9529dd4109268e1">Fastcgipp::Manager< T >::localHandler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager< T >::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<typename T> </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>< T >::<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< T >::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager< T >::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<typename T> </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>< T >::<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< T >::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager< T >::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<typename T> </div> <table class="memname"> <tr> <td class="memname">std::queue<<a class="el" href="structFastcgipp_1_1Message.html">Message</a>> <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::<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< T >::localHandler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager< T >::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<typename T> </div> <table class="memname"> <tr> <td class="memname">bool <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::<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< T >::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager< T >::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<typename T> </div> <table class="memname"> <tr> <td class="memname">boost::mutex <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::<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< T >::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#33fabd7f6c5eab389ef766fe67f4f870">Fastcgipp::Manager< T >::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<typename T> </div> <table class="memname"> <tr> <td class="memname">pthread_t <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::<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< T >::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<typename T> </div> <table class="memname"> <tr> <td class="memname">bool <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::<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< T >::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#248ec9febea8b11f4c168b811be583e6">Fastcgipp::Manager< T >::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<typename T> </div> <table class="memname"> <tr> <td class="memname">boost::mutex <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::<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< T >::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#248ec9febea8b11f4c168b811be583e6">Fastcgipp::Manager< T >::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<typename T> </div> <table class="memname"> <tr> <td class="memname">bool <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::<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< T >::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#6b07f268ade71b1b6b4a518ec6817164">Fastcgipp::Manager< T >::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<typename T> </div> <table class="memname"> <tr> <td class="memname">boost::mutex <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::<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< T >::handler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#6b07f268ade71b1b6b4a518ec6817164">Fastcgipp::Manager< T >::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<typename T> </div> <table class="memname"> <tr> <td class="memname"><a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T > * <a class="el" href="classFastcgipp_1_1Manager.html">Fastcgipp::Manager</a>< T >::<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< T >::Manager()</a>, <a class="el" href="classFastcgipp_1_1Manager.html#cd92f71250a911fe74269286e3ab4356">Fastcgipp::Manager< T >::signalHandler()</a>, and <a class="el" href="classFastcgipp_1_1Manager.html#f981c2197efc3fd9e464ae66b1868837">Fastcgipp::Manager< T >::~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 <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>