run_8c.html 22.5 KB
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<title>server: src/server/run.c File Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/search.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript">
$(document).ready(initResizable);
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css"/>
</head>
<body onload='searchBox.OnSelectItem(0);'>
<!-- Generated by Doxygen 1.7.3 -->
<script type="text/javascript"><!--
var searchBox = new SearchBox("searchBox", "search",false,'Search');
--></script>
<div id="top">
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td style="padding-left: 0.5em;">
   <div id="projectname">server&#160;<span id="projectnumber">0.0.1</span></div>
   <div id="projectbrief">basicserverinfrastructure</div>
  </td>
 </tr>
 </tbody>
</table>
</div>
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="annotated.html"><span>Classes</span></a></li>
      <li class="current"><a href="files.html"><span>Files</span></a></li>
      <li id="searchli">
        <div id="MSearchBox" class="MSearchBoxInactive">
        <span class="left">
          <img id="MSearchSelect" src="search/mag_sel.png"
               onmouseover="return searchBox.OnSearchSelectShow()"
               onmouseout="return searchBox.OnSearchSelectHide()"
               alt=""/>
          <input type="text" id="MSearchField" value="Search" accesskey="S"
               onfocus="searchBox.OnSearchFieldFocus(true)" 
               onblur="searchBox.OnSearchFieldFocus(false)" 
               onkeyup="searchBox.OnSearchFieldChange(event)"/>
          </span><span class="right">
            <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
          </span>
        </div>
      </li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="files.html"><span>File&#160;List</span></a></li>
      <li><a href="globals.html"><span>File&#160;Members</span></a></li>
    </ul>
  </div>
</div>
<div id="side-nav" class="ui-resizable side-nav-resizable">
  <div id="nav-tree">
    <div id="nav-tree-contents">
    </div>
  </div>
  <div id="splitbar" style="-moz-user-select:none;" 
       class="ui-resizable-handle">
  </div>
</div>
<script type="text/javascript">
  initNavTree('run_8c.html','');
</script>
<div id="doc-content">
<div class="header">
  <div class="summary">
<a href="#define-members">Defines</a> &#124;
<a href="#func-members">Functions</a>  </div>
  <div class="headertitle">
<h1>src/server/run.c File Reference</h1>  </div>
</div>
<div class="contents">
<div class="textblock"><code>#include &lt;poll.h&gt;</code><br/>
<code>#include &lt;string.h&gt;</code><br/>
<code>#include &lt;stdlib.h&gt;</code><br/>
<code>#include &lt;errno.h&gt;</code><br/>
<code>#include &lt;unistd.h&gt;</code><br/>
<code>#include &lt;time.h&gt;</code><br/>
<code>#include &quot;server.h&quot;</code><br/>
<code>#include &quot;socket.h&quot;</code><br/>
<code>#include &quot;logger.h&quot;</code><br/>
<code>#include &quot;signalHandling.h&quot;</code><br/>
<code>#include &quot;interface/class.h&quot;</code><br/>
<code>#include &quot;interface/stream_reader.h&quot;</code><br/>
<code>#include &quot;interface/logger.h&quot;</code><br/>
<code>#include &quot;http/request.h&quot;</code><br/>
<code>#include &quot;http/request_parser.h&quot;</code><br/>
<code>#include &quot;http/request_queue.h&quot;</code><br/>
<code>#include &quot;<a class="el" href="poll_8c_source.html">poll.c</a>&quot;</code><br/>
<code>#include &quot;<a class="el" href="handle__accept_8c_source.html">handle_accept.c</a>&quot;</code><br/>
<code>#include &quot;<a class="el" href="read_8c_source.html">read.c</a>&quot;</code><br/>
</div><div class="textblock"><div class="dynheader">
Include dependency graph for run.c:</div>
<div class="dyncontent">
<div class="center"><img src="run_8c__incl.png" border="0" usemap="#src_2server_2run_8c" alt=""/></div>
<map name="src_2server_2run_8c" id="src_2server_2run_8c">
<area shape="rect" id="node35" href="poll_8c.html" title="poll.c" alt="" coords="1907,83,1960,111"/><area shape="rect" id="node37" href="handle__accept_8c.html" title="handle_accept.c" alt="" coords="1984,83,2101,111"/><area shape="rect" id="node39" href="read_8c.html" title="read.c" alt="" coords="2125,83,2184,111"/></map>
</div>
</div>
<p><a href="run_8c_source.html">Go to the source code of this file.</a></p>
<table class="memberdecls">
<tr><td colspan="2"><h2><a name="define-members"></a>
Defines</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="run_8c.html#aacc3ee1a7f283f8ef65cea31f4436a95">MAX</a>(x, y)&#160;&#160;&#160;((x) &gt; (y) ? (x) : (y))</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="run_8c.html#a62de8b169a3e2f03f0e793aee87b3758">RESP_HEAD</a></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="run_8c.html#a668b468f247abfce706ce6eaf6caecc9">RESP_DATA</a></td></tr>
<tr><td colspan="2"><h2><a name="func-members"></a>
Functions</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="run_8c.html#a67a4d9073b80d8ae1459fb11ddd23675">serverRun</a> (<a class="el" href="structServer.html">Server</a> this)</td></tr>
</table>
<hr/><h2>Define Documentation</h2>
<a class="anchor" id="aacc3ee1a7f283f8ef65cea31f4436a95"></a><!-- doxytag: member="run.c::MAX" ref="aacc3ee1a7f283f8ef65cea31f4436a95" args="(x, y)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define MAX</td>
          <td>(</td>
          <td class="paramtype">&#160;</td>
          <td class="paramname">x, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">&#160;</td>
          <td class="paramname">y&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td>&#160;&#160;&#160;((x) &gt; (y) ? (x) : (y))</td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Definition at line <a class="el" href="run_8c_source.html#l00023">23</a> of file <a class="el" href="run_8c_source.html">run.c</a>.</p>

</div>
</div>
<a class="anchor" id="a668b468f247abfce706ce6eaf6caecc9"></a><!-- doxytag: member="run.c::RESP_DATA" ref="a668b468f247abfce706ce6eaf6caecc9" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define RESP_DATA</td>
        </tr>
      </table>
</div>
<div class="memdoc">
<b>Value:</b><div class="fragment"><pre class="fragment"><span class="stringliteral">&quot;&lt;?xml version=\&quot;1.0\&quot; encoding=\&quot;iso-8859-1\&quot;?&gt;\n&quot;</span> \
                                                        <span class="stringliteral">&quot;&lt;!DOCTYPE html PUBLIC \&quot;-//W3C//DTD XHTML 1.0 Transitional//EN\&quot;\n&quot;</span> \
                                                        <span class="stringliteral">&quot; \&quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\&quot;&gt;\n&quot;</span> \
                                                        <span class="stringliteral">&quot;&lt;html xmlns=\&quot;http://www.w3.org/1999/xhtml\&quot; xml:lang=\&quot;en\&quot; lang=\&quot;en\&quot;&gt;\n&quot;</span> \
                                                        <span class="stringliteral">&quot;&lt;head&gt;&lt;title&gt;404 - Not Found&lt;/title&gt;&lt;/head&gt;&quot;</span> \
                                                        <span class="stringliteral">&quot;&lt;body&gt;&lt;h1&gt;404 - Not Found&lt;/h1&gt;&lt;/body&gt;&quot;</span> \
                                                        <span class="stringliteral">&quot;&lt;/html&gt;&quot;</span>
</pre></div>
</div>
</div>
<a class="anchor" id="a62de8b169a3e2f03f0e793aee87b3758"></a><!-- doxytag: member="run.c::RESP_HEAD" ref="a62de8b169a3e2f03f0e793aee87b3758" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define RESP_HEAD</td>
        </tr>
      </table>
</div>
<div class="memdoc">
<b>Value:</b><div class="fragment"><pre class="fragment"><span class="stringliteral">&quot;HTTP/1.1 404 Not Found\r\n&quot;</span> \
                                                        <span class="stringliteral">&quot;Content-Type: text/html\r\n&quot;</span> \
                                                        <span class="stringliteral">&quot;Content-Length: %lu\r\n&quot;</span> \
                                                        <span class="stringliteral">&quot;Date: %s\r\n&quot;</span> \
                                                        <span class="stringliteral">&quot;Server: testserver\r\n&quot;</span>
</pre></div>
</div>
</div>
<hr/><h2>Function Documentation</h2>
<a class="anchor" id="a67a4d9073b80d8ae1459fb11ddd23675"></a><!-- doxytag: member="run.c::serverRun" ref="a67a4d9073b80d8ae1459fb11ddd23675" args="(Server this)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void serverRun </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="structServer.html">Server</a>&#160;</td>
          <td class="paramname"><em>this</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p><p>: actually this is the main loop of my server. When stuff becomes more complicated it might be feasabible to split stuff into separate processes. This will definetly involve some IPC and syncing. Right now as this is actually only a simple HTTP server implementation we go on with this single process. What we can first do to get some processing between read/write cicles is to use the poll timeout.</p>
<p>handle accept</p>
<p>handle reads</p>
<p>do some other processing : actually this will hard assume that our stream reader is a http parser and it has its queue...think about more generalizing here.</p>
<p>: for now simply remove request and send not found. Make this sane.</p>
<p>: the complete response stuff have to be removed here.</p>
<p>: just to send an answer and be able to make some apache benchs i do it here...this definetly MUST BE moved</p>
<p>handle writes</p>
</p>

<p>Definition at line <a class="el" href="run_8c_source.html#l00030">30</a> of file <a class="el" href="run_8c_source.html">run.c</a>.</p>
<div class="fragment"><pre class="fragment">{
    <a class="code" href="interface_2logger_8h.html#ae9f8662ec8b300dcfb5064906937553e">loggerLog</a>(this-&gt;logger, <a class="code" href="logger_8h.html#a63296c69f4b9bf51d6756a5d2c482d1ea3a56c2c000665930df74a9ebf9047316">LOGGER_INFO</a>, <span class="stringliteral">&quot;service started&quot;</span>);

    <span class="keywordflow">while</span> (!<a class="code" href="signalHandling_8h.html#a960e985a396acaabb1bbed4f15668ade">doShutdown</a>) <span class="comment">/* until error or signal  */</span>
    {
                <span class="keywordtype">int</span>          events;
                <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> i;

                events = serverPoll(<span class="keyword">this</span>);
                <span class="keywordflow">if</span> (<a class="code" href="signalHandling_8h.html#a960e985a396acaabb1bbed4f15668ade">doShutdown</a>) <span class="keywordflow">break</span>;

                <span class="keywordflow">for</span> (i=0; i &lt; events; i++) {
                        <span class="keywordtype">int</span> fd = (this-&gt;fds)[i].fd;
                        <span class="comment">//int nreads = 0, nwrites = 0;</span>

                        <span class="keywordflow">if</span> (0 != ((this-&gt;fds)[i].revents &amp; POLLIN)) {
                                <span class="keywordflow">if</span> (this-&gt;sock-&gt;handle == (this-&gt;fds)[i].fd) {
                                        serverHandleAccept(<span class="keyword">this</span>);
                                }

                                <span class="keywordflow">else</span> {
                                        <span class="keywordtype">int</span> size;
                                        <span class="keywordflow">if</span> (0 &lt; (size=serverRead(<span class="keyword">this</span>, i))) {
                                                <span class="keywordtype">int</span>              j;
                                                <a class="code" href="structHttpRequestQueue.html">HttpRequestQueue</a> queue =
                                                        ((<a class="code" href="structHttpRequestParser.html">HttpRequestParser</a>)(this-&gt;conns)[fd].reader)-&gt;request_queue;

                                                <span class="keywordflow">for</span> (j=0; j&lt;queue-&gt;<a class="code" href="structHttpRequestQueue.html#a2bd08c36442f90e82b29b09f54a08682">nrequests</a>; j++) {
                                                        <a class="code" href="structHttpRequest.html">HttpRequest</a> request = queue-&gt;<a class="code" href="structHttpRequestQueue.html#a9413ed3fe003274c47618adde5335164">requests</a>[j];

                                                        <span class="comment">//if (NULL != request-&gt;body) {</span>
                                                        <span class="comment">//      puts(&quot;==REQUEST BODY==&quot;);</span>
                                                        <span class="comment">//      puts(request-&gt;body);</span>
                                                        <span class="comment">//}</span>

                                                        <span class="keyword">delete</span>(&amp;request);

                                                        time_t t;
                                                        <span class="keyword">struct </span>tm * tmp;
                                                        <span class="keywordtype">char</span> timestr[200];

<span class="preprocessor">#define RESP_HEAD &quot;HTTP/1.1 404 Not Found\r\n&quot; \</span>
<span class="preprocessor">                                                        &quot;Content-Type: text/html\r\n&quot; \</span>
<span class="preprocessor">                                                        &quot;Content-Length: %lu\r\n&quot; \</span>
<span class="preprocessor">                                                        &quot;Date: %s\r\n&quot; \</span>
<span class="preprocessor">                                                        &quot;Server: testserver\r\n&quot;</span>
<span class="preprocessor"></span>
<span class="preprocessor">#define RESP_DATA &quot;&lt;?xml version=\&quot;1.0\&quot; encoding=\&quot;iso-8859-1\&quot;?&gt;\n&quot; \</span>
<span class="preprocessor">                                                        &quot;&lt;!DOCTYPE html PUBLIC \&quot;-//W3C//DTD XHTML 1.0 Transitional//EN\&quot;\n&quot; \</span>
<span class="preprocessor">                                                        &quot; \&quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\&quot;&gt;\n&quot; \</span>
<span class="preprocessor">                                                        &quot;&lt;html xmlns=\&quot;http://www.w3.org/1999/xhtml\&quot; xml:lang=\&quot;en\&quot; lang=\&quot;en\&quot;&gt;\n&quot; \</span>
<span class="preprocessor">                                                        &quot;&lt;head&gt;&lt;title&gt;404 - Not Found&lt;/title&gt;&lt;/head&gt;&quot; \</span>
<span class="preprocessor">                                                        &quot;&lt;body&gt;&lt;h1&gt;404 - Not Found&lt;/h1&gt;&lt;/body&gt;&quot; \</span>
<span class="preprocessor">                                                        &quot;&lt;/html&gt;&quot;</span>
<span class="preprocessor"></span>
                                                        t = time(NULL);
                                                        tmp = localtime(&amp;t);
                                                        strftime(timestr, <span class="keyword">sizeof</span>(timestr), <span class="stringliteral">&quot;%a, %d %b %Y %T %Z&quot;</span>, tmp);

                                                        sprintf((this-&gt;conns)[fd].wbuf, RESP_HEAD <span class="stringliteral">&quot;\r\n&quot;</span> RESP_DATA, <span class="keyword">sizeof</span>(RESP_DATA), timestr);
                                                        (this-&gt;fds)[i].events = (this-&gt;fds)[i].events | POLLOUT;
                                                }

                                                queue-&gt;<a class="code" href="structHttpRequestQueue.html#a2bd08c36442f90e82b29b09f54a08682">nrequests</a> = 0;
                                        }
                                }
                        }

                        <span class="keywordflow">if</span> (0 != ((this-&gt;fds)[i].revents &amp; POLLOUT)) {
                                <span class="keywordtype">int</span> size;

                                size = write(
                                                (this-&gt;fds)[i].fd,
                                                (this-&gt;conns)[fd].wbuf,
                                                strlen((this-&gt;conns)[fd].wbuf));

                                <span class="keywordflow">if</span> (size == strlen((this-&gt;conns)[fd].wbuf) ||
                                                -1 == size) {
                                        <span class="keywordflow">if</span> (-1 == size) {
                                                <a class="code" href="interface_2logger_8h.html#ae9f8662ec8b300dcfb5064906937553e">loggerLog</a>(this-&gt;logger, <a class="code" href="logger_8h.html#a63296c69f4b9bf51d6756a5d2c482d1eadea66ab9219dfd6addc90edf08ed96fb">LOGGER_ERR</a>,
                                                                <span class="stringliteral">&quot;write error, closing connection&quot;</span>);
                                        }

                                        <a class="code" href="server_8h.html#a81f787254ea87cbc851d292e5a7d195d">serverCloseConn</a>(<span class="keyword">this</span>, i);
                                }
                                <span class="keywordflow">else</span> {
                                        memmove((this-&gt;conns)[fd].wbuf,
                                                        (this-&gt;conns)[fd].wbuf + size,
                                                        strlen((this-&gt;conns)[fd].wbuf) - size + 1);
                                }
                        }
                }
    }
}
</pre></div>
<p><div class="dynheader">
Here is the call graph for this function:</div>
<div class="dyncontent">
<div class="center"><img src="run_8c_a67a4d9073b80d8ae1459fb11ddd23675_cgraph.png" border="0" usemap="#run_8c_a67a4d9073b80d8ae1459fb11ddd23675_cgraph" alt=""/></div>
<map name="run_8c_a67a4d9073b80d8ae1459fb11ddd23675_cgraph" id="run_8c_a67a4d9073b80d8ae1459fb11ddd23675_cgraph">
<area shape="rect" id="node3" href="interface_2logger_8h.html#ae9f8662ec8b300dcfb5064906937553e" title="loggerLog" alt="" coords="161,5,241,33"/><area shape="rect" id="node5" href="server_8h.html#a81f787254ea87cbc851d292e5a7d195d" title="serverCloseConn" alt="" coords="139,55,264,83"/></map>
</div>
</p>

<p><div class="dynheader">
Here is the caller graph for this function:</div>
<div class="dyncontent">
<div class="center"><img src="run_8c_a67a4d9073b80d8ae1459fb11ddd23675_icgraph.png" border="0" usemap="#run_8c_a67a4d9073b80d8ae1459fb11ddd23675_icgraph" alt=""/></div>
<map name="run_8c_a67a4d9073b80d8ae1459fb11ddd23675_icgraph" id="run_8c_a67a4d9073b80d8ae1459fb11ddd23675_icgraph">
<area shape="rect" id="node3" href="testserver_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4" title="main" alt="" coords="139,5,189,33"/></map>
</div>
</p>

</div>
</div>
</div>
</div>
  <div id="nav-path" class="navpath">
    <ul>
      <li class="navelem"><a class="el" href="run_8c.html">run.c</a>      </li>
      <li class="footer">Generated on Thu Feb 9 2012 22:38:12 for server by&#160;
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.7.3 </li>
    </ul>
  </div>
<!--- window showing the filter options -->
<div id="MSearchSelectWindow"
     onmouseover="return searchBox.OnSearchSelectShow()"
     onmouseout="return searchBox.OnSearchSelectHide()"
     onkeydown="return searchBox.OnSearchSelectKey(event)">
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark">&#160;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&#160;</span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&#160;</span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&#160;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&#160;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&#160;</span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&#160;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&#160;</span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark">&#160;</span>Defines</a></div>

<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="" frameborder="0" 
        name="MSearchResults" id="MSearchResults">
</iframe>
</div>


</body>
</html>