loggers_8hh_source.html 34.7 KB
Newer Older
garciay's avatar
garciay committed
<!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.13"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>ETSI STF525 / Internal Testing test suite: /home/vagrant/TriesAndDelete/etsi_its/framework/include/loggers.hh 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="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.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 id="projectalign" style="padding-left: 0.5em;">
   <div id="projectname">ETSI STF525 / Internal Testing test suite
   </div>
   <div id="projectbrief">This project provides an internal testing test suite and its associated Test Adapter/Codec</div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.13 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
$(function() {
  initMenu('',true,false,'search.php','Search');
  $(document).ready(function() { init_search(); });
});
</script>
<div id="main-nav"></div>
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
     onmouseover="return searchBox.OnSearchSelectShow()"
     onmouseout="return searchBox.OnSearchSelectHide()"
     onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>

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

<div id="nav-path" class="navpath">
  <ul>
<li class="navelem"><a class="el" href="dir_644e041c3a6521da7b27eba0e4eb2b95.html">framework</a></li><li class="navelem"><a class="el" href="dir_dd40116cd1cfebdc77a7c7114b29912e.html">include</a></li>  </ul>
</div>
</div><!-- top -->
<div class="header">
  <div class="headertitle">
<div class="title">loggers.hh</div>  </div>
</div><!--header-->
<div class="contents">
<a href="loggers_8hh.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;</div><div class="line"><a name="l00011"></a><span class="lineno">   11</span>&#160;<span class="preprocessor">#pragma once</span></div><div class="line"><a name="l00012"></a><span class="lineno">   12</span>&#160;</div><div class="line"><a name="l00013"></a><span class="lineno">   13</span>&#160;<span class="preprocessor">#include &lt;memory&gt;</span></div><div class="line"><a name="l00014"></a><span class="lineno">   14</span>&#160;<span class="preprocessor">#include &lt;map&gt;</span></div><div class="line"><a name="l00015"></a><span class="lineno">   15</span>&#160;<span class="preprocessor">#include &lt;string&gt;</span></div><div class="line"><a name="l00016"></a><span class="lineno">   16</span>&#160;<span class="preprocessor">#include &lt;ctime&gt;</span></div><div class="line"><a name="l00017"></a><span class="lineno">   17</span>&#160;<span class="preprocessor">#include &lt;cstdarg&gt;</span></div><div class="line"><a name="l00018"></a><span class="lineno">   18</span>&#160;</div><div class="line"><a name="l00033"></a><span class="lineno">   33</span>&#160;<span class="keyword">using namespace </span><a class="code" href="namespacestd.html">std</a>; <span class="comment">// Required for isnan()</span></div><div class="line"><a name="l00034"></a><span class="lineno">   34</span>&#160;<span class="preprocessor">#include &lt;TTCN3.hh&gt;</span></div><div class="line"><a name="l00035"></a><span class="lineno">   35</span>&#160;</div><div class="line"><a name="l00042"></a><span class="lineno"><a class="line" href="classloggers.html">   42</a></span>&#160;<span class="keyword">class </span><a class="code" href="classloggers.html">loggers</a> {</div><div class="line"><a name="l00043"></a><span class="lineno">   43</span>&#160;<span class="keyword">private</span>: </div><div class="line"><a name="l00044"></a><span class="lineno"><a class="line" href="classloggers.html#a82e10216399c19d5163000f9bc4e86dd">   44</a></span>&#160;  <span class="keyword">static</span> std::unique_ptr&lt;loggers&gt; <a class="code" href="classloggers.html#a82e10216399c19d5163000f9bc4e86dd">_instance</a>;   </div><div class="line"><a name="l00045"></a><span class="lineno"><a class="line" href="classloggers.html#af999d35c4c60c630258f66f81c9a33a2">   45</a></span>&#160;  std::map&lt;std::string, std::clock_t&gt; <a class="code" href="classloggers.html#af999d35c4c60c630258f66f81c9a33a2">_times</a>;  </div><div class="line"><a name="l00046"></a><span class="lineno">   46</span>&#160;</div><div class="line"><a name="l00052"></a><span class="lineno"><a class="line" href="classloggers.html#aa8a2258ab15b12927f974c36b4b68d65">   52</a></span>&#160;  <span class="keyword">explicit</span> <a class="code" href="classloggers.html#aa8a2258ab15b12927f974c36b4b68d65">loggers</a>() : _times() { };</div><div class="line"><a name="l00053"></a><span class="lineno">   53</span>&#160;</div><div class="line"><a name="l00054"></a><span class="lineno">   54</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> log_time_exec(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_fmt, ...);</div><div class="line"><a name="l00055"></a><span class="lineno">   55</span>&#160;</div><div class="line"><a name="l00056"></a><span class="lineno">   56</span>&#160;<span class="keyword">public</span>: </div><div class="line"><a name="l00057"></a><span class="lineno">   57</span>&#160;</div><div class="line"><a name="l00060"></a><span class="lineno"><a class="line" href="classloggers.html#a1d6a7861d319bc6137381822ee049936">   60</a></span>&#160;  <span class="keyword">virtual</span> <a class="code" href="classloggers.html#a1d6a7861d319bc6137381822ee049936">~loggers</a>() {};</div><div class="line"><a name="l00061"></a><span class="lineno">   61</span>&#160;</div><div class="line"><a name="l00067"></a><span class="lineno"><a class="line" href="classloggers.html#ae5b1e222942002f395e1e5bafdf9121a">   67</a></span>&#160;  <span class="keyword">static</span> <span class="keyword">inline</span> <a class="code" href="classloggers.html">loggers</a>&amp; get_instance() { <span class="keywordflow">return</span> *_instance.get(); };</div><div class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;    </div><div class="line"><a name="l00076"></a><span class="lineno">   76</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> <a class="code" href="classloggers.html#ae5b1e222942002f395e1e5bafdf9121a">log_to_hexa</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> TTCN_Buffer&amp; buffer);</div><div class="line"><a name="l00084"></a><span class="lineno">   84</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> log_to_hexa(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> OCTETSTRING&amp; msg);</div><div class="line"><a name="l00092"></a><span class="lineno">   92</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> log_to_hexa(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>* msg, <span class="keyword">const</span> <span class="keywordtype">size_t</span> msg_size);</div><div class="line"><a name="l00100"></a><span class="lineno">  100</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> log_msg(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> Base_Type&amp; p_type);</div><div class="line"><a name="l00108"></a><span class="lineno">  108</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> log(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_fmt, ...);</div><div class="line"><a name="l00109"></a><span class="lineno">  109</span>&#160;</div><div class="line"><a name="l00117"></a><span class="lineno">  117</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> user_msg(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> Base_Type&amp; p_type);</div><div class="line"><a name="l00125"></a><span class="lineno">  125</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> user(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_fmt, ...);</div><div class="line"><a name="l00126"></a><span class="lineno">  126</span>&#160;  </div><div class="line"><a name="l00134"></a><span class="lineno">  134</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> warning_msg(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> Base_Type&amp; p_type);</div><div class="line"><a name="l00142"></a><span class="lineno">  142</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> warning(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_fmt, ...);</div><div class="line"><a name="l00143"></a><span class="lineno">  143</span>&#160;  </div><div class="line"><a name="l00151"></a><span class="lineno">  151</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> error(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_fmt, ...);</div><div class="line"><a name="l00152"></a><span class="lineno">  152</span>&#160;</div><div class="line"><a name="l00159"></a><span class="lineno">  159</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> set_start_time(std::string&amp; p_time_key);</div><div class="line"><a name="l00167"></a><span class="lineno">  167</span>&#160;  <span class="keyword">inline</span> <span class="keywordtype">void</span> set_stop_time(std::string&amp; p_time_key, <span class="keywordtype">float</span>&amp; p_time);</div><div class="line"><a name="l00168"></a><span class="lineno">  168</span>&#160;}; <span class="comment">// End of class loggers</span></div><div class="line"><a name="l00169"></a><span class="lineno">  169</span>&#160;</div><div class="line"><a name="l00170"></a><span class="lineno">  170</span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#ae5b1e222942002f395e1e5bafdf9121a">loggers::log_to_hexa</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> TTCN_Buffer &amp; buffer)</div><div class="line"><a name="l00171"></a><span class="lineno">  171</span>&#160;{</div><div class="line"><a name="l00172"></a><span class="lineno">  172</span>&#160;  TTCN_Logger::begin_event(TTCN_Logger::DEBUG_UNQUALIFIED);</div><div class="line"><a name="l00173"></a><span class="lineno">  173</span>&#160;  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00174"></a><span class="lineno">  174</span>&#160;  buffer.log();</div><div class="line"><a name="l00175"></a><span class="lineno">  175</span>&#160;  TTCN_Logger::end_event();</div><div class="line"><a name="l00176"></a><span class="lineno">  176</span>&#160;}</div><div class="line"><a name="l00177"></a><span class="lineno">  177</span>&#160;</div><div class="line"><a name="l00178"></a><span class="lineno"><a class="line" href="classloggers.html#a6a1e272f6ad2c0f08d02dbb8f86c29f0">  178</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#ae5b1e222942002f395e1e5bafdf9121a">loggers::log_to_hexa</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> OCTETSTRING&amp; msg)</div><div class="line"><a name="l00179"></a><span class="lineno">  179</span>&#160;{</div><div class="line"><a name="l00180"></a><span class="lineno">  180</span>&#160;  TTCN_Logger::begin_event(TTCN_Logger::DEBUG_UNQUALIFIED);</div><div class="line"><a name="l00181"></a><span class="lineno">  181</span>&#160;  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00182"></a><span class="lineno">  182</span>&#160;  TTCN_Logger::log_event(<span class="stringliteral">&quot;Size: %d,\nMsg: &quot;</span>, msg.lengthof());</div><div class="line"><a name="l00183"></a><span class="lineno">  183</span>&#160;</div><div class="line"><a name="l00184"></a><span class="lineno">  184</span>&#160;  <span class="keywordflow">for</span>(<span class="keywordtype">int</span> i = 0; i &lt; msg.lengthof(); i++) {</div><div class="line"><a name="l00185"></a><span class="lineno">  185</span>&#160;    TTCN_Logger::log_event(<span class="stringliteral">&quot; %02x&quot;</span>, ((<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>*)msg)[i]);</div><div class="line"><a name="l00186"></a><span class="lineno">  186</span>&#160;  }</div><div class="line"><a name="l00187"></a><span class="lineno">  187</span>&#160;  TTCN_Logger::log_event(<span class="stringliteral">&quot;\n&quot;</span>);</div><div class="line"><a name="l00188"></a><span class="lineno">  188</span>&#160;  TTCN_Logger::end_event();</div><div class="line"><a name="l00189"></a><span class="lineno">  189</span>&#160;}</div><div class="line"><a name="l00190"></a><span class="lineno">  190</span>&#160;</div><div class="line"><a name="l00191"></a><span class="lineno"><a class="line" href="classloggers.html#a738c7c0bbd7c27f64f053817050251ba">  191</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#ae5b1e222942002f395e1e5bafdf9121a">loggers::log_to_hexa</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>* msg, <span class="keyword">const</span> <span class="keywordtype">size_t</span> msg_size)</div><div class="line"><a name="l00192"></a><span class="lineno">  192</span>&#160;{</div><div class="line"><a name="l00193"></a><span class="lineno">  193</span>&#160;  TTCN_Logger::begin_event(TTCN_Logger::DEBUG_UNQUALIFIED);</div><div class="line"><a name="l00194"></a><span class="lineno">  194</span>&#160;  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00195"></a><span class="lineno">  195</span>&#160;  <span class="keywordflow">for</span>(<span class="keywordtype">size_t</span> i = 0; i &lt; msg_size; i++) {</div><div class="line"><a name="l00196"></a><span class="lineno">  196</span>&#160;    TTCN_Logger::log_event(<span class="stringliteral">&quot; %02x&quot;</span>, *(msg + i));</div><div class="line"><a name="l00197"></a><span class="lineno">  197</span>&#160;  }</div><div class="line"><a name="l00198"></a><span class="lineno">  198</span>&#160;  TTCN_Logger::log_event(<span class="stringliteral">&quot;\n&quot;</span>);</div><div class="line"><a name="l00199"></a><span class="lineno">  199</span>&#160;  TTCN_Logger::end_event();</div><div class="line"><a name="l00200"></a><span class="lineno">  200</span>&#160;}</div><div class="line"><a name="l00201"></a><span class="lineno">  201</span>&#160;</div><div class="line"><a name="l00202"></a><span class="lineno"><a class="line" href="classloggers.html#ac7a0c88774d5fe9bf65722309f9fac80">  202</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#ac7a0c88774d5fe9bf65722309f9fac80">loggers::log_msg</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> Base_Type&amp; p_type)</div><div class="line"><a name="l00203"></a><span class="lineno">  203</span>&#160;{</div><div class="line"><a name="l00204"></a><span class="lineno">  204</span>&#160;  TTCN_Logger::begin_event(TTCN_Logger::DEBUG_UNQUALIFIED);</div><div class="line"><a name="l00205"></a><span class="lineno">  205</span>&#160;  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00206"></a><span class="lineno">  206</span>&#160;  p_type.log();</div><div class="line"><a name="l00207"></a><span class="lineno">  207</span>&#160;  TTCN_Logger::end_event();</div><div class="line"><a name="l00208"></a><span class="lineno">  208</span>&#160;}</div><div class="line"><a name="l00209"></a><span class="lineno">  209</span>&#160;</div><div class="line"><a name="l00210"></a><span class="lineno"><a class="line" href="classloggers.html#a329cb6d52eaa63b891f4d462ce0217a0">  210</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#a329cb6d52eaa63b891f4d462ce0217a0">loggers::log</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_fmt, ...)</div><div class="line"><a name="l00211"></a><span class="lineno">  211</span>&#160;{</div><div class="line"><a name="l00212"></a><span class="lineno">  212</span>&#160;  TTCN_Logger::begin_event(TTCN_Logger::DEBUG_UNQUALIFIED);</div><div class="line"><a name="l00213"></a><span class="lineno">  213</span>&#160;  va_list args;</div><div class="line"><a name="l00214"></a><span class="lineno">  214</span>&#160;  va_start(args, p_fmt);</div><div class="line"><a name="l00215"></a><span class="lineno">  215</span>&#160;  TTCN_Logger::log_event_va_list(p_fmt, args);</div><div class="line"><a name="l00216"></a><span class="lineno">  216</span>&#160;  va_end(args);</div><div class="line"><a name="l00217"></a><span class="lineno">  217</span>&#160;  TTCN_Logger::end_event();</div><div class="line"><a name="l00218"></a><span class="lineno">  218</span>&#160;}</div><div class="line"><a name="l00219"></a><span class="lineno">  219</span>&#160;</div><div class="line"><a name="l00220"></a><span class="lineno"><a class="line" href="classloggers.html#af5403ed11b848a6760d9e862fb9b1958">  220</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#af5403ed11b848a6760d9e862fb9b1958">loggers::user_msg</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> Base_Type&amp; p_type)</div><div class="line"><a name="l00221"></a><span class="lineno">  221</span>&#160;{</div><div class="line"><a name="l00222"></a><span class="lineno">  222</span>&#160;  TTCN_Logger::begin_event(TTCN_Logger::USER_UNQUALIFIED);</div><div class="line"><a name="l00223"></a><span class="lineno">  223</span>&#160;  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00224"></a><span class="lineno">  224</span>&#160;  p_type.log();</div><div class="line"><a name="l00225"></a><span class="lineno">  225</span>&#160;  TTCN_Logger::end_event();</div><div class="line"><a name="l00226"></a><span class="lineno">  226</span>&#160;}</div><div class="line"><a name="l00227"></a><span class="lineno">  227</span>&#160;</div><div class="line"><a name="l00228"></a><span class="lineno"><a class="line" href="classloggers.html#a7f76b393efa2a06f0ab8ba551f789156">  228</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#a7f76b393efa2a06f0ab8ba551f789156">loggers::user</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_fmt, ...)</div><div class="line"><a name="l00229"></a><span class="lineno">  229</span>&#160;{</div><div class="line"><a name="l00230"></a><span class="lineno">  230</span>&#160;  TTCN_Logger::begin_event(TTCN_Logger::USER_UNQUALIFIED);</div><div class="line"><a name="l00231"></a><span class="lineno">  231</span>&#160;  va_list args;</div><div class="line"><a name="l00232"></a><span class="lineno">  232</span>&#160;  va_start(args, p_fmt);</div><div class="line"><a name="l00233"></a><span class="lineno">  233</span>&#160;  TTCN_Logger::log_event_va_list(p_fmt, args);</div><div class="line"><a name="l00234"></a><span class="lineno">  234</span>&#160;  va_end(args);</div><div class="line"><a name="l00235"></a><span class="lineno">  235</span>&#160;  TTCN_Logger::end_event();</div><div class="line"><a name="l00236"></a><span class="lineno">  236</span>&#160;}</div><div class="line"><a name="l00237"></a><span class="lineno">  237</span>&#160;</div><div class="line"><a name="l00238"></a><span class="lineno"><a class="line" href="classloggers.html#a8bd538744863c9d60d8e31efe3eef3aa">  238</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#a8bd538744863c9d60d8e31efe3eef3aa">loggers::warning</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_fmt, ...)</div><div class="line"><a name="l00239"></a><span class="lineno">  239</span>&#160;{</div><div class="line"><a name="l00240"></a><span class="lineno">  240</span>&#160;  TTCN_Logger::begin_event(TTCN_Logger::WARNING_UNQUALIFIED);</div><div class="line"><a name="l00241"></a><span class="lineno">  241</span>&#160;  va_list args;</div><div class="line"><a name="l00242"></a><span class="lineno">  242</span>&#160;  va_start(args, p_fmt);</div><div class="line"><a name="l00243"></a><span class="lineno">  243</span>&#160;  TTCN_Logger::log_event_va_list(p_fmt, args);</div><div class="line"><a name="l00244"></a><span class="lineno">  244</span>&#160;  va_end(args);</div><div class="line"><a name="l00245"></a><span class="lineno">  245</span>&#160;  TTCN_Logger::end_event();</div><div class="line"><a name="l00246"></a><span class="lineno">  246</span>&#160;}</div><div class="line"><a name="l00247"></a><span class="lineno">  247</span>&#160;</div><div class="line"><a name="l00248"></a><span class="lineno"><a class="line" href="classloggers.html#aee3482dc0fea0b0f38678487d9421f9e">  248</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#aee3482dc0fea0b0f38678487d9421f9e">loggers::warning_msg</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_prompt, <span class="keyword">const</span> Base_Type&amp; p_type)</div><div class="line"><a name="l00249"></a><span class="lineno">  249</span>&#160;{</div><div class="line"><a name="l00250"></a><span class="lineno">  250</span>&#160;  TTCN_Logger::begin_event(TTCN_Logger::WARNING_UNQUALIFIED);</div><div class="line"><a name="l00251"></a><span class="lineno">  251</span>&#160;  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00252"></a><span class="lineno">  252</span>&#160;  p_type.log();</div><div class="line"><a name="l00253"></a><span class="lineno">  253</span>&#160;  TTCN_Logger::end_event();</div><div class="line"><a name="l00254"></a><span class="lineno">  254</span>&#160;}</div><div class="line"><a name="l00255"></a><span class="lineno">  255</span>&#160;</div><div class="line"><a name="l00256"></a><span class="lineno"><a class="line" href="classloggers.html#ab766757bc69b4a3f8f3427186ad89ec1">  256</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#ab766757bc69b4a3f8f3427186ad89ec1">loggers::error</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_fmt, ...)</div><div class="line"><a name="l00257"></a><span class="lineno">  257</span>&#160;{</div><div class="line"><a name="l00258"></a><span class="lineno">  258</span>&#160;  va_list args;</div><div class="line"><a name="l00259"></a><span class="lineno">  259</span>&#160;  va_start(args, p_fmt);</div><div class="line"><a name="l00260"></a><span class="lineno">  260</span>&#160;  TTCN_error(p_fmt, args);</div><div class="line"><a name="l00261"></a><span class="lineno">  261</span>&#160;  va_end(args);</div><div class="line"><a name="l00262"></a><span class="lineno">  262</span>&#160;}</div><div class="line"><a name="l00263"></a><span class="lineno">  263</span>&#160;</div><div class="line"><a name="l00264"></a><span class="lineno"><a class="line" href="classloggers.html#adc3628cb6ea90b2d691f85948ee64dc8">  264</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#adc3628cb6ea90b2d691f85948ee64dc8">loggers::set_start_time</a>(std::string&amp; p_time_key)</div><div class="line"><a name="l00265"></a><span class="lineno">  265</span>&#160;{</div><div class="line"><a name="l00266"></a><span class="lineno">  266</span>&#160;  _times[p_time_key] = std::clock();</div><div class="line"><a name="l00267"></a><span class="lineno">  267</span>&#160;}</div><div class="line"><a name="l00268"></a><span class="lineno">  268</span>&#160;  </div><div class="line"><a name="l00269"></a><span class="lineno"><a class="line" href="classloggers.html#ab7e59a4638b88a16b7d2ca9aea9644d0">  269</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#ab7e59a4638b88a16b7d2ca9aea9644d0">loggers::set_stop_time</a>(std::string&amp; p_time_key, <span class="keywordtype">float</span>&amp; p_time)</div><div class="line"><a name="l00270"></a><span class="lineno">  270</span>&#160;{</div><div class="line"><a name="l00271"></a><span class="lineno">  271</span>&#160;  std::map&lt;std::string, std::clock_t&gt;::iterator it = _times.find(p_time_key);</div><div class="line"><a name="l00272"></a><span class="lineno">  272</span>&#160;  <span class="keywordflow">if</span> (it != <a class="code" href="classloggers.html#af999d35c4c60c630258f66f81c9a33a2">loggers::_times</a>.end()) {</div><div class="line"><a name="l00273"></a><span class="lineno">  273</span>&#160;    p_time = (std::clock() - _times[p_time_key]) * 1000.0 / CLOCKS_PER_SEC; <span class="comment">// in milliseconds</span></div><div class="line"><a name="l00274"></a><span class="lineno">  274</span>&#160;    _times.erase(it);</div><div class="line"><a name="l00275"></a><span class="lineno">  275</span>&#160;    <a class="code" href="classloggers.html#ad12a3690baf8f929e8b565821f8db4cb">loggers::get_instance</a>().<a class="code" href="classloggers.html#a355a8824e5211a20dbd59ea9dbf33891">log_time_exec</a>(<span class="stringliteral">&quot;%s: Execution duration: %f ms&quot;</span>, p_time_key.c_str(), p_time);</div><div class="line"><a name="l00276"></a><span class="lineno">  276</span>&#160;    </div><div class="line"><a name="l00277"></a><span class="lineno">  277</span>&#160;  }</div><div class="line"><a name="l00278"></a><span class="lineno">  278</span>&#160;}</div><div class="line"><a name="l00279"></a><span class="lineno">  279</span>&#160;</div><div class="line"><a name="l00280"></a><span class="lineno"><a class="line" href="classloggers.html#a355a8824e5211a20dbd59ea9dbf33891">  280</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classloggers.html#a355a8824e5211a20dbd59ea9dbf33891">loggers::log_time_exec</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> *p_fmt, ...)</div><div class="line"><a name="l00281"></a><span class="lineno">  281</span>&#160;{</div><div class="line"><a name="l00282"></a><span class="lineno">  282</span>&#160;  TTCN_Logger::begin_event(TTCN_Logger::EXECUTOR_RUNTIME);</div><div class="line"><a name="l00283"></a><span class="lineno">  283</span>&#160;  va_list args;</div><div class="line"><a name="l00284"></a><span class="lineno">  284</span>&#160;  va_start(args, p_fmt);</div><div class="line"><a name="l00285"></a><span class="lineno">  285</span>&#160;  TTCN_Logger::log_event_va_list(p_fmt, args);</div><div class="line"><a name="l00286"></a><span class="lineno">  286</span>&#160;  va_end(args);</div><div class="line"><a name="l00287"></a><span class="lineno">  287</span>&#160;  TTCN_Logger::end_event();</div><div class="line"><a name="l00288"></a><span class="lineno">  288</span>&#160;}</div><div class="line"><a name="l00289"></a><span class="lineno">  289</span>&#160;</div><div class="ttc" id="classloggers_html_a8bd538744863c9d60d8e31efe3eef3aa"><div class="ttname"><a href="classloggers.html#a8bd538744863c9d60d8e31efe3eef3aa">loggers::warning</a></div><div class="ttdeci">void warning(const char *p_fmt,...)</div><div class="ttdef"><b>Definition:</b> loggers.hh:238</div></div>
<div class="ttc" id="classloggers_html_a329cb6d52eaa63b891f4d462ce0217a0"><div class="ttname"><a href="classloggers.html#a329cb6d52eaa63b891f4d462ce0217a0">loggers::log</a></div><div class="ttdeci">void log(const char *p_fmt,...)</div><div class="ttdoc">Debug message based on printf-compliant formatting message. </div><div class="ttdef"><b>Definition:</b> loggers.hh:210</div></div>
<div class="ttc" id="classloggers_html_ae5b1e222942002f395e1e5bafdf9121a"><div class="ttname"><a href="classloggers.html#ae5b1e222942002f395e1e5bafdf9121a">loggers::log_to_hexa</a></div><div class="ttdeci">void log_to_hexa(const char *p_prompt, const TTCN_Buffer &amp;buffer)</div><div class="ttdoc">Hexa dump of the. </div><div class="ttdef"><b>Definition:</b> loggers.hh:67</div></div>
<div class="ttc" id="classloggers_html_aa8a2258ab15b12927f974c36b4b68d65"><div class="ttname"><a href="classloggers.html#aa8a2258ab15b12927f974c36b4b68d65">loggers::loggers</a></div><div class="ttdeci">loggers()</div><div class="ttdoc">Timer used to measure execution time between calls to methods ::set_start_time and ::set_stop_time...</div><div class="ttdef"><b>Definition:</b> loggers.hh:52</div></div>
<div class="ttc" id="namespacestd_html"><div class="ttname"><a href="namespacestd.html">std</a></div></div>
<div class="ttc" id="classloggers_html_a1d6a7861d319bc6137381822ee049936"><div class="ttname"><a href="classloggers.html#a1d6a7861d319bc6137381822ee049936">loggers::~loggers</a></div><div class="ttdeci">virtual ~loggers()</div><div class="ttdoc">Default destructor. </div><div class="ttdef"><b>Definition:</b> loggers.hh:60</div></div>
<div class="ttc" id="classloggers_html_af5403ed11b848a6760d9e862fb9b1958"><div class="ttname"><a href="classloggers.html#af5403ed11b848a6760d9e862fb9b1958">loggers::user_msg</a></div><div class="ttdeci">void user_msg(const char *p_prompt, const Base_Type &amp;p_type)</div><div class="ttdoc">User message of TITAN data structures. </div><div class="ttdef"><b>Definition:</b> loggers.hh:220</div></div>
<div class="ttc" id="classloggers_html_ac7a0c88774d5fe9bf65722309f9fac80"><div class="ttname"><a href="classloggers.html#ac7a0c88774d5fe9bf65722309f9fac80">loggers::log_msg</a></div><div class="ttdeci">void log_msg(const char *p_prompt, const Base_Type &amp;p_type)</div><div class="ttdoc">Debug log of TITAN data structures. </div><div class="ttdef"><b>Definition:</b> loggers.hh:202</div></div>
<div class="ttc" id="classloggers_html_af999d35c4c60c630258f66f81c9a33a2"><div class="ttname"><a href="classloggers.html#af999d35c4c60c630258f66f81c9a33a2">loggers::_times</a></div><div class="ttdeci">std::map&lt; std::string, std::clock_t &gt; _times</div><div class="ttdoc">Smart pointer to the unique instance of the logger framework. </div><div class="ttdef"><b>Definition:</b> loggers.hh:45</div></div>
<div class="ttc" id="classloggers_html_a82e10216399c19d5163000f9bc4e86dd"><div class="ttname"><a href="classloggers.html#a82e10216399c19d5163000f9bc4e86dd">loggers::_instance</a></div><div class="ttdeci">static std::unique_ptr&lt; loggers &gt; _instance</div><div class="ttdef"><b>Definition:</b> loggers.hh:44</div></div>
<div class="ttc" id="classloggers_html"><div class="ttname"><a href="classloggers.html">loggers</a></div><div class="ttdoc">This class provides basic functionalities for an ITS dictionary. </div><div class="ttdef"><b>Definition:</b> loggers.hh:42</div></div>
<div class="ttc" id="classloggers_html_a7f76b393efa2a06f0ab8ba551f789156"><div class="ttname"><a href="classloggers.html#a7f76b393efa2a06f0ab8ba551f789156">loggers::user</a></div><div class="ttdeci">void user(const char *p_fmt,...)</div><div class="ttdoc">User message based on printf-compliant formatting message. </div><div class="ttdef"><b>Definition:</b> loggers.hh:228</div></div>
<div class="ttc" id="classloggers_html_ad12a3690baf8f929e8b565821f8db4cb"><div class="ttname"><a href="classloggers.html#ad12a3690baf8f929e8b565821f8db4cb">loggers::get_instance</a></div><div class="ttdeci">static loggers &amp; get_instance()</div><div class="ttdoc">Accessor for the unique instance of the logger framework . </div><div class="ttdef"><b>Definition:</b> loggers.hh:67</div></div>
<div class="ttc" id="classloggers_html_ab766757bc69b4a3f8f3427186ad89ec1"><div class="ttname"><a href="classloggers.html#ab766757bc69b4a3f8f3427186ad89ec1">loggers::error</a></div><div class="ttdeci">void error(const char *p_fmt,...)</div><div class="ttdef"><b>Definition:</b> loggers.hh:256</div></div>
<div class="ttc" id="classloggers_html_ab7e59a4638b88a16b7d2ca9aea9644d0"><div class="ttname"><a href="classloggers.html#ab7e59a4638b88a16b7d2ca9aea9644d0">loggers::set_stop_time</a></div><div class="ttdeci">void set_stop_time(std::string &amp;p_time_key, float &amp;p_time)</div><div class="ttdoc">Stop execution time measurement. </div><div class="ttdef"><b>Definition:</b> loggers.hh:269</div></div>
<div class="ttc" id="classloggers_html_a355a8824e5211a20dbd59ea9dbf33891"><div class="ttname"><a href="classloggers.html#a355a8824e5211a20dbd59ea9dbf33891">loggers::log_time_exec</a></div><div class="ttdeci">void log_time_exec(const char *p_fmt,...)</div><div class="ttdef"><b>Definition:</b> loggers.hh:280</div></div>
<div class="ttc" id="classloggers_html_adc3628cb6ea90b2d691f85948ee64dc8"><div class="ttname"><a href="classloggers.html#adc3628cb6ea90b2d691f85948ee64dc8">loggers::set_start_time</a></div><div class="ttdeci">void set_start_time(std::string &amp;p_time_key)</div><div class="ttdoc">Start execution time measurement. </div><div class="ttdef"><b>Definition:</b> loggers.hh:264</div></div>
<div class="ttc" id="classloggers_html_aee3482dc0fea0b0f38678487d9421f9e"><div class="ttname"><a href="classloggers.html#aee3482dc0fea0b0f38678487d9421f9e">loggers::warning_msg</a></div><div class="ttdeci">void warning_msg(const char *p_prompt, const Base_Type &amp;p_type)</div><div class="ttdef"><b>Definition:</b> loggers.hh:248</div></div>
</div><!-- fragment --></div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated on Wed Apr 4 2018 14:16:23 for ETSI STF525 / Internal Testing test suite by &#160;<a href="http://www.doxygen.org/index.html">
garciay's avatar
garciay committed
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.13
</small></address>
</body>
</html>