File: _log_8cpp_source.html

package info (click to toggle)
quickfix 1.13.3%2Bdfsg-9
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 152,548 kB
  • ctags: 679,426
  • sloc: cpp: 639,331; xml: 129,200; python: 108,722; ruby: 85,152; sh: 10,492; ansic: 9,025; java: 1,827; cs: 1,145; makefile: 523; sql: 313; perl: 108
file content (119 lines) | stat: -rw-r--r-- 13,702 bytes parent folder | download
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
<title>QuickFIX: /home/omiller/Development/autobuild/quickfix/src/C++/Log.cpp Source File</title>
<link href="quickfix.css" rel="stylesheet" type="text/css">
<table cellspacing="0" cellpadding="0" border="0">
  <tr>
   <td>
	<img src="images/QuickFIX.jpg" align="middle" border=0>
	&nbsp;&nbsp;
	<a href="index.html">Index</a>&nbsp;
	<a href="files.html">Source Files</a>&nbsp;
	<a href="annotated.html">Annotated Class List</a>&nbsp;
	<a href="classes.html">Alphabetical Class List</a>&nbsp;
	<a href="hierarchy.html">Class Hierarchy</a>&nbsp;
	<a href="inherits.html">Graphical Class Hierarchy</a>&nbsp;
   </td>
  </tr>
</table>
</head><body bgcolor="#ffffff">
<!-- Generated by Doxygen 1.6.1 -->
  <div class="navpath"><a class="el" href="dir_a9003438d6daff57482a26b22b6121a1.html">src</a>&nbsp;&raquo&nbsp;<a class="el" href="dir_348ef16cf184025134029522e7f02883.html">C++</a>
  </div>
<div class="contents">
<h1>Log.cpp</h1><a href="_log_8cpp.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/****************************************************************************</span>
<a name="l00002"></a>00002 <span class="comment">** Copyright (c) quickfixengine.org  All rights reserved.</span>
<a name="l00003"></a>00003 <span class="comment">**</span>
<a name="l00004"></a>00004 <span class="comment">** This file is part of the QuickFIX FIX Engine</span>
<a name="l00005"></a>00005 <span class="comment">**</span>
<a name="l00006"></a>00006 <span class="comment">** This file may be distributed under the terms of the quickfixengine.org</span>
<a name="l00007"></a>00007 <span class="comment">** license as defined by quickfixengine.org and appearing in the file</span>
<a name="l00008"></a>00008 <span class="comment">** LICENSE included in the packaging of this file.</span>
<a name="l00009"></a>00009 <span class="comment">**</span>
<a name="l00010"></a>00010 <span class="comment">** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE</span>
<a name="l00011"></a>00011 <span class="comment">** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.</span>
<a name="l00012"></a>00012 <span class="comment">**</span>
<a name="l00013"></a>00013 <span class="comment">** See http://www.quickfixengine.org/LICENSE for licensing information.</span>
<a name="l00014"></a>00014 <span class="comment">**</span>
<a name="l00015"></a>00015 <span class="comment">** Contact ask@quickfixengine.org if any conditions of this licensing are</span>
<a name="l00016"></a>00016 <span class="comment">** not clear to you.</span>
<a name="l00017"></a>00017 <span class="comment">**</span>
<a name="l00018"></a>00018 <span class="comment">****************************************************************************/</span>
<a name="l00019"></a>00019 
<a name="l00020"></a>00020 <span class="preprocessor">#ifdef _MSC_VER</span>
<a name="l00021"></a>00021 <span class="preprocessor"></span><span class="preprocessor">#include &quot;stdafx.h&quot;</span>
<a name="l00022"></a>00022 <span class="preprocessor">#else</span>
<a name="l00023"></a>00023 <span class="preprocessor"></span><span class="preprocessor">#include &quot;config.h&quot;</span>
<a name="l00024"></a>00024 <span class="preprocessor">#endif</span>
<a name="l00025"></a>00025 <span class="preprocessor"></span><span class="preprocessor">#include &quot;<a class="code" href="_call_stack_8h.html">CallStack.h</a>&quot;</span>
<a name="l00026"></a>00026 
<a name="l00027"></a>00027 <span class="preprocessor">#include &quot;<a class="code" href="_log_8h.html">Log.h</a>&quot;</span>
<a name="l00028"></a>00028 
<a name="l00029"></a>00029 <span class="keyword">namespace </span>FIX
<a name="l00030"></a>00030 {
<a name="l00031"></a>00031 Mutex <a class="code" href="class_f_i_x_1_1_screen_log.html#a09159664a0e96bd6afdc7a7822d07f53">ScreenLog::s_mutex</a>;
<a name="l00032"></a>00032 
<a name="l00033"></a><a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a8cb6a3c39cbdd7710deaffb711a9557c">00033</a> <a class="code" href="class_f_i_x_1_1_log.html" title="This interface must be implemented to log messages and events.">Log</a>* <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a8cb6a3c39cbdd7710deaffb711a9557c">ScreenLogFactory::create</a>()
<a name="l00034"></a>00034 { <a class="code" href="_call_stack_8h.html#a3b1ffd24ab4b24161008f4867150f4c8">QF_STACK_PUSH</a>(<a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a8cb6a3c39cbdd7710deaffb711a9557c">ScreenLogFactory::create</a>)
<a name="l00035"></a>00035 
<a name="l00036"></a>00036   <span class="keywordtype">bool</span> incoming, outgoing, event;
<a name="l00037"></a>00037   <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a05956d174b131259d25d0133587f0b46">init</a>( <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#aa4cc8023975b2451f62f23b9c6147d98">m_settings</a>.<a class="code" href="class_f_i_x_1_1_session_settings.html#a6ca0fa92c8826964049fe4ee696af410" title="Get a dictionary for a session.">get</a>(), incoming, outgoing, event );
<a name="l00038"></a>00038   <span class="keywordflow">return</span> <span class="keyword">new</span> <a class="code" href="class_f_i_x_1_1_screen_log.html" title="Screen based implementation of Log.">ScreenLog</a>( incoming, outgoing, event );
<a name="l00039"></a>00039 
<a name="l00040"></a>00040   <a class="code" href="_call_stack_8h.html#ac6b0115ca0a0988c881219c711c9c57e">QF_STACK_POP</a>
<a name="l00041"></a>00041 }
<a name="l00042"></a>00042 
<a name="l00043"></a><a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a676e720373ade3d11f0dc73d8220c8dd">00043</a> <a class="code" href="class_f_i_x_1_1_log.html" title="This interface must be implemented to log messages and events.">Log</a>* <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a8cb6a3c39cbdd7710deaffb711a9557c">ScreenLogFactory::create</a>( <span class="keyword">const</span> <a class="code" href="class_f_i_x_1_1_session_i_d.html" title="Unique session id consists of BeginString, SenderCompID and TargetCompID.">SessionID</a>&amp; sessionID )
<a name="l00044"></a>00044 { <a class="code" href="_call_stack_8h.html#a3b1ffd24ab4b24161008f4867150f4c8">QF_STACK_PUSH</a>(<a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a8cb6a3c39cbdd7710deaffb711a9557c">ScreenLogFactory::create</a>)
<a name="l00045"></a>00045 
<a name="l00046"></a>00046   <a class="code" href="class_f_i_x_1_1_dictionary.html" title="For storage and retrieval of key/value pairs.">Dictionary</a> settings;
<a name="l00047"></a>00047   <span class="keywordflow">if</span>( <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#aa4cc8023975b2451f62f23b9c6147d98">m_settings</a>.<a class="code" href="class_f_i_x_1_1_session_settings.html#a8371067d336c4d8814623bee46028bd7" title="Check if session setings are present.">has</a>(sessionID) ) 
<a name="l00048"></a>00048           settings = <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#aa4cc8023975b2451f62f23b9c6147d98">m_settings</a>.<a class="code" href="class_f_i_x_1_1_session_settings.html#a6ca0fa92c8826964049fe4ee696af410" title="Get a dictionary for a session.">get</a>( sessionID );
<a name="l00049"></a>00049 
<a name="l00050"></a>00050   <span class="keywordtype">bool</span> incoming, outgoing, event;
<a name="l00051"></a>00051   <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a05956d174b131259d25d0133587f0b46">init</a>( settings, incoming, outgoing, event );
<a name="l00052"></a>00052   <span class="keywordflow">return</span> <span class="keyword">new</span> <a class="code" href="class_f_i_x_1_1_screen_log.html" title="Screen based implementation of Log.">ScreenLog</a>( sessionID, incoming, outgoing, event );
<a name="l00053"></a>00053 
<a name="l00054"></a>00054   <a class="code" href="_call_stack_8h.html#ac6b0115ca0a0988c881219c711c9c57e">QF_STACK_POP</a>
<a name="l00055"></a>00055 }
<a name="l00056"></a>00056 
<a name="l00057"></a><a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a05956d174b131259d25d0133587f0b46">00057</a> <span class="keywordtype">void</span> <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a05956d174b131259d25d0133587f0b46">ScreenLogFactory::init</a>( <span class="keyword">const</span> <a class="code" href="class_f_i_x_1_1_dictionary.html" title="For storage and retrieval of key/value pairs.">Dictionary</a>&amp; settings, <span class="keywordtype">bool</span>&amp; incoming, <span class="keywordtype">bool</span>&amp; outgoing, <span class="keywordtype">bool</span>&amp; event )
<a name="l00058"></a>00058 { <a class="code" href="_call_stack_8h.html#a3b1ffd24ab4b24161008f4867150f4c8">QF_STACK_PUSH</a>(<a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a05956d174b131259d25d0133587f0b46">ScreenLogFactory::init</a>)
<a name="l00059"></a>00059         
<a name="l00060"></a>00060   <span class="keywordflow">if</span>( <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a5d3644448f9442a481d26946c1c13fba">m_useSettings</a> )
<a name="l00061"></a>00061   {
<a name="l00062"></a>00062     incoming = <span class="keyword">true</span>;
<a name="l00063"></a>00063     outgoing = <span class="keyword">true</span>;
<a name="l00064"></a>00064     <span class="keyword">event</span> = <span class="keyword">true</span>;
<a name="l00065"></a>00065 
<a name="l00066"></a>00066     <span class="keywordflow">if</span>( settings.<a class="code" href="class_f_i_x_1_1_dictionary.html#ad512496c3e4559743e231b9531aa65e4" title="Check if the dictionary contains a value for key.">has</a>(<a class="code" href="namespace_f_i_x.html#a8845581913f25d041ae544b62a2c169d">SCREEN_LOG_SHOW_INCOMING</a>) )
<a name="l00067"></a>00067       incoming = settings.<a class="code" href="class_f_i_x_1_1_dictionary.html#abc7da99f792033525aa23f39c19179b3" title="Get a value as a bool.">getBool</a>(<a class="code" href="namespace_f_i_x.html#a8845581913f25d041ae544b62a2c169d">SCREEN_LOG_SHOW_INCOMING</a>);
<a name="l00068"></a>00068     <span class="keywordflow">if</span>( settings.<a class="code" href="class_f_i_x_1_1_dictionary.html#ad512496c3e4559743e231b9531aa65e4" title="Check if the dictionary contains a value for key.">has</a>(<a class="code" href="namespace_f_i_x.html#a4e60d396d9e11f2c2572878cfc09e418">SCREEN_LOG_SHOW_OUTGOING</a>) )
<a name="l00069"></a>00069       outgoing = settings.<a class="code" href="class_f_i_x_1_1_dictionary.html#abc7da99f792033525aa23f39c19179b3" title="Get a value as a bool.">getBool</a>(<a class="code" href="namespace_f_i_x.html#a4e60d396d9e11f2c2572878cfc09e418">SCREEN_LOG_SHOW_OUTGOING</a>);
<a name="l00070"></a>00070     <span class="keywordflow">if</span>( settings.<a class="code" href="class_f_i_x_1_1_dictionary.html#ad512496c3e4559743e231b9531aa65e4" title="Check if the dictionary contains a value for key.">has</a>(<a class="code" href="namespace_f_i_x.html#a2a2675b223a0a747a03215e1106b49b9">SCREEN_LOG_SHOW_EVENTS</a>) )
<a name="l00071"></a>00071       event = settings.<a class="code" href="class_f_i_x_1_1_dictionary.html#abc7da99f792033525aa23f39c19179b3" title="Get a value as a bool.">getBool</a>(<a class="code" href="namespace_f_i_x.html#a2a2675b223a0a747a03215e1106b49b9">SCREEN_LOG_SHOW_EVENTS</a>);
<a name="l00072"></a>00072   }
<a name="l00073"></a>00073   <span class="keywordflow">else</span>
<a name="l00074"></a>00074   {
<a name="l00075"></a>00075         incoming = <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#a10655c8d0e30de2701be8dcd8107d924">m_incoming</a>;
<a name="l00076"></a>00076         outgoing = <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#af8d6b29a8d63a56b0dea56e59468b106">m_outgoing</a>;
<a name="l00077"></a>00077         <span class="keyword">event</span> = <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#aa05d2c0dac0995ec43558d5e0e215f00">m_event</a>;
<a name="l00078"></a>00078   }
<a name="l00079"></a>00079 
<a name="l00080"></a>00080   <a class="code" href="_call_stack_8h.html#ac6b0115ca0a0988c881219c711c9c57e">QF_STACK_POP</a>
<a name="l00081"></a>00081 }
<a name="l00082"></a>00082 
<a name="l00083"></a><a class="code" href="class_f_i_x_1_1_screen_log_factory.html#ab2ce2eafd732b16de9a822e36673d799">00083</a> <span class="keywordtype">void</span> <a class="code" href="class_f_i_x_1_1_screen_log_factory.html#ab2ce2eafd732b16de9a822e36673d799">ScreenLogFactory::destroy</a>( <a class="code" href="class_f_i_x_1_1_log.html" title="This interface must be implemented to log messages and events.">Log</a>* pLog )
<a name="l00084"></a>00084 { <a class="code" href="_call_stack_8h.html#a3b1ffd24ab4b24161008f4867150f4c8">QF_STACK_PUSH</a>(<a class="code" href="class_f_i_x_1_1_screen_log_factory.html#ab2ce2eafd732b16de9a822e36673d799">ScreenLogFactory::destroy</a>)
<a name="l00085"></a>00085   <span class="keyword">delete</span> pLog;
<a name="l00086"></a>00086   <a class="code" href="_call_stack_8h.html#ac6b0115ca0a0988c881219c711c9c57e">QF_STACK_POP</a>
<a name="l00087"></a>00087 }
<a name="l00088"></a>00088 } <span class="comment">//namespace FIX</span>
</pre></div></div>
<hr><address><small>
Generated on Mon Apr 5 20:59:50 2010 for QuickFIX by <a href="http://www.doxygen.org/index.html">
<img src="doxygen.gif" alt="doxygen" align="middle" border=0 width=110 height=53>
</a> 1.6.1 written by <a href="mailto:dimitri@stack.nl">Dimitri van Heesch</a>,
 &copy;&nbsp;1997-2001</small></address>
</body>
</html>