<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> <meta http-equiv="X-UA-Compatible" content="IE=9"/> <meta name="generator" content="Doxygen 1.8.5"/> <title>GNU CommonC++: applog.h Source File</title> <link href="tabs.css" rel="stylesheet" type="text/css"/> <script type="text/javascript" src="jquery.js"></script> <script type="text/javascript" src="dynsections.js"></script> <link href="doxygen.css" rel="stylesheet" type="text/css" /> </head> <body> <div id="top"><!-- do not remove this div, it is closed by doxygen! --> <div id="titlearea"> <table cellspacing="0" cellpadding="0"> <tbody> <tr style="height: 56px;"> <td style="padding-left: 0.5em;"> <div id="projectname">GNU CommonC++ </div> </td> </tr> </tbody> </table> </div> <!-- end header part --> <!-- Generated by Doxygen 1.8.5 --> <div id="navrow1" class="tabs"> <ul class="tablist"> <li><a href="index.html"><span>Main Page</span></a></li> <li><a href="namespaces.html"><span>Namespaces</span></a></li> <li><a href="annotated.html"><span>Classes</span></a></li> <li class="current"><a href="files.html"><span>Files</span></a></li> <li><a href="examples.html"><span>Examples</span></a></li> </ul> </div> <div id="navrow2" class="tabs2"> <ul class="tablist"> <li><a href="files.html"><span>File List</span></a></li> <li><a href="globals.html"><span>File Members</span></a></li> </ul> </div> <div id="nav-path" class="navpath"> <ul> <li class="navelem"><a class="el" href="dir_bfccd401955b95cf8c75461437045ac0.html">inc</a></li><li class="navelem"><a class="el" href="dir_6b3e09e31d3da6038137f0238e9fb19b.html">cc++</a></li> </ul> </div> </div><!-- top --> <div class="header"> <div class="headertitle"> <div class="title">applog.h</div> </div> </div><!--header--> <div class="contents"> <a href="applog_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span> <span class="comment">// Copyright (C) 2005-2010 Angelo Naselli, Penta Engineering s.r.l.</span></div> <div class="line"><a name="l00002"></a><span class="lineno"> 2</span> <span class="comment">//</span></div> <div class="line"><a name="l00003"></a><span class="lineno"> 3</span> <span class="comment">// This program is free software; you can redistribute it and/or modify</span></div> <div class="line"><a name="l00004"></a><span class="lineno"> 4</span> <span class="comment">// it under the terms of the GNU General Public License as published by</span></div> <div class="line"><a name="l00005"></a><span class="lineno"> 5</span> <span class="comment">// the Free Software Foundation; either version 2 of the License, or</span></div> <div class="line"><a name="l00006"></a><span class="lineno"> 6</span> <span class="comment">// (at your option) any later version.</span></div> <div class="line"><a name="l00007"></a><span class="lineno"> 7</span> <span class="comment">//</span></div> <div class="line"><a name="l00008"></a><span class="lineno"> 8</span> <span class="comment">// but WITHOUT ANY WARRANTY; without even the implied warranty of</span></div> <div class="line"><a name="l00009"></a><span class="lineno"> 9</span> <span class="comment">// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the</span></div> <div class="line"><a name="l00010"></a><span class="lineno"> 10</span> <span class="comment">// GNU General Public License for more details.</span></div> <div class="line"><a name="l00011"></a><span class="lineno"> 11</span> <span class="comment">//</span></div> <div class="line"><a name="l00012"></a><span class="lineno"> 12</span> <span class="comment">// You should have received a copy of the GNU General Public License</span></div> <div class="line"><a name="l00013"></a><span class="lineno"> 13</span> <span class="comment">// along with this program; if not, write to the Free Software</span></div> <div class="line"><a name="l00014"></a><span class="lineno"> 14</span> <span class="comment">// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.</span></div> <div class="line"><a name="l00015"></a><span class="lineno"> 15</span> <span class="comment">//</span></div> <div class="line"><a name="l00016"></a><span class="lineno"> 16</span> <span class="comment">// As a special exception, you may use this file as part of a free software</span></div> <div class="line"><a name="l00017"></a><span class="lineno"> 17</span> <span class="comment">// library without restriction. Specifically, if other files instantiate</span></div> <div class="line"><a name="l00018"></a><span class="lineno"> 18</span> <span class="comment">// templates or use macros or inline functions from this file, or you compile</span></div> <div class="line"><a name="l00019"></a><span class="lineno"> 19</span> <span class="comment">// this file and link it with other files to produce an executable, this</span></div> <div class="line"><a name="l00020"></a><span class="lineno"> 20</span> <span class="comment">// file does not by itself cause the resulting executable to be covered by</span></div> <div class="line"><a name="l00021"></a><span class="lineno"> 21</span> <span class="comment">// the GNU General Public License. This exception does not however</span></div> <div class="line"><a name="l00022"></a><span class="lineno"> 22</span> <span class="comment">// invalidate any other reasons why the executable file might be covered by</span></div> <div class="line"><a name="l00023"></a><span class="lineno"> 23</span> <span class="comment">// the GNU General Public License.</span></div> <div class="line"><a name="l00024"></a><span class="lineno"> 24</span> <span class="comment">//</span></div> <div class="line"><a name="l00025"></a><span class="lineno"> 25</span> <span class="comment">// This exception applies only to the code released under the name GNU</span></div> <div class="line"><a name="l00026"></a><span class="lineno"> 26</span> <span class="comment">// Common C++. If you copy code from other releases into a copy of GNU</span></div> <div class="line"><a name="l00027"></a><span class="lineno"> 27</span> <span class="comment">// Common C++, as the General Public License permits, the exception does</span></div> <div class="line"><a name="l00028"></a><span class="lineno"> 28</span> <span class="comment">// not apply to the code that you add in this way. To avoid misleading</span></div> <div class="line"><a name="l00029"></a><span class="lineno"> 29</span> <span class="comment">// anyone as to the status of such modified files, you must delete</span></div> <div class="line"><a name="l00030"></a><span class="lineno"> 30</span> <span class="comment">// this exception notice from them.</span></div> <div class="line"><a name="l00031"></a><span class="lineno"> 31</span> <span class="comment">//</span></div> <div class="line"><a name="l00032"></a><span class="lineno"> 32</span> <span class="comment">// If you write modifications of your own for GNU Common C++, it is your choice</span></div> <div class="line"><a name="l00033"></a><span class="lineno"> 33</span> <span class="comment">// whether to permit this exception to apply to your modifications.</span></div> <div class="line"><a name="l00034"></a><span class="lineno"> 34</span> <span class="comment">// If you do not wish that, delete this exception notice.</span></div> <div class="line"><a name="l00035"></a><span class="lineno"> 35</span> <span class="comment">//</span></div> <div class="line"><a name="l00036"></a><span class="lineno"> 36</span> </div> <div class="line"><a name="l00043"></a><span class="lineno"> 43</span> <span class="preprocessor">#ifndef ___APPLOG_H___</span></div> <div class="line"><a name="l00044"></a><span class="lineno"> 44</span> <span class="preprocessor"></span><span class="preprocessor">#define ___APPLOG_H___</span></div> <div class="line"><a name="l00045"></a><span class="lineno"> 45</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00046"></a><span class="lineno"> 46</span> <span class="preprocessor">#ifndef CCXX_SLOG_H_</span></div> <div class="line"><a name="l00047"></a><span class="lineno"> 47</span> <span class="preprocessor"></span><span class="preprocessor">#include <<a class="code" href="slog_8h.html">cc++/slog.h</a>></span></div> <div class="line"><a name="l00048"></a><span class="lineno"> 48</span> <span class="preprocessor">#endif</span></div> <div class="line"><a name="l00049"></a><span class="lineno"> 49</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00050"></a><span class="lineno"> 50</span> <span class="preprocessor">#include <<a class="code" href="exception_8h.html">cc++/exception.h</a>></span></div> <div class="line"><a name="l00051"></a><span class="lineno"> 51</span> </div> <div class="line"><a name="l00052"></a><span class="lineno"> 52</span> <span class="preprocessor">#include <string></span></div> <div class="line"><a name="l00053"></a><span class="lineno"> 53</span> <span class="preprocessor">#include <sstream></span></div> <div class="line"><a name="l00054"></a><span class="lineno"> 54</span> <span class="preprocessor">#include <iostream></span></div> <div class="line"><a name="l00055"></a><span class="lineno"> 55</span> <span class="preprocessor">#include <map></span></div> <div class="line"><a name="l00056"></a><span class="lineno"> 56</span> </div> <div class="line"><a name="l00057"></a><span class="lineno"> 57</span> <span class="preprocessor">#ifdef CCXX_NAMESPACES</span></div> <div class="line"><a name="l00058"></a><span class="lineno"> 58</span> <span class="preprocessor"></span><span class="keyword">using namespace </span>std;</div> <div class="line"><a name="l00059"></a><span class="lineno"> 59</span> </div> <div class="line"><a name="l00060"></a><span class="lineno"> 60</span> <span class="keyword">namespace </span>ost</div> <div class="line"><a name="l00061"></a><span class="lineno"> 61</span> {</div> <div class="line"><a name="l00062"></a><span class="lineno"> 62</span> <span class="preprocessor">#endif</span></div> <div class="line"><a name="l00063"></a><span class="lineno"> 63</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00071"></a><span class="lineno"><a class="line" href="classost_1_1_h_e_xdump.html"> 71</a></span> <span class="keyword">class </span><a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <a class="code" href="classost_1_1_h_e_xdump.html">HEXdump</a></div> <div class="line"><a name="l00072"></a><span class="lineno"> 72</span> {</div> <div class="line"><a name="l00073"></a><span class="lineno"> 73</span>  <span class="keyword">protected</span>:</div> <div class="line"><a name="l00077"></a><span class="lineno"><a class="line" href="classost_1_1_h_e_xdump.html#a838834d8a6e61937fb604fa13eee60fb"> 77</a></span>  std::string <a class="code" href="classost_1_1_h_e_xdump.html#a838834d8a6e61937fb604fa13eee60fb">_str</a>;</div> <div class="line"><a name="l00078"></a><span class="lineno"> 78</span> </div> <div class="line"><a name="l00079"></a><span class="lineno"> 79</span>  <span class="keyword">public</span>:</div> <div class="line"><a name="l00080"></a><span class="lineno"> 80</span>  <span class="comment">// max_len: max number of bytes to be printed. 0 prints all.</span></div> <div class="line"><a name="l00089"></a><span class="lineno"> 89</span> <span class="comment"></span> <a class="code" href="classost_1_1_h_e_xdump.html">HEXdump</a>(<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *buffer, <span class="keywordtype">int</span> buff_len, <span class="keywordtype">int</span> max_len = 200);</div> <div class="line"><a name="l00090"></a><span class="lineno"> 90</span> </div> <div class="line"><a name="l00094"></a><span class="lineno"><a class="line" href="classost_1_1_h_e_xdump.html#abd509f740608db0e1a9bad4a77b8fbb6"> 94</a></span>  <span class="keyword">virtual</span> <a class="code" href="classost_1_1_h_e_xdump.html#abd509f740608db0e1a9bad4a77b8fbb6">~HEXdump</a>() { _str = string();}</div> <div class="line"><a name="l00095"></a><span class="lineno"> 95</span> </div> <div class="line"><a name="l00100"></a><span class="lineno"><a class="line" href="classost_1_1_h_e_xdump.html#a78ad113b39885750e7a791b56efc8112"> 100</a></span>  <span class="keyword">const</span> <span class="keywordtype">char</span> * <a class="code" href="classost_1_1_h_e_xdump.html#a78ad113b39885750e7a791b56efc8112">c_str</a>()<span class="keyword"> const</span></div> <div class="line"><a name="l00101"></a><span class="lineno"> 101</span> <span class="keyword"> </span>{</div> <div class="line"><a name="l00102"></a><span class="lineno"> 102</span>  <span class="keywordflow">return</span> _str.c_str();</div> <div class="line"><a name="l00103"></a><span class="lineno"> 103</span>  }</div> <div class="line"><a name="l00104"></a><span class="lineno"> 104</span> </div> <div class="line"><a name="l00108"></a><span class="lineno"><a class="line" href="classost_1_1_h_e_xdump.html#a278b3d7b7e72f1c6f795fca7fbb24ab5"> 108</a></span>  std::string <a class="code" href="classost_1_1_h_e_xdump.html#a278b3d7b7e72f1c6f795fca7fbb24ab5">str</a>()</div> <div class="line"><a name="l00109"></a><span class="lineno"> 109</span>  {</div> <div class="line"><a name="l00110"></a><span class="lineno"> 110</span>  <span class="keywordflow">return</span> _str;</div> <div class="line"><a name="l00111"></a><span class="lineno"> 111</span>  }</div> <div class="line"><a name="l00112"></a><span class="lineno"> 112</span> </div> <div class="line"><a name="l00118"></a><span class="lineno"><a class="line" href="classost_1_1_h_e_xdump.html#a603863bee72a824a89c3baf889825fd7"> 118</a></span>  <span class="keyword">friend</span> std::ostream& <a class="code" href="namespaceost.html#a43b65f3c2266eb63ba22c1ff73a6e20b">operator<< </a>(std::ostream& out, <span class="keyword">const</span> <a class="code" href="classost_1_1_h_e_xdump.html">HEXdump</a> &hd)</div> <div class="line"><a name="l00119"></a><span class="lineno"> 119</span>  {</div> <div class="line"><a name="l00120"></a><span class="lineno"> 120</span>  out << hd.<a class="code" href="classost_1_1_h_e_xdump.html#a78ad113b39885750e7a791b56efc8112">c_str</a>();</div> <div class="line"><a name="l00121"></a><span class="lineno"> 121</span>  <span class="keywordflow">return</span> out;</div> <div class="line"><a name="l00122"></a><span class="lineno"> 122</span>  }</div> <div class="line"><a name="l00123"></a><span class="lineno"> 123</span> </div> <div class="line"><a name="l00124"></a><span class="lineno"> 124</span> };</div> <div class="line"><a name="l00125"></a><span class="lineno"> 125</span> </div> <div class="line"><a name="l00126"></a><span class="lineno"> 126</span> <span class="preprocessor">#ifdef CCXX_EXCEPTIONS</span></div> <div class="line"><a name="l00127"></a><span class="lineno"> 127</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00131"></a><span class="lineno"> 131</span> <span class="keyword">class </span><a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> AppLogException : <span class="keyword">public</span> ost::Exception</div> <div class="line"><a name="l00132"></a><span class="lineno"> 132</span> {</div> <div class="line"><a name="l00133"></a><span class="lineno"> 133</span>  <span class="keyword">public</span>:</div> <div class="line"><a name="l00138"></a><span class="lineno"> 138</span>  AppLogException(<span class="keyword">const</span> std::string &what_arg) : ost::Exception(what_arg) {};</div> <div class="line"><a name="l00139"></a><span class="lineno"> 139</span> </div> <div class="line"><a name="l00140"></a><span class="lineno"> 140</span> };</div> <div class="line"><a name="l00141"></a><span class="lineno"> 141</span> <span class="preprocessor">#endif</span></div> <div class="line"><a name="l00142"></a><span class="lineno"> 142</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00143"></a><span class="lineno"> 143</span> <span class="keyword">class </span>AppLogPrivate;</div> <div class="line"><a name="l00144"></a><span class="lineno"> 144</span> </div> <div class="line"><a name="l00173"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html"> 173</a></span> <span class="keyword">class </span><a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <a class="code" href="classost_1_1_app_log.html">AppLog</a> : <span class="keyword">protected</span> streambuf, <span class="keyword">public</span> ostream</div> <div class="line"><a name="l00174"></a><span class="lineno"> 174</span> {</div> <div class="line"><a name="l00175"></a><span class="lineno"> 175</span>  <span class="keyword">protected</span>:</div> <div class="line"><a name="l00176"></a><span class="lineno"> 176</span>  <span class="comment">// d pointer</span></div> <div class="line"><a name="l00177"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#addfc3b19ad63afdec4c97de6761ddc81"> 177</a></span>  AppLogPrivate *<a class="code" href="classost_1_1_app_log.html#addfc3b19ad63afdec4c97de6761ddc81">d</a>;</div> <div class="line"><a name="l00178"></a><span class="lineno"> 178</span>  <span class="keywordtype">void</span> writeLog(<span class="keywordtype">bool</span> endOfLine = <span class="keyword">true</span>);</div> <div class="line"><a name="l00179"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#a6856a1e8dda262714294257163156196"> 179</a></span>  <span class="keyword">static</span> map<string, Slog::Level> *<a class="code" href="classost_1_1_app_log.html#a6856a1e8dda262714294257163156196">assoc</a>;</div> <div class="line"><a name="l00180"></a><span class="lineno"> 180</span> </div> <div class="line"><a name="l00181"></a><span class="lineno"> 181</span>  <span class="keyword">public</span>:</div> <div class="line"><a name="l00185"></a><span class="lineno"><a class="line" href="classost_1_1_app_log_1_1_ident.html"> 185</a></span>  <span class="keyword">class </span><a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <a class="code" href="classost_1_1_app_log_1_1_ident.html">Ident</a></div> <div class="line"><a name="l00186"></a><span class="lineno"> 186</span>  {</div> <div class="line"><a name="l00187"></a><span class="lineno"> 187</span>  <span class="keyword">private</span>:</div> <div class="line"><a name="l00188"></a><span class="lineno"> 188</span>  std::string _ident;</div> <div class="line"><a name="l00189"></a><span class="lineno"> 189</span>  <span class="keyword">public</span>:</div> <div class="line"><a name="l00190"></a><span class="lineno"> 190</span> </div> <div class="line"><a name="l00194"></a><span class="lineno"><a class="line" href="classost_1_1_app_log_1_1_ident.html#a6458be4fe6aacb582b6822b6cbfe6e04"> 194</a></span>  <a class="code" href="classost_1_1_app_log_1_1_ident.html#a6458be4fe6aacb582b6822b6cbfe6e04">Ident</a>() {};</div> <div class="line"><a name="l00195"></a><span class="lineno"> 195</span> </div> <div class="line"><a name="l00199"></a><span class="lineno"><a class="line" href="classost_1_1_app_log_1_1_ident.html#a9b68fbacbdfa3bf3994bc6972cfe0bd2"> 199</a></span>  <a class="code" href="classost_1_1_app_log_1_1_ident.html#a9b68fbacbdfa3bf3994bc6972cfe0bd2">~Ident</a>() {};</div> <div class="line"><a name="l00200"></a><span class="lineno"> 200</span> </div> <div class="line"><a name="l00204"></a><span class="lineno"><a class="line" href="classost_1_1_app_log_1_1_ident.html#ac3e34ed09c3d8ccd707252b88a32ee93"> 204</a></span>  <a class="code" href="classost_1_1_app_log_1_1_ident.html#ac3e34ed09c3d8ccd707252b88a32ee93">Ident</a>(<a class="code" href="classost_1_1_app_log_1_1_ident.html">Ident</a>& <span class="keywordtype">id</span>) {_ident = <span class="keywordtype">id</span>._ident;}</div> <div class="line"><a name="l00205"></a><span class="lineno"> 205</span> </div> <div class="line"><a name="l00209"></a><span class="lineno"><a class="line" href="classost_1_1_app_log_1_1_ident.html#aff90fa408df309cf8f4297879a8696d5"> 209</a></span>  <a class="code" href="classost_1_1_app_log_1_1_ident.html#aff90fa408df309cf8f4297879a8696d5">Ident</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *str) : _ident(str) {};</div> <div class="line"><a name="l00210"></a><span class="lineno"> 210</span> </div> <div class="line"><a name="l00214"></a><span class="lineno"><a class="line" href="classost_1_1_app_log_1_1_ident.html#af41c54dd075cebc48c9de7060d3a8f58"> 214</a></span>  std::string& <a class="code" href="classost_1_1_app_log_1_1_ident.html#af41c54dd075cebc48c9de7060d3a8f58">str</a>() {<span class="keywordflow">return</span> _ident;}</div> <div class="line"><a name="l00215"></a><span class="lineno"> 215</span> </div> <div class="line"><a name="l00219"></a><span class="lineno"><a class="line" href="classost_1_1_app_log_1_1_ident.html#a6fffb0b2292a5ae980195a299bccb622"> 219</a></span>  <a class="code" href="classost_1_1_app_log_1_1_ident.html">Ident</a>& operator= (std::string &st) {_ident = st; <span class="keywordflow">return</span> *<span class="keyword">this</span>;}</div> <div class="line"><a name="l00220"></a><span class="lineno"> 220</span> </div> <div class="line"><a name="l00224"></a><span class="lineno"><a class="line" href="classost_1_1_app_log_1_1_ident.html#a0cb957bd54e54ef621a07a3e1b8fd0b0"> 224</a></span>  <a class="code" href="classost_1_1_app_log_1_1_ident.html">Ident</a>& operator= (<span class="keyword">const</span> <span class="keywordtype">char</span> str[]) {_ident = str; <span class="keywordflow">return</span> *<span class="keyword">this</span>;}</div> <div class="line"><a name="l00225"></a><span class="lineno"> 225</span> </div> <div class="line"><a name="l00229"></a><span class="lineno"><a class="line" href="classost_1_1_app_log_1_1_ident.html#a4c75892c51ee36c04b5c0f0e79920b3a"> 229</a></span>  <span class="keyword">const</span> <span class="keywordtype">char</span>* <a class="code" href="classost_1_1_app_log_1_1_ident.html#a4c75892c51ee36c04b5c0f0e79920b3a">c_str</a>() {<span class="keywordflow">return</span> _ident.c_str();}</div> <div class="line"><a name="l00230"></a><span class="lineno"> 230</span>  };</div> <div class="line"><a name="l00231"></a><span class="lineno"> 231</span> </div> <div class="line"><a name="l00232"></a><span class="lineno"> 232</span> <span class="preprocessor">#ifndef WIN32</span></div> <div class="line"><a name="l00233"></a><span class="lineno"> 233</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00240"></a><span class="lineno"> 240</span>  <a class="code" href="classost_1_1_app_log.html">AppLog</a>(<span class="keyword">const</span> <span class="keywordtype">char</span>* logFileName = NULL, <span class="keywordtype">bool</span> logDirectly = <span class="keyword">false</span> , <span class="keywordtype">bool</span> usePipe = <span class="keyword">false</span>);</div> <div class="line"><a name="l00241"></a><span class="lineno"> 241</span> <span class="preprocessor">#else</span></div> <div class="line"><a name="l00242"></a><span class="lineno"> 242</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00248"></a><span class="lineno"> 248</span>  <a class="code" href="classost_1_1_app_log.html">AppLog</a>(<span class="keyword">const</span> <span class="keywordtype">char</span>* logFileName = NULL, <span class="keywordtype">bool</span> logDirectly = <span class="keyword">false</span>);</div> <div class="line"><a name="l00249"></a><span class="lineno"> 249</span> <span class="preprocessor">#endif</span></div> <div class="line"><a name="l00250"></a><span class="lineno"> 250</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00253"></a><span class="lineno"> 253</span>  <span class="keyword">virtual</span> ~<a class="code" href="classost_1_1_app_log.html">AppLog</a>();</div> <div class="line"><a name="l00254"></a><span class="lineno"> 254</span> </div> <div class="line"><a name="l00259"></a><span class="lineno"> 259</span>  <span class="keywordtype">void</span> subscribe();</div> <div class="line"><a name="l00260"></a><span class="lineno"> 260</span> </div> <div class="line"><a name="l00264"></a><span class="lineno"> 264</span>  <span class="keywordtype">void</span> unsubscribe();</div> <div class="line"><a name="l00265"></a><span class="lineno"> 265</span> </div> <div class="line"><a name="l00266"></a><span class="lineno"> 266</span> <span class="preprocessor">#ifndef WIN32</span></div> <div class="line"><a name="l00267"></a><span class="lineno"> 267</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00274"></a><span class="lineno"> 274</span>  <span class="keywordtype">void</span> logFileName(<span class="keyword">const</span> <span class="keywordtype">char</span>* FileName, <span class="keywordtype">bool</span> logDirectly = <span class="keyword">false</span>, <span class="keywordtype">bool</span> usePipe = <span class="keyword">false</span>);</div> <div class="line"><a name="l00275"></a><span class="lineno"> 275</span> <span class="preprocessor">#else</span></div> <div class="line"><a name="l00276"></a><span class="lineno"> 276</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00282"></a><span class="lineno"> 282</span>  <span class="keywordtype">void</span> logFileName(<span class="keyword">const</span> <span class="keywordtype">char</span>* FileName, <span class="keywordtype">bool</span> logDirectly = <span class="keyword">false</span>);</div> <div class="line"><a name="l00283"></a><span class="lineno"> 283</span> <span class="preprocessor">#endif</span></div> <div class="line"><a name="l00284"></a><span class="lineno"> 284</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00287"></a><span class="lineno"> 287</span>  <span class="keywordtype">void</span> close(<span class="keywordtype">void</span>);</div> <div class="line"><a name="l00288"></a><span class="lineno"> 288</span> </div> <div class="line"><a name="l00293"></a><span class="lineno"> 293</span>  <span class="keywordtype">void</span> level(<a class="code" href="classost_1_1_slog.html#a47ef36225607dba90b4be5012daccd7a">Slog::Level</a> enable);</div> <div class="line"><a name="l00294"></a><span class="lineno"> 294</span> </div> <div class="line"><a name="l00299"></a><span class="lineno"> 299</span>  <span class="keywordtype">void</span> clogEnable(<span class="keywordtype">bool</span> en = <span class="keyword">true</span>);</div> <div class="line"><a name="l00300"></a><span class="lineno"> 300</span> </div> <div class="line"><a name="l00305"></a><span class="lineno"> 305</span>  <span class="keywordtype">void</span> slogEnable(<span class="keywordtype">bool</span> en = <span class="keyword">true</span>);</div> <div class="line"><a name="l00306"></a><span class="lineno"> 306</span> </div> <div class="line"><a name="l00312"></a><span class="lineno"> 312</span>  <span class="keywordtype">void</span> identLevel(<span class="keyword">const</span> <span class="keywordtype">char</span> *ident, <a class="code" href="classost_1_1_slog.html#a47ef36225607dba90b4be5012daccd7a">Slog::Level</a> level);</div> <div class="line"><a name="l00313"></a><span class="lineno"> 313</span> </div> <div class="line"><a name="l00318"></a><span class="lineno"> 318</span>  <span class="keywordtype">void</span> open(<span class="keyword">const</span> <span class="keywordtype">char</span> *ident);</div> <div class="line"><a name="l00319"></a><span class="lineno"> 319</span> </div> <div class="line"><a name="l00325"></a><span class="lineno"> 325</span>  <span class="keyword">virtual</span> <span class="keywordtype">int</span> overflow(<span class="keywordtype">int</span> c);</div> <div class="line"><a name="l00326"></a><span class="lineno"> 326</span> </div> <div class="line"><a name="l00330"></a><span class="lineno"> 330</span>  <span class="keyword">virtual</span> <span class="keywordtype">int</span> sync();</div> <div class="line"><a name="l00331"></a><span class="lineno"> 331</span> </div> <div class="line"><a name="l00332"></a><span class="lineno"> 332</span> <span class="preprocessor">#ifdef HAVE_SNPRINTF</span></div> <div class="line"><a name="l00333"></a><span class="lineno"> 333</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00338"></a><span class="lineno"> 338</span>  <span class="keywordtype">void</span> <a class="code" href="namespaceost.html#a83dc8550b8ed793d67cdd61eb19c92ed">emerg</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *format, ...);</div> <div class="line"><a name="l00339"></a><span class="lineno"> 339</span> </div> <div class="line"><a name="l00344"></a><span class="lineno"> 344</span>  <span class="keywordtype">void</span> <a class="code" href="namespaceost.html#a1f2a71206461b2144eaf6a3e7150e5dd">alert</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *format, ...);</div> <div class="line"><a name="l00345"></a><span class="lineno"> 345</span> </div> <div class="line"><a name="l00350"></a><span class="lineno"> 350</span>  <span class="keywordtype">void</span> <a class="code" href="namespaceost.html#a5e16a3488a940fdefd3b54e9f472668b">critical</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *format, ...);</div> <div class="line"><a name="l00351"></a><span class="lineno"> 351</span> </div> <div class="line"><a name="l00356"></a><span class="lineno"> 356</span>  <span class="keywordtype">void</span> <a class="code" href="namespaceost.html#a61faeec2dc6ec946dc3e98979bd93124">error</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *format, ...);</div> <div class="line"><a name="l00357"></a><span class="lineno"> 357</span> </div> <div class="line"><a name="l00362"></a><span class="lineno"> 362</span>  <span class="keywordtype">void</span> <a class="code" href="namespaceost.html#a24dc8ba691e7376d9c19762e2701fa63">warn</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *format, ...);</div> <div class="line"><a name="l00363"></a><span class="lineno"> 363</span> </div> <div class="line"><a name="l00368"></a><span class="lineno"> 368</span>  <span class="keywordtype">void</span> <a class="code" href="namespaceost.html#a14670ea356ba2430da0221cd72532cdf">notice</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *format, ...);</div> <div class="line"><a name="l00369"></a><span class="lineno"> 369</span> </div> <div class="line"><a name="l00374"></a><span class="lineno"> 374</span>  <span class="keywordtype">void</span> <a class="code" href="namespaceost.html#a622b45d2f58d84c1d8c364763a97c2da">info</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *format, ...);</div> <div class="line"><a name="l00375"></a><span class="lineno"> 375</span> </div> <div class="line"><a name="l00380"></a><span class="lineno"> 380</span>  <span class="keywordtype">void</span> <a class="code" href="namespaceost.html#a60294b8e0dd5a8812580edd0446ac11a">debug</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *format, ...);</div> <div class="line"><a name="l00381"></a><span class="lineno"> 381</span> <span class="preprocessor">#endif</span></div> <div class="line"><a name="l00382"></a><span class="lineno"> 382</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00389"></a><span class="lineno"> 389</span>  <a class="code" href="classost_1_1_app_log.html">AppLog</a> &operator()(<span class="keyword">const</span> <span class="keywordtype">char</span> *ident, <a class="code" href="classost_1_1_slog.html#a47ef36225607dba90b4be5012daccd7a">Slog::Level</a> level = Slog::levelError);</div> <div class="line"><a name="l00390"></a><span class="lineno"> 390</span> </div> <div class="line"><a name="l00396"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#a673f799d6c818a46dac948e08dbefeb1"> 396</a></span>  <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a>& <a class="code" href="classost_1_1_app_log.html#a673f799d6c818a46dac948e08dbefeb1">operator()</a>(<a class="code" href="classost_1_1_app_log_1_1_ident.html">Ident</a> &ident)</div> <div class="line"><a name="l00397"></a><span class="lineno"> 397</span>  {</div> <div class="line"><a name="l00398"></a><span class="lineno"> 398</span>  open(ident.<a class="code" href="classost_1_1_app_log_1_1_ident.html#a4c75892c51ee36c04b5c0f0e79920b3a">c_str</a>());</div> <div class="line"><a name="l00399"></a><span class="lineno"> 399</span>  <span class="keywordflow">return</span> *<span class="keyword">this</span>;</div> <div class="line"><a name="l00400"></a><span class="lineno"> 400</span>  }</div> <div class="line"><a name="l00401"></a><span class="lineno"> 401</span> </div> <div class="line"><a name="l00407"></a><span class="lineno"> 407</span>  <a class="code" href="classost_1_1_app_log.html">AppLog</a> &operator()(<a class="code" href="classost_1_1_slog.html#a47ef36225607dba90b4be5012daccd7a">Slog::Level</a> level);</div> <div class="line"><a name="l00408"></a><span class="lineno"> 408</span> </div> <div class="line"><a name="l00414"></a><span class="lineno"> 414</span>  <a class="code" href="classost_1_1_app_log.html">AppLog</a>& <a class="code" href="namespaceost.html#a43b65f3c2266eb63ba22c1ff73a6e20b">operator<< </a>(<a class="code" href="classost_1_1_app_log.html">AppLog</a>& (*pfManipulator)(<a class="code" href="classost_1_1_app_log.html">AppLog</a>&));</div> <div class="line"><a name="l00415"></a><span class="lineno"> 415</span> </div> <div class="line"><a name="l00421"></a><span class="lineno"> 421</span>  <a class="code" href="classost_1_1_app_log.html">AppLog</a>& <a class="code" href="namespaceost.html#a43b65f3c2266eb63ba22c1ff73a6e20b">operator<< </a>(ostream& (*pfManipulator)(ostream&));</div> <div class="line"><a name="l00422"></a><span class="lineno"> 422</span> </div> <div class="line"><a name="l00423"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#a384f03d87c24cce6657ca9b2628ffabc"> 423</a></span>  <span class="keyword">friend</span> ostream& <a class="code" href="namespaceost.html#a43b65f3c2266eb63ba22c1ff73a6e20b">operator << </a>(ostream &out, <a class="code" href="classost_1_1_app_log.html">AppLog</a> & al)</div> <div class="line"><a name="l00424"></a><span class="lineno"> 424</span>  {</div> <div class="line"><a name="l00425"></a><span class="lineno"> 425</span>  <span class="keywordflow">return</span> al;</div> <div class="line"><a name="l00426"></a><span class="lineno"> 426</span>  }</div> <div class="line"><a name="l00427"></a><span class="lineno"> 427</span> </div> <div class="line"><a name="l00433"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#a5c9718f106182a1ec8b659c47c71a784"> 433</a></span>  <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a>& <a class="code" href="namespaceost.html#a43b65f3c2266eb63ba22c1ff73a6e20b">operator<< </a>(<a class="code" href="classost_1_1_app_log_1_1_ident.html">Ident</a> &ident)</div> <div class="line"><a name="l00434"></a><span class="lineno"> 434</span>  {</div> <div class="line"><a name="l00435"></a><span class="lineno"> 435</span>  open(ident.<a class="code" href="classost_1_1_app_log_1_1_ident.html#a4c75892c51ee36c04b5c0f0e79920b3a">c_str</a>());</div> <div class="line"><a name="l00436"></a><span class="lineno"> 436</span>  <span class="keywordflow">return</span> *<span class="keyword">this</span>;</div> <div class="line"><a name="l00437"></a><span class="lineno"> 437</span>  }</div> <div class="line"><a name="l00438"></a><span class="lineno"> 438</span> </div> <div class="line"><a name="l00439"></a><span class="lineno"> 439</span> </div> <div class="line"><a name="l00444"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#accb6db72e959657f69c0d77c748f8b59"> 444</a></span>  <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="classost_1_1_app_log.html#accb6db72e959657f69c0d77c748f8b59">warn</a>(<span class="keywordtype">void</span>)</div> <div class="line"><a name="l00445"></a><span class="lineno"> 445</span>  {<span class="keywordflow">return</span> operator()(Slog::levelWarning);}</div> <div class="line"><a name="l00446"></a><span class="lineno"> 446</span> </div> <div class="line"><a name="l00451"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#ab99b34d86684217522da9c40564cdb14"> 451</a></span>  <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="classost_1_1_app_log.html#ab99b34d86684217522da9c40564cdb14">error</a>(<span class="keywordtype">void</span>)</div> <div class="line"><a name="l00452"></a><span class="lineno"> 452</span>  { <span class="keywordflow">return</span> operator()(Slog::levelError);}</div> <div class="line"><a name="l00453"></a><span class="lineno"> 453</span> </div> <div class="line"><a name="l00458"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#af1bf30ea9b0d324cf66c04f2386b4390"> 458</a></span>  <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="classost_1_1_app_log.html#af1bf30ea9b0d324cf66c04f2386b4390">debug</a>(<span class="keywordtype">void</span>)</div> <div class="line"><a name="l00459"></a><span class="lineno"> 459</span>  {<span class="keywordflow">return</span> operator()(Slog::levelDebug);}</div> <div class="line"><a name="l00460"></a><span class="lineno"> 460</span> </div> <div class="line"><a name="l00465"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#a96dc36849c8d4b815c094b63ad8672ce"> 465</a></span>  <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="classost_1_1_app_log.html#a96dc36849c8d4b815c094b63ad8672ce">emerg</a>(<span class="keywordtype">void</span>)</div> <div class="line"><a name="l00466"></a><span class="lineno"> 466</span>  {<span class="keywordflow">return</span> operator()(Slog::levelEmergency);}</div> <div class="line"><a name="l00467"></a><span class="lineno"> 467</span> </div> <div class="line"><a name="l00472"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#aa2bbf94e5e3437f32ffa2622a67dfef1"> 472</a></span>  <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="classost_1_1_app_log.html#aa2bbf94e5e3437f32ffa2622a67dfef1">alert</a>(<span class="keywordtype">void</span>)</div> <div class="line"><a name="l00473"></a><span class="lineno"> 473</span>  {<span class="keywordflow">return</span> operator()(Slog::levelAlert);}</div> <div class="line"><a name="l00474"></a><span class="lineno"> 474</span> </div> <div class="line"><a name="l00479"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#a5b36002e1bcbd94380878e2b1dd8cf60"> 479</a></span>  <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="classost_1_1_app_log.html#a5b36002e1bcbd94380878e2b1dd8cf60">critical</a>(<span class="keywordtype">void</span>)</div> <div class="line"><a name="l00480"></a><span class="lineno"> 480</span>  {<span class="keywordflow">return</span> operator()(Slog::levelCritical);}</div> <div class="line"><a name="l00481"></a><span class="lineno"> 481</span> </div> <div class="line"><a name="l00486"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#ab9cc7122fa0d1f6b4e13abb99779f715"> 486</a></span>  <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="classost_1_1_app_log.html#ab9cc7122fa0d1f6b4e13abb99779f715">notice</a>(<span class="keywordtype">void</span>)</div> <div class="line"><a name="l00487"></a><span class="lineno"> 487</span>  {<span class="keywordflow">return</span> operator()(Slog::levelNotice);}</div> <div class="line"><a name="l00488"></a><span class="lineno"> 488</span> </div> <div class="line"><a name="l00493"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#ac014c749d07e07765fb42a947acee104"> 493</a></span>  <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="classost_1_1_app_log.html#ac014c749d07e07765fb42a947acee104">info</a>(<span class="keywordtype">void</span>)</div> <div class="line"><a name="l00494"></a><span class="lineno"> 494</span>  {<span class="keywordflow">return</span> operator()(Slog::levelInfo);}</div> <div class="line"><a name="l00495"></a><span class="lineno"> 495</span> </div> <div class="line"><a name="l00511"></a><span class="lineno"><a class="line" href="classost_1_1_app_log.html#a3373feee3364f5055a254a5631f0ba06"> 511</a></span>  <span class="keyword">static</span> <a class="code" href="classost_1_1_slog.html#a47ef36225607dba90b4be5012daccd7a">Slog::Level</a> <a class="code" href="classost_1_1_app_log.html#a3373feee3364f5055a254a5631f0ba06">levelTranslate</a>(<span class="keywordtype">string</span> name)</div> <div class="line"><a name="l00512"></a><span class="lineno"> 512</span>  {</div> <div class="line"><a name="l00513"></a><span class="lineno"> 513</span>  map<string, Slog::Level>::iterator it = assoc->find(name);</div> <div class="line"><a name="l00514"></a><span class="lineno"> 514</span> </div> <div class="line"><a name="l00515"></a><span class="lineno"> 515</span>  <span class="keywordflow">return</span> (it != assoc->end()) ? it->second : Slog::levelEmergency;</div> <div class="line"><a name="l00516"></a><span class="lineno"> 516</span>  }</div> <div class="line"><a name="l00517"></a><span class="lineno"> 517</span> </div> <div class="line"><a name="l00518"></a><span class="lineno"> 518</span> };</div> <div class="line"><a name="l00519"></a><span class="lineno"> 519</span> </div> <div class="line"><a name="l00525"></a><span class="lineno"><a class="line" href="namespaceost.html#a60294b8e0dd5a8812580edd0446ac11a"> 525</a></span> <a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="namespaceost.html#a60294b8e0dd5a8812580edd0446ac11a">debug</a>(<a class="code" href="classost_1_1_app_log.html">AppLog</a>& sl)</div> <div class="line"><a name="l00526"></a><span class="lineno"> 526</span> {<span class="keywordflow">return</span> sl.operator()(Slog::levelDebug);}</div> <div class="line"><a name="l00527"></a><span class="lineno"> 527</span> </div> <div class="line"><a name="l00533"></a><span class="lineno"><a class="line" href="namespaceost.html#a24dc8ba691e7376d9c19762e2701fa63"> 533</a></span> <a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="namespaceost.html#a24dc8ba691e7376d9c19762e2701fa63">warn</a>(<a class="code" href="classost_1_1_app_log.html">AppLog</a>& sl)</div> <div class="line"><a name="l00534"></a><span class="lineno"> 534</span> {<span class="keywordflow">return</span> sl.operator()(Slog::levelWarning);}</div> <div class="line"><a name="l00535"></a><span class="lineno"> 535</span> </div> <div class="line"><a name="l00541"></a><span class="lineno"><a class="line" href="namespaceost.html#a61faeec2dc6ec946dc3e98979bd93124"> 541</a></span> <a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="namespaceost.html#a61faeec2dc6ec946dc3e98979bd93124">error</a>(<a class="code" href="classost_1_1_app_log.html">AppLog</a>& sl)</div> <div class="line"><a name="l00542"></a><span class="lineno"> 542</span> { <span class="keywordflow">return</span> sl.operator()(Slog::levelError);}</div> <div class="line"><a name="l00543"></a><span class="lineno"> 543</span> </div> <div class="line"><a name="l00549"></a><span class="lineno"><a class="line" href="namespaceost.html#a83dc8550b8ed793d67cdd61eb19c92ed"> 549</a></span> <a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="namespaceost.html#a83dc8550b8ed793d67cdd61eb19c92ed">emerg</a>(<a class="code" href="classost_1_1_app_log.html">AppLog</a>& sl)</div> <div class="line"><a name="l00550"></a><span class="lineno"> 550</span> {<span class="keywordflow">return</span> sl.operator()(Slog::levelEmergency);}</div> <div class="line"><a name="l00551"></a><span class="lineno"> 551</span> </div> <div class="line"><a name="l00557"></a><span class="lineno"><a class="line" href="namespaceost.html#a1f2a71206461b2144eaf6a3e7150e5dd"> 557</a></span> <a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="namespaceost.html#a1f2a71206461b2144eaf6a3e7150e5dd">alert</a>(<a class="code" href="classost_1_1_app_log.html">AppLog</a>& sl)</div> <div class="line"><a name="l00558"></a><span class="lineno"> 558</span> {<span class="keywordflow">return</span> sl.operator()(Slog::levelAlert);}</div> <div class="line"><a name="l00559"></a><span class="lineno"> 559</span> </div> <div class="line"><a name="l00565"></a><span class="lineno"><a class="line" href="namespaceost.html#a5e16a3488a940fdefd3b54e9f472668b"> 565</a></span> <a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="namespaceost.html#a5e16a3488a940fdefd3b54e9f472668b">critical</a>(<a class="code" href="classost_1_1_app_log.html">AppLog</a>& sl)</div> <div class="line"><a name="l00566"></a><span class="lineno"> 566</span> {<span class="keywordflow">return</span> sl.operator()(Slog::levelCritical);}</div> <div class="line"><a name="l00567"></a><span class="lineno"> 567</span> </div> <div class="line"><a name="l00573"></a><span class="lineno"><a class="line" href="namespaceost.html#a14670ea356ba2430da0221cd72532cdf"> 573</a></span> <a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="namespaceost.html#a14670ea356ba2430da0221cd72532cdf">notice</a>(<a class="code" href="classost_1_1_app_log.html">AppLog</a>& sl)</div> <div class="line"><a name="l00574"></a><span class="lineno"> 574</span> {<span class="keywordflow">return</span> sl.operator()(Slog::levelNotice);}</div> <div class="line"><a name="l00575"></a><span class="lineno"> 575</span> </div> <div class="line"><a name="l00581"></a><span class="lineno"><a class="line" href="namespaceost.html#a622b45d2f58d84c1d8c364763a97c2da"> 581</a></span> <a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <span class="keyword">inline</span> <a class="code" href="classost_1_1_app_log.html">AppLog</a> &<a class="code" href="namespaceost.html#a622b45d2f58d84c1d8c364763a97c2da">info</a>(<a class="code" href="classost_1_1_app_log.html">AppLog</a>& sl)</div> <div class="line"><a name="l00582"></a><span class="lineno"> 582</span> {<span class="keywordflow">return</span> sl.operator()(Slog::levelInfo);}</div> <div class="line"><a name="l00583"></a><span class="lineno"> 583</span> </div> <div class="line"><a name="l00587"></a><span class="lineno"> 587</span> <a class="code" href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a> <span class="keyword">extern</span> AppLog <a class="code" href="namespaceost.html#ac345333eb0936b0bf9bef5e72cef1440">alog</a>;</div> <div class="line"><a name="l00588"></a><span class="lineno"> 588</span> </div> <div class="line"><a name="l00589"></a><span class="lineno"> 589</span> <span class="preprocessor">#ifdef CCXX_NAMESPACES</span></div> <div class="line"><a name="l00590"></a><span class="lineno"> 590</span> <span class="preprocessor"></span>} <span class="comment">//namespace</span></div> <div class="line"><a name="l00591"></a><span class="lineno"> 591</span> <span class="preprocessor">#endif</span></div> <div class="line"><a name="l00592"></a><span class="lineno"> 592</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00593"></a><span class="lineno"> 593</span> <span class="preprocessor">#endif //___APPLOG_H___</span></div> <div class="ttc" id="namespaceost_html_a1f2a71206461b2144eaf6a3e7150e5dd"><div class="ttname"><a href="namespaceost.html#a1f2a71206461b2144eaf6a3e7150e5dd">ost::alert</a></div><div class="ttdeci">__EXPORT AppLog & alert(AppLog &sl)</div><div class="ttdoc">Manipulator for alert level. </div><div class="ttdef"><b>Definition:</b> applog.h:557</div></div> <div class="ttc" id="classost_1_1_app_log_html_a5b36002e1bcbd94380878e2b1dd8cf60"><div class="ttname"><a href="classost_1_1_app_log.html#a5b36002e1bcbd94380878e2b1dd8cf60">ost::AppLog::critical</a></div><div class="ttdeci">AppLog & critical(void)</div><div class="ttdoc">critical level </div><div class="ttdef"><b>Definition:</b> applog.h:479</div></div> <div class="ttc" id="classost_1_1_app_log_html"><div class="ttname"><a href="classost_1_1_app_log.html">ost::AppLog</a></div><div class="ttdoc">Application logger is a class that implements a logger that can be used by applications to save log f...</div><div class="ttdef"><b>Definition:</b> applog.h:173</div></div> <div class="ttc" id="namespaceost_html_ac345333eb0936b0bf9bef5e72cef1440"><div class="ttname"><a href="namespaceost.html#ac345333eb0936b0bf9bef5e72cef1440">ost::alog</a></div><div class="ttdeci">__EXPORT AppLog alog</div><div class="ttdoc">alog global log stream definition </div></div> <div class="ttc" id="classost_1_1_app_log_1_1_ident_html_a6458be4fe6aacb582b6822b6cbfe6e04"><div class="ttname"><a href="classost_1_1_app_log_1_1_ident.html#a6458be4fe6aacb582b6822b6cbfe6e04">ost::AppLog::Ident::Ident</a></div><div class="ttdeci">Ident()</div><div class="ttdoc">Constructor. </div><div class="ttdef"><b>Definition:</b> applog.h:194</div></div> <div class="ttc" id="classost_1_1_app_log_html_ac014c749d07e07765fb42a947acee104"><div class="ttname"><a href="classost_1_1_app_log.html#ac014c749d07e07765fb42a947acee104">ost::AppLog::info</a></div><div class="ttdeci">AppLog & info(void)</div><div class="ttdoc">info level </div><div class="ttdef"><b>Definition:</b> applog.h:493</div></div> <div class="ttc" id="classost_1_1_app_log_1_1_ident_html"><div class="ttname"><a href="classost_1_1_app_log_1_1_ident.html">ost::AppLog::Ident</a></div><div class="ttdoc">Ident class that represents module name. </div><div class="ttdef"><b>Definition:</b> applog.h:185</div></div> <div class="ttc" id="classost_1_1_app_log_1_1_ident_html_a9b68fbacbdfa3bf3994bc6972cfe0bd2"><div class="ttname"><a href="classost_1_1_app_log_1_1_ident.html#a9b68fbacbdfa3bf3994bc6972cfe0bd2">ost::AppLog::Ident::~Ident</a></div><div class="ttdeci">~Ident()</div><div class="ttdoc">Desctructor. </div><div class="ttdef"><b>Definition:</b> applog.h:199</div></div> <div class="ttc" id="classost_1_1_h_e_xdump_html_a838834d8a6e61937fb604fa13eee60fb"><div class="ttname"><a href="classost_1_1_h_e_xdump.html#a838834d8a6e61937fb604fa13eee60fb">ost::HEXdump::_str</a></div><div class="ttdeci">std::string _str</div><div class="ttdoc">output string </div><div class="ttdef"><b>Definition:</b> applog.h:77</div></div> <div class="ttc" id="classost_1_1_app_log_html_a3373feee3364f5055a254a5631f0ba06"><div class="ttname"><a href="classost_1_1_app_log.html#a3373feee3364f5055a254a5631f0ba06">ost::AppLog::levelTranslate</a></div><div class="ttdeci">static Slog::Level levelTranslate(string name)</div><div class="ttdoc">Translates level from string to Slog::Level, useful for configuration files for instance. </div><div class="ttdef"><b>Definition:</b> applog.h:511</div></div> <div class="ttc" id="classost_1_1_app_log_html_accb6db72e959657f69c0d77c748f8b59"><div class="ttname"><a href="classost_1_1_app_log.html#accb6db72e959657f69c0d77c748f8b59">ost::AppLog::warn</a></div><div class="ttdeci">AppLog & warn(void)</div><div class="ttdoc">warn level </div><div class="ttdef"><b>Definition:</b> applog.h:444</div></div> <div class="ttc" id="config_8h_html_ad10ef148ba8327bd530fc6c32c1e181c"><div class="ttname"><a href="config_8h.html#ad10ef148ba8327bd530fc6c32c1e181c">__EXPORT</a></div><div class="ttdeci">#define __EXPORT</div><div class="ttdef"><b>Definition:</b> config.h:980</div></div> <div class="ttc" id="classost_1_1_app_log_1_1_ident_html_aff90fa408df309cf8f4297879a8696d5"><div class="ttname"><a href="classost_1_1_app_log_1_1_ident.html#aff90fa408df309cf8f4297879a8696d5">ost::AppLog::Ident::Ident</a></div><div class="ttdeci">Ident(const char *str)</div><div class="ttdoc">const char* constructor, provided for convenience. </div><div class="ttdef"><b>Definition:</b> applog.h:209</div></div> <div class="ttc" id="classost_1_1_h_e_xdump_html_abd509f740608db0e1a9bad4a77b8fbb6"><div class="ttname"><a href="classost_1_1_h_e_xdump.html#abd509f740608db0e1a9bad4a77b8fbb6">ost::HEXdump::~HEXdump</a></div><div class="ttdeci">virtual ~HEXdump()</div><div class="ttdoc">HEXdump destructor. </div><div class="ttdef"><b>Definition:</b> applog.h:94</div></div> <div class="ttc" id="classost_1_1_slog_html_a47ef36225607dba90b4be5012daccd7a"><div class="ttname"><a href="classost_1_1_slog.html#a47ef36225607dba90b4be5012daccd7a">ost::Slog::Level</a></div><div class="ttdeci">Level</div><div class="ttdef"><b>Definition:</b> slog.h:123</div></div> <div class="ttc" id="namespaceost_html_a24dc8ba691e7376d9c19762e2701fa63"><div class="ttname"><a href="namespaceost.html#a24dc8ba691e7376d9c19762e2701fa63">ost::warn</a></div><div class="ttdeci">__EXPORT AppLog & warn(AppLog &sl)</div><div class="ttdoc">Manipulator for warn level. </div><div class="ttdef"><b>Definition:</b> applog.h:533</div></div> <div class="ttc" id="exception_8h_html"><div class="ttname"><a href="exception_8h.html">exception.h</a></div><div class="ttdoc">GNU Common C++ exception model base classes. </div></div> <div class="ttc" id="classost_1_1_app_log_1_1_ident_html_ac3e34ed09c3d8ccd707252b88a32ee93"><div class="ttname"><a href="classost_1_1_app_log_1_1_ident.html#ac3e34ed09c3d8ccd707252b88a32ee93">ost::AppLog::Ident::Ident</a></div><div class="ttdeci">Ident(Ident &id)</div><div class="ttdoc">Copy constructor. </div><div class="ttdef"><b>Definition:</b> applog.h:204</div></div> <div class="ttc" id="classost_1_1_app_log_html_a6856a1e8dda262714294257163156196"><div class="ttname"><a href="classost_1_1_app_log.html#a6856a1e8dda262714294257163156196">ost::AppLog::assoc</a></div><div class="ttdeci">static map< string, Slog::Level > * assoc</div><div class="ttdef"><b>Definition:</b> applog.h:179</div></div> <div class="ttc" id="classost_1_1_app_log_html_ab9cc7122fa0d1f6b4e13abb99779f715"><div class="ttname"><a href="classost_1_1_app_log.html#ab9cc7122fa0d1f6b4e13abb99779f715">ost::AppLog::notice</a></div><div class="ttdeci">AppLog & notice(void)</div><div class="ttdoc">notice level </div><div class="ttdef"><b>Definition:</b> applog.h:486</div></div> <div class="ttc" id="classost_1_1_app_log_html_a96dc36849c8d4b815c094b63ad8672ce"><div class="ttname"><a href="classost_1_1_app_log.html#a96dc36849c8d4b815c094b63ad8672ce">ost::AppLog::emerg</a></div><div class="ttdeci">AppLog & emerg(void)</div><div class="ttdoc">emerg level </div><div class="ttdef"><b>Definition:</b> applog.h:465</div></div> <div class="ttc" id="namespaceost_html_a14670ea356ba2430da0221cd72532cdf"><div class="ttname"><a href="namespaceost.html#a14670ea356ba2430da0221cd72532cdf">ost::notice</a></div><div class="ttdeci">__EXPORT AppLog & notice(AppLog &sl)</div><div class="ttdoc">Manipulator for notice level. </div><div class="ttdef"><b>Definition:</b> applog.h:573</div></div> <div class="ttc" id="namespaceost_html_a5e16a3488a940fdefd3b54e9f472668b"><div class="ttname"><a href="namespaceost.html#a5e16a3488a940fdefd3b54e9f472668b">ost::critical</a></div><div class="ttdeci">__EXPORT AppLog & critical(AppLog &sl)</div><div class="ttdoc">Manipulator for critical level. </div><div class="ttdef"><b>Definition:</b> applog.h:565</div></div> <div class="ttc" id="classost_1_1_h_e_xdump_html"><div class="ttname"><a href="classost_1_1_h_e_xdump.html">ost::HEXdump</a></div><div class="ttdoc">Produces a dump of a buffer in a hexdump way with its code Ascii translation and relative buffer addr...</div><div class="ttdef"><b>Definition:</b> applog.h:71</div></div> <div class="ttc" id="namespaceost_html_a622b45d2f58d84c1d8c364763a97c2da"><div class="ttname"><a href="namespaceost.html#a622b45d2f58d84c1d8c364763a97c2da">ost::info</a></div><div class="ttdeci">__EXPORT AppLog & info(AppLog &sl)</div><div class="ttdoc">Manipulator for info level. </div><div class="ttdef"><b>Definition:</b> applog.h:581</div></div> <div class="ttc" id="classost_1_1_app_log_html_ab99b34d86684217522da9c40564cdb14"><div class="ttname"><a href="classost_1_1_app_log.html#ab99b34d86684217522da9c40564cdb14">ost::AppLog::error</a></div><div class="ttdeci">AppLog & error(void)</div><div class="ttdoc">error level </div><div class="ttdef"><b>Definition:</b> applog.h:451</div></div> <div class="ttc" id="classost_1_1_app_log_1_1_ident_html_af41c54dd075cebc48c9de7060d3a8f58"><div class="ttname"><a href="classost_1_1_app_log_1_1_ident.html#af41c54dd075cebc48c9de7060d3a8f58">ost::AppLog::Ident::str</a></div><div class="ttdeci">std::string & str()</div><div class="ttdoc">std::string cast. </div><div class="ttdef"><b>Definition:</b> applog.h:214</div></div> <div class="ttc" id="classost_1_1_h_e_xdump_html_a78ad113b39885750e7a791b56efc8112"><div class="ttname"><a href="classost_1_1_h_e_xdump.html#a78ad113b39885750e7a791b56efc8112">ost::HEXdump::c_str</a></div><div class="ttdeci">const char * c_str() const </div><div class="ttdoc">const char* cast provided for conveneince. </div><div class="ttdef"><b>Definition:</b> applog.h:100</div></div> <div class="ttc" id="classost_1_1_app_log_1_1_ident_html_a4c75892c51ee36c04b5c0f0e79920b3a"><div class="ttname"><a href="classost_1_1_app_log_1_1_ident.html#a4c75892c51ee36c04b5c0f0e79920b3a">ost::AppLog::Ident::c_str</a></div><div class="ttdeci">const char * c_str()</div><div class="ttdoc">const char* cast provided for conveneince. </div><div class="ttdef"><b>Definition:</b> applog.h:229</div></div> <div class="ttc" id="namespaceost_html_a43b65f3c2266eb63ba22c1ff73a6e20b"><div class="ttname"><a href="namespaceost.html#a43b65f3c2266eb63ba22c1ff73a6e20b">ost::operator<<</a></div><div class="ttdeci">__EXPORT std::ostream & operator<<(std::ostream &os, const IPV4Address &ia)</div></div> <div class="ttc" id="slog_8h_html"><div class="ttname"><a href="slog_8h.html">slog.h</a></div><div class="ttdoc">System logging facilities abstraction. </div></div> <div class="ttc" id="classost_1_1_app_log_html_af1bf30ea9b0d324cf66c04f2386b4390"><div class="ttname"><a href="classost_1_1_app_log.html#af1bf30ea9b0d324cf66c04f2386b4390">ost::AppLog::debug</a></div><div class="ttdeci">AppLog & debug(void)</div><div class="ttdoc">debug level </div><div class="ttdef"><b>Definition:</b> applog.h:458</div></div> <div class="ttc" id="classost_1_1_h_e_xdump_html_a278b3d7b7e72f1c6f795fca7fbb24ab5"><div class="ttname"><a href="classost_1_1_h_e_xdump.html#a278b3d7b7e72f1c6f795fca7fbb24ab5">ost::HEXdump::str</a></div><div class="ttdeci">std::string str()</div><div class="ttdoc">string cast provided for conveneince. </div><div class="ttdef"><b>Definition:</b> applog.h:108</div></div> <div class="ttc" id="classost_1_1_app_log_html_a673f799d6c818a46dac948e08dbefeb1"><div class="ttname"><a href="classost_1_1_app_log.html#a673f799d6c818a46dac948e08dbefeb1">ost::AppLog::operator()</a></div><div class="ttdeci">AppLog & operator()(Ident &ident)</div><div class="ttdoc">operator to change ident </div><div class="ttdef"><b>Definition:</b> applog.h:396</div></div> <div class="ttc" id="classost_1_1_app_log_html_aa2bbf94e5e3437f32ffa2622a67dfef1"><div class="ttname"><a href="classost_1_1_app_log.html#aa2bbf94e5e3437f32ffa2622a67dfef1">ost::AppLog::alert</a></div><div class="ttdeci">AppLog & alert(void)</div><div class="ttdoc">alert level </div><div class="ttdef"><b>Definition:</b> applog.h:472</div></div> <div class="ttc" id="namespaceost_html_a60294b8e0dd5a8812580edd0446ac11a"><div class="ttname"><a href="namespaceost.html#a60294b8e0dd5a8812580edd0446ac11a">ost::debug</a></div><div class="ttdeci">__EXPORT AppLog & debug(AppLog &sl)</div><div class="ttdoc">Manipulator for debug level. </div><div class="ttdef"><b>Definition:</b> applog.h:525</div></div> <div class="ttc" id="classost_1_1_app_log_html_addfc3b19ad63afdec4c97de6761ddc81"><div class="ttname"><a href="classost_1_1_app_log.html#addfc3b19ad63afdec4c97de6761ddc81">ost::AppLog::d</a></div><div class="ttdeci">AppLogPrivate * d</div><div class="ttdef"><b>Definition:</b> applog.h:177</div></div> <div class="ttc" id="namespaceost_html_a83dc8550b8ed793d67cdd61eb19c92ed"><div class="ttname"><a href="namespaceost.html#a83dc8550b8ed793d67cdd61eb19c92ed">ost::emerg</a></div><div class="ttdeci">__EXPORT AppLog & emerg(AppLog &sl)</div><div class="ttdoc">Manipulator for emerg level. </div><div class="ttdef"><b>Definition:</b> applog.h:549</div></div> <div class="ttc" id="namespaceost_html_a61faeec2dc6ec946dc3e98979bd93124"><div class="ttname"><a href="namespaceost.html#a61faeec2dc6ec946dc3e98979bd93124">ost::error</a></div><div class="ttdeci">__EXPORT AppLog & error(AppLog &sl)</div><div class="ttdoc">Manipulator for error level. </div><div class="ttdef"><b>Definition:</b> applog.h:541</div></div> </div><!-- fragment --></div><!-- contents --> <!-- start footer part --> <hr class="footer"/><address class="footer"><small> Generated on Thu Oct 17 2013 23:24:56 for GNU CommonC++ by  <a href="http://www.doxygen.org/index.html"> <img class="footer" src="doxygen.png" alt="doxygen"/> </a> 1.8.5 </small></address> </body> </html>