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>
<a href="index.html">Index</a>
<a href="files.html">Source Files</a>
<a href="annotated.html">Annotated Class List</a>
<a href="classes.html">Alphabetical Class List</a>
<a href="hierarchy.html">Class Hierarchy</a>
<a href="inherits.html">Graphical Class Hierarchy</a>
</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> » <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 "stdafx.h"</span>
<a name="l00022"></a>00022 <span class="preprocessor">#else</span>
<a name="l00023"></a>00023 <span class="preprocessor"></span><span class="preprocessor">#include "config.h"</span>
<a name="l00024"></a>00024 <span class="preprocessor">#endif</span>
<a name="l00025"></a>00025 <span class="preprocessor"></span><span class="preprocessor">#include "<a class="code" href="_call_stack_8h.html">CallStack.h</a>"</span>
<a name="l00026"></a>00026
<a name="l00027"></a>00027 <span class="preprocessor">#include "<a class="code" href="_log_8h.html">Log.h</a>"</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>& 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>& settings, <span class="keywordtype">bool</span>& incoming, <span class="keywordtype">bool</span>& outgoing, <span class="keywordtype">bool</span>& 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>,
© 1997-2001</small></address>
</body>
</html>
|