<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1"> <title>rlog: rlog-c99.h Source File</title> <link href="doxygen.css" rel="stylesheet" type="text/css"> </head><body> <!-- Generated by Doxygen 1.4.3 --> <div class="qindex"><a class="qindex" href="index.html">Main Page</a> | <a class="qindex" href="modules.html">Modules</a> | <a class="qindex" href="annotated.html">Class List</a> | <a class="qindex" href="dirs.html">Directories</a> | <a class="qindex" href="files.html">File List</a> | <a class="qindex" href="functions.html">Class Members</a> | <a class="qindex" href="pages.html">Related Pages</a></div> <div class="nav"> <a class="el" href="dir_000003.html">_darcs</a> » <a class="el" href="dir_000004.html">current</a> » <a class="el" href="dir_000005.html">rlog</a></div> <h1>_darcs/current/rlog/rlog-c99.h</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*****************************************************************************</span> <a name="l00002"></a>00002 <span class="comment"> * Author: Valient Gough <vgough@pobox.com></span> <a name="l00003"></a>00003 <span class="comment"> *</span> <a name="l00004"></a>00004 <span class="comment"> *****************************************************************************</span> <a name="l00005"></a>00005 <span class="comment"> * Copyright (c) 2002-2004, Valient Gough</span> <a name="l00006"></a>00006 <span class="comment"> *</span> <a name="l00007"></a>00007 <span class="comment"> * This library is free software; you can distribute it and/or modify it under</span> <a name="l00008"></a>00008 <span class="comment"> * the terms of the GNU Lesser General Public License (LGPL), as published by</span> <a name="l00009"></a>00009 <span class="comment"> * the Free Software Foundation; either version 2.1 of the License, or (at your</span> <a name="l00010"></a>00010 <span class="comment"> * option) any later version.</span> <a name="l00011"></a>00011 <span class="comment"> *</span> <a name="l00012"></a>00012 <span class="comment"> * This library is distributed in the hope that it will be useful, but WITHOUT</span> <a name="l00013"></a>00013 <span class="comment"> * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or</span> <a name="l00014"></a>00014 <span class="comment"> * FITNESS FOR A PARTICULAR PURPOSE. See the LGPL in the file COPYING for more</span> <a name="l00015"></a>00015 <span class="comment"> * details.</span> <a name="l00016"></a>00016 <span class="comment"> *</span> <a name="l00017"></a>00017 <span class="comment"> */</span> <a name="l00018"></a>00018 <a name="l00019"></a>00019 <a name="l00025"></a>00025 <span class="preprocessor">#define _rMessageDef(ID, COMPONENT) \</span> <a name="l00026"></a>00026 <span class="preprocessor"> static rlog::PublishLoc ID ={&rlog::RLog_Register, 0, STR(COMPONENT), \</span> <a name="l00027"></a>00027 <span class="preprocessor"> __FILE__, __FUNCTION__, __LINE__, 0};</span> <a name="l00028"></a>00028 <span class="preprocessor"></span> <a name="l00033"></a>00033 <span class="preprocessor">#if HAVE_PRINTF_FP || !HAVE_PRINTF_ATTR</span> <a name="l00034"></a>00034 <span class="preprocessor"></span><span class="preprocessor"># define _rMessageCall(ID, CHANNEL, ...) \</span> <a name="l00035"></a>00035 <span class="preprocessor"> if(unlikely(ID.publish!=0)) (*ID.publish)( &ID, CHANNEL, ##__VA_ARGS__ );</span> <a name="l00036"></a>00036 <span class="preprocessor"></span><span class="preprocessor">#else // no PRINTF attributes..</span> <a name="l00037"></a>00037 <span class="preprocessor"></span><span class="preprocessor"># define _rMessageCall(ID, CHANNEL, ...) \</span> <a name="l00038"></a>00038 <span class="preprocessor"> if(unlikely(ID.publish!=0)) \</span> <a name="l00039"></a>00039 <span class="preprocessor"> { \</span> <a name="l00040"></a>00040 <span class="preprocessor"> (*ID.publish)( &ID, CHANNEL, ##__VA_ARGS__ ); \</span> <a name="l00041"></a>00041 <span class="preprocessor"> rlog::__checkArgs( 0, ##__VA_ARGS__ ); \</span> <a name="l00042"></a>00042 <span class="preprocessor"> }</span> <a name="l00043"></a>00043 <span class="preprocessor"></span><span class="preprocessor">#endif</span> <a name="l00044"></a>00044 <span class="preprocessor"></span> <a name="l00054"></a>00054 <span class="preprocessor">#define _rMessage(ID, CHANNEL, ... ) \</span> <a name="l00055"></a>00055 <span class="preprocessor"> do { _rMessageDef(ID, RLOG_COMPONENT) \</span> <a name="l00056"></a>00056 <span class="preprocessor"> _rMessageCall(ID, CHANNEL, ##__VA_ARGS__ ) } while(0)</span> <a name="l00057"></a>00057 <span class="preprocessor"></span> <a name="l00082"></a><a class="code" href="group__RLogMacros.html#ga0">00082</a> <span class="preprocessor">#define rDebug(...) \</span> <a name="l00083"></a>00083 <span class="preprocessor"> _rMessage( LOGID, rlog::_RLDebugChannel, ##__VA_ARGS__ )</span> <a name="l00084"></a>00084 <span class="preprocessor"></span> <a name="l00098"></a><a class="code" href="group__RLogMacros.html#ga1">00098</a> <span class="preprocessor">#define rInfo(...) \</span> <a name="l00099"></a>00099 <span class="preprocessor"> _rMessage( LOGID, rlog::_RLInfoChannel, ##__VA_ARGS__ )</span> <a name="l00100"></a>00100 <span class="preprocessor"></span> <a name="l00118"></a><a class="code" href="group__RLogMacros.html#ga2">00118</a> <span class="preprocessor">#define rWarning(...) \</span> <a name="l00119"></a>00119 <span class="preprocessor"> _rMessage( LOGID, rlog::_RLWarningChannel, ##__VA_ARGS__ )</span> <a name="l00120"></a>00120 <span class="preprocessor"></span> <a name="l00136"></a><a class="code" href="group__RLogMacros.html#ga3">00136</a> <span class="preprocessor">#define rError(...) \</span> <a name="l00137"></a>00137 <span class="preprocessor"> _rMessage( LOGID, rlog::_RLErrorChannel, ##__VA_ARGS__ )</span> <a name="l00138"></a>00138 <span class="preprocessor"></span> <a name="l00156"></a><a class="code" href="group__RLogMacros.html#ga4">00156</a> <span class="preprocessor">#define rLog(channel, ...) \</span> <a name="l00157"></a>00157 <span class="preprocessor"> _rMessage( LOGID, channel, ##__VA_ARGS__ )</span> <a name="l00158"></a>00158 <span class="preprocessor"></span> <a name="l00159"></a>00159 </pre></div><hr size="1"><address style="align: right;"><small>Generated on Wed Oct 5 11:13:40 2005 for rlog by <a href="http://www.doxygen.org/index.html"> <img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.4.3 </small></address> </body> </html>