Newer
Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
<!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> </div><div class="line"><a name="l00011"></a><span class="lineno"> 11</span> <span class="preprocessor">#pragma once</span></div><div class="line"><a name="l00012"></a><span class="lineno"> 12</span> </div><div class="line"><a name="l00013"></a><span class="lineno"> 13</span> <span class="preprocessor">#include <memory></span></div><div class="line"><a name="l00014"></a><span class="lineno"> 14</span> <span class="preprocessor">#include <map></span></div><div class="line"><a name="l00015"></a><span class="lineno"> 15</span> <span class="preprocessor">#include <string></span></div><div class="line"><a name="l00016"></a><span class="lineno"> 16</span> <span class="preprocessor">#include <ctime></span></div><div class="line"><a name="l00017"></a><span class="lineno"> 17</span> <span class="preprocessor">#include <cstdarg></span></div><div class="line"><a name="l00018"></a><span class="lineno"> 18</span> </div><div class="line"><a name="l00033"></a><span class="lineno"> 33</span> <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> <span class="preprocessor">#include <TTCN3.hh></span></div><div class="line"><a name="l00035"></a><span class="lineno"> 35</span> </div><div class="line"><a name="l00042"></a><span class="lineno"><a class="line" href="classloggers.html"> 42</a></span> <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> <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>  <span class="keyword">static</span> std::unique_ptr<loggers> <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>  std::map<std::string, std::clock_t> <a class="code" href="classloggers.html#af999d35c4c60c630258f66f81c9a33a2">_times</a>; </div><div class="line"><a name="l00046"></a><span class="lineno"> 46</span> </div><div class="line"><a name="l00052"></a><span class="lineno"><a class="line" href="classloggers.html#aa8a2258ab15b12927f974c36b4b68d65"> 52</a></span>  <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> </div><div class="line"><a name="l00054"></a><span class="lineno"> 54</span>  <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> </div><div class="line"><a name="l00056"></a><span class="lineno"> 56</span> <span class="keyword">public</span>: </div><div class="line"><a name="l00057"></a><span class="lineno"> 57</span> </div><div class="line"><a name="l00060"></a><span class="lineno"><a class="line" href="classloggers.html#a1d6a7861d319bc6137381822ee049936"> 60</a></span>  <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> </div><div class="line"><a name="l00067"></a><span class="lineno"><a class="line" href="classloggers.html#ae5b1e222942002f395e1e5bafdf9121a"> 67</a></span>  <span class="keyword">static</span> <span class="keyword">inline</span> <a class="code" href="classloggers.html">loggers</a>& get_instance() { <span class="keywordflow">return</span> *_instance.get(); };</div><div class="line"><a name="l00068"></a><span class="lineno"> 68</span>  </div><div class="line"><a name="l00076"></a><span class="lineno"> 76</span>  <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& buffer);</div><div class="line"><a name="l00084"></a><span class="lineno"> 84</span>  <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& msg);</div><div class="line"><a name="l00092"></a><span class="lineno"> 92</span>  <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>  <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& p_type);</div><div class="line"><a name="l00108"></a><span class="lineno"> 108</span>  <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> </div><div class="line"><a name="l00117"></a><span class="lineno"> 117</span>  <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& p_type);</div><div class="line"><a name="l00125"></a><span class="lineno"> 125</span>  <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>  </div><div class="line"><a name="l00134"></a><span class="lineno"> 134</span>  <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& p_type);</div><div class="line"><a name="l00142"></a><span class="lineno"> 142</span>  <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>  </div><div class="line"><a name="l00151"></a><span class="lineno"> 151</span>  <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> </div><div class="line"><a name="l00159"></a><span class="lineno"> 159</span>  <span class="keyword">inline</span> <span class="keywordtype">void</span> set_start_time(std::string& p_time_key);</div><div class="line"><a name="l00167"></a><span class="lineno"> 167</span>  <span class="keyword">inline</span> <span class="keywordtype">void</span> set_stop_time(std::string& p_time_key, <span class="keywordtype">float</span>& p_time);</div><div class="line"><a name="l00168"></a><span class="lineno"> 168</span> }; <span class="comment">// End of class loggers</span></div><div class="line"><a name="l00169"></a><span class="lineno"> 169</span> </div><div class="line"><a name="l00170"></a><span class="lineno"> 170</span> <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 & buffer)</div><div class="line"><a name="l00171"></a><span class="lineno"> 171</span> {</div><div class="line"><a name="l00172"></a><span class="lineno"> 172</span>  TTCN_Logger::begin_event(TTCN_Logger::DEBUG_UNQUALIFIED);</div><div class="line"><a name="l00173"></a><span class="lineno"> 173</span>  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00174"></a><span class="lineno"> 174</span>  buffer.log();</div><div class="line"><a name="l00175"></a><span class="lineno"> 175</span>  TTCN_Logger::end_event();</div><div class="line"><a name="l00176"></a><span class="lineno"> 176</span> }</div><div class="line"><a name="l00177"></a><span class="lineno"> 177</span> </div><div class="line"><a name="l00178"></a><span class="lineno"><a class="line" href="classloggers.html#a6a1e272f6ad2c0f08d02dbb8f86c29f0"> 178</a></span> <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& msg)</div><div class="line"><a name="l00179"></a><span class="lineno"> 179</span> {</div><div class="line"><a name="l00180"></a><span class="lineno"> 180</span>  TTCN_Logger::begin_event(TTCN_Logger::DEBUG_UNQUALIFIED);</div><div class="line"><a name="l00181"></a><span class="lineno"> 181</span>  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00182"></a><span class="lineno"> 182</span>  TTCN_Logger::log_event(<span class="stringliteral">"Size: %d,\nMsg: "</span>, msg.lengthof());</div><div class="line"><a name="l00183"></a><span class="lineno"> 183</span> </div><div class="line"><a name="l00184"></a><span class="lineno"> 184</span>  <span class="keywordflow">for</span>(<span class="keywordtype">int</span> i = 0; i < msg.lengthof(); i++) {</div><div class="line"><a name="l00185"></a><span class="lineno"> 185</span>  TTCN_Logger::log_event(<span class="stringliteral">" %02x"</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>  }</div><div class="line"><a name="l00187"></a><span class="lineno"> 187</span>  TTCN_Logger::log_event(<span class="stringliteral">"\n"</span>);</div><div class="line"><a name="l00188"></a><span class="lineno"> 188</span>  TTCN_Logger::end_event();</div><div class="line"><a name="l00189"></a><span class="lineno"> 189</span> }</div><div class="line"><a name="l00190"></a><span class="lineno"> 190</span> </div><div class="line"><a name="l00191"></a><span class="lineno"><a class="line" href="classloggers.html#a738c7c0bbd7c27f64f053817050251ba"> 191</a></span> <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> {</div><div class="line"><a name="l00193"></a><span class="lineno"> 193</span>  TTCN_Logger::begin_event(TTCN_Logger::DEBUG_UNQUALIFIED);</div><div class="line"><a name="l00194"></a><span class="lineno"> 194</span>  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00195"></a><span class="lineno"> 195</span>  <span class="keywordflow">for</span>(<span class="keywordtype">size_t</span> i = 0; i < msg_size; i++) {</div><div class="line"><a name="l00196"></a><span class="lineno"> 196</span>  TTCN_Logger::log_event(<span class="stringliteral">" %02x"</span>, *(msg + i));</div><div class="line"><a name="l00197"></a><span class="lineno"> 197</span>  }</div><div class="line"><a name="l00198"></a><span class="lineno"> 198</span>  TTCN_Logger::log_event(<span class="stringliteral">"\n"</span>);</div><div class="line"><a name="l00199"></a><span class="lineno"> 199</span>  TTCN_Logger::end_event();</div><div class="line"><a name="l00200"></a><span class="lineno"> 200</span> }</div><div class="line"><a name="l00201"></a><span class="lineno"> 201</span> </div><div class="line"><a name="l00202"></a><span class="lineno"><a class="line" href="classloggers.html#ac7a0c88774d5fe9bf65722309f9fac80"> 202</a></span> <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& p_type)</div><div class="line"><a name="l00203"></a><span class="lineno"> 203</span> {</div><div class="line"><a name="l00204"></a><span class="lineno"> 204</span>  TTCN_Logger::begin_event(TTCN_Logger::DEBUG_UNQUALIFIED);</div><div class="line"><a name="l00205"></a><span class="lineno"> 205</span>  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00206"></a><span class="lineno"> 206</span>  p_type.log();</div><div class="line"><a name="l00207"></a><span class="lineno"> 207</span>  TTCN_Logger::end_event();</div><div class="line"><a name="l00208"></a><span class="lineno"> 208</span> }</div><div class="line"><a name="l00209"></a><span class="lineno"> 209</span> </div><div class="line"><a name="l00210"></a><span class="lineno"><a class="line" href="classloggers.html#a329cb6d52eaa63b891f4d462ce0217a0"> 210</a></span> <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> {</div><div class="line"><a name="l00212"></a><span class="lineno"> 212</span>  TTCN_Logger::begin_event(TTCN_Logger::DEBUG_UNQUALIFIED);</div><div class="line"><a name="l00213"></a><span class="lineno"> 213</span>  va_list args;</div><div class="line"><a name="l00214"></a><span class="lineno"> 214</span>  va_start(args, p_fmt);</div><div class="line"><a name="l00215"></a><span class="lineno"> 215</span>  TTCN_Logger::log_event_va_list(p_fmt, args);</div><div class="line"><a name="l00216"></a><span class="lineno"> 216</span>  va_end(args);</div><div class="line"><a name="l00217"></a><span class="lineno"> 217</span>  TTCN_Logger::end_event();</div><div class="line"><a name="l00218"></a><span class="lineno"> 218</span> }</div><div class="line"><a name="l00219"></a><span class="lineno"> 219</span> </div><div class="line"><a name="l00220"></a><span class="lineno"><a class="line" href="classloggers.html#af5403ed11b848a6760d9e862fb9b1958"> 220</a></span> <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& p_type)</div><div class="line"><a name="l00221"></a><span class="lineno"> 221</span> {</div><div class="line"><a name="l00222"></a><span class="lineno"> 222</span>  TTCN_Logger::begin_event(TTCN_Logger::USER_UNQUALIFIED);</div><div class="line"><a name="l00223"></a><span class="lineno"> 223</span>  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00224"></a><span class="lineno"> 224</span>  p_type.log();</div><div class="line"><a name="l00225"></a><span class="lineno"> 225</span>  TTCN_Logger::end_event();</div><div class="line"><a name="l00226"></a><span class="lineno"> 226</span> }</div><div class="line"><a name="l00227"></a><span class="lineno"> 227</span> </div><div class="line"><a name="l00228"></a><span class="lineno"><a class="line" href="classloggers.html#a7f76b393efa2a06f0ab8ba551f789156"> 228</a></span> <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> {</div><div class="line"><a name="l00230"></a><span class="lineno"> 230</span>  TTCN_Logger::begin_event(TTCN_Logger::USER_UNQUALIFIED);</div><div class="line"><a name="l00231"></a><span class="lineno"> 231</span>  va_list args;</div><div class="line"><a name="l00232"></a><span class="lineno"> 232</span>  va_start(args, p_fmt);</div><div class="line"><a name="l00233"></a><span class="lineno"> 233</span>  TTCN_Logger::log_event_va_list(p_fmt, args);</div><div class="line"><a name="l00234"></a><span class="lineno"> 234</span>  va_end(args);</div><div class="line"><a name="l00235"></a><span class="lineno"> 235</span>  TTCN_Logger::end_event();</div><div class="line"><a name="l00236"></a><span class="lineno"> 236</span> }</div><div class="line"><a name="l00237"></a><span class="lineno"> 237</span> </div><div class="line"><a name="l00238"></a><span class="lineno"><a class="line" href="classloggers.html#a8bd538744863c9d60d8e31efe3eef3aa"> 238</a></span> <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> {</div><div class="line"><a name="l00240"></a><span class="lineno"> 240</span>  TTCN_Logger::begin_event(TTCN_Logger::WARNING_UNQUALIFIED);</div><div class="line"><a name="l00241"></a><span class="lineno"> 241</span>  va_list args;</div><div class="line"><a name="l00242"></a><span class="lineno"> 242</span>  va_start(args, p_fmt);</div><div class="line"><a name="l00243"></a><span class="lineno"> 243</span>  TTCN_Logger::log_event_va_list(p_fmt, args);</div><div class="line"><a name="l00244"></a><span class="lineno"> 244</span>  va_end(args);</div><div class="line"><a name="l00245"></a><span class="lineno"> 245</span>  TTCN_Logger::end_event();</div><div class="line"><a name="l00246"></a><span class="lineno"> 246</span> }</div><div class="line"><a name="l00247"></a><span class="lineno"> 247</span> </div><div class="line"><a name="l00248"></a><span class="lineno"><a class="line" href="classloggers.html#aee3482dc0fea0b0f38678487d9421f9e"> 248</a></span> <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& p_type)</div><div class="line"><a name="l00249"></a><span class="lineno"> 249</span> {</div><div class="line"><a name="l00250"></a><span class="lineno"> 250</span>  TTCN_Logger::begin_event(TTCN_Logger::WARNING_UNQUALIFIED);</div><div class="line"><a name="l00251"></a><span class="lineno"> 251</span>  TTCN_Logger::log_event_str(p_prompt);</div><div class="line"><a name="l00252"></a><span class="lineno"> 252</span>  p_type.log();</div><div class="line"><a name="l00253"></a><span class="lineno"> 253</span>  TTCN_Logger::end_event();</div><div class="line"><a name="l00254"></a><span class="lineno"> 254</span> }</div><div class="line"><a name="l00255"></a><span class="lineno"> 255</span> </div><div class="line"><a name="l00256"></a><span class="lineno"><a class="line" href="classloggers.html#ab766757bc69b4a3f8f3427186ad89ec1"> 256</a></span> <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> {</div><div class="line"><a name="l00258"></a><span class="lineno"> 258</span>  va_list args;</div><div class="line"><a name="l00259"></a><span class="lineno"> 259</span>  va_start(args, p_fmt);</div><div class="line"><a name="l00260"></a><span class="lineno"> 260</span>  TTCN_error(p_fmt, args);</div><div class="line"><a name="l00261"></a><span class="lineno"> 261</span>  va_end(args);</div><div class="line"><a name="l00262"></a><span class="lineno"> 262</span> }</div><div class="line"><a name="l00263"></a><span class="lineno"> 263</span> </div><div class="line"><a name="l00264"></a><span class="lineno"><a class="line" href="classloggers.html#adc3628cb6ea90b2d691f85948ee64dc8"> 264</a></span> <span class="keywordtype">void</span> <a class="code" href="classloggers.html#adc3628cb6ea90b2d691f85948ee64dc8">loggers::set_start_time</a>(std::string& p_time_key)</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>  _times[p_time_key] = std::clock();</div><div class="line"><a name="l00267"></a><span class="lineno"> 267</span> }</div><div class="line"><a name="l00268"></a><span class="lineno"> 268</span>  </div><div class="line"><a name="l00269"></a><span class="lineno"><a class="line" href="classloggers.html#ab7e59a4638b88a16b7d2ca9aea9644d0"> 269</a></span> <span class="keywordtype">void</span> <a class="code" href="classloggers.html#ab7e59a4638b88a16b7d2ca9aea9644d0">loggers::set_stop_time</a>(std::string& p_time_key, <span class="keywordtype">float</span>& p_time)</div><div class="line"><a name="l00270"></a><span class="lineno"> 270</span> {</div><div class="line"><a name="l00271"></a><span class="lineno"> 271</span>  std::map<std::string, std::clock_t>::iterator it = _times.find(p_time_key);</div><div class="line"><a name="l00272"></a><span class="lineno"> 272</span>  <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>  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>  _times.erase(it);</div><div class="line"><a name="l00275"></a><span class="lineno"> 275</span>  <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">"%s: Execution duration: %f ms"</span>, p_time_key.c_str(), p_time);</div><div class="line"><a name="l00276"></a><span class="lineno"> 276</span>  </div><div class="line"><a name="l00277"></a><span class="lineno"> 277</span>  }</div><div class="line"><a name="l00278"></a><span class="lineno"> 278</span> }</div><div class="line"><a name="l00279"></a><span class="lineno"> 279</span> </div><div class="line"><a name="l00280"></a><span class="lineno"><a class="line" href="classloggers.html#a355a8824e5211a20dbd59ea9dbf33891"> 280</a></span> <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> {</div><div class="line"><a name="l00282"></a><span class="lineno"> 282</span>  TTCN_Logger::begin_event(TTCN_Logger::EXECUTOR_RUNTIME);</div><div class="line"><a name="l00283"></a><span class="lineno"> 283</span>  va_list args;</div><div class="line"><a name="l00284"></a><span class="lineno"> 284</span>  va_start(args, p_fmt);</div><div class="line"><a name="l00285"></a><span class="lineno"> 285</span>  TTCN_Logger::log_event_va_list(p_fmt, args);</div><div class="line"><a name="l00286"></a><span class="lineno"> 286</span>  va_end(args);</div><div class="line"><a name="l00287"></a><span class="lineno"> 287</span>  TTCN_Logger::end_event();</div><div class="line"><a name="l00288"></a><span class="lineno"> 288</span> }</div><div class="line"><a name="l00289"></a><span class="lineno"> 289</span> </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 &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 &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 &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< std::string, std::clock_t > _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< loggers > _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 & 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 &p_time_key, float &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 &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 &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  <a href="http://www.doxygen.org/index.html">