MFC TRACE Macro for Console Applications

The TRACE macro defined using MFC and ATL can also be used in console or Win32 application, however with some small modifications.
This example will post Messages to the tracer built-in with Visual Studio IDE, TraceEx Also includes source file and code line which can be used as shortcut when double clicked on.

/* 
	Trace.h
*/

#ifndef __TRACE_H__
#define __TRACE_H__

#include <crtdbg.h>
#include <stdarg.h>
#include <stdio.h>
#include <string.h>

#ifdef _DEBUG
#define TRACEMAXSTRING	1024

char szBuffer[TRACEMAXSTRING];
inline void Trace(const char* format,...)
{
 va_list args;
 va_start(args,format);
 int nBuf;
 nBuf = _vsnprintf(szBuffer,
                   TRACEMAXSTRING,
                   format,
                   args);
 va_end(args);

 _RPT0(_CRT_WARN,szBuffer);
}
#define TraceEx _snprintf(szBuffer,TRACEMAXSTRING,"%s(%d): ", \
                          &strrchr(__FILE__,'\\')[1],__LINE__); \
_RPT0(_CRT_WARN,szBuffer); \
Trace

#else
 inline void Trace(0);
 inline void TraceEx(0);
#endif


#endif // __TRACE_H__

Example

Here's all you have to do to use this macro!
#include "trace.h"

int main(void)
{
 TraceEx("Somethings wrongs here %d\n",1)
}
Running this application will result in the following output:
main.cpp(5): Somethings wrong here 1
Other features that could be included are ThreadID, ProcessID etc. fun debugging.


Comments

  • This macro include any dangurous case.

    Posted by Legacy on 07/27/2003 12:00am

    Originally posted by: tae young park

    This macro include any dangurous case.
    If this macro is used bellow example.

    example:

    if( ... ) {
    } else
    TraceEx( "trace sample.." );

    This example code will be expanded

    if( ... ) {
    } else
    _snprintf(szBuffer, TRACEMAXSTRING, "%s(%d" : ",
    &strchr(__FILE__,'\\')[1], __LINE__);
    _RPT0(_CRT_WARN,szBuffer);
    Trace("trace sample..");

    so last two line will be executed in any case.
    therefore this macro must be used with a parenthesis.

    if( ... ) {
    } else
    {
    TraceEx( "trace sample..");
    }

    Be carefull !

    • Parenthese

      Posted by jjwalters on 02/17/2005 05:38pm

      Wouldn't it be more sensible to modify the macro slightly to allow for your 
      if( ... ) { 
      } else 
      TraceEx( "trace sample.." ); 
      text?
      
      Put the parentheses around the macro
      #define TraceEx {_snprintf(szBuffer,TRACEMAXSTRING,"%s(%d): ", \
                                &strrchr(__FILE__,'\\')[1],__LINE__); \
      _RPT0(_CRT_WARN,szBuffer); \
      Trace}

      Reply
    Reply
  • Useful (-_-)

    Posted by Legacy on 05/13/2003 12:00am

    Originally posted by: Janus.K

    z

    Reply
  • Release build errors

    Posted by Legacy on 02/01/2002 12:00am

    Originally posted by: suma

    I get the following error message on release build

    error C2182: 'Trace' : illegal use of type 'void'
    error C2433: 'Trace' : 'inline' not permitted on data declarations
    error C2182: 'TraceEx' : illegal use of type 'void'
    error C2433: 'TraceEx' : 'inline' not permitted on data declarations

    These error corresponds to the following lines

    #define TraceEx _snprintf(szBuffer,TRACEMAXSTRING,"%s(%d): ", \
    &strrchr(__FILE__,'\\')[1],__LINE__); \
    _RPT0(_CRT_WARN,szBuffer); \
    Trace

    #else
    inline void Trace(0);
    inline void TraceEx(0);
    #endif

    Reply
  • Good job ;-) !!!

    Posted by Legacy on 10/23/2001 12:00am

    Originally posted by: Hartmut

    This was what I really needed. Well done !!!

    Reply
Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • Live Event Date: December 11, 2014 @ 1:00 p.m. ET / 10:00 a.m. PT Market pressures to move more quickly and develop innovative applications are forcing organizations to rethink how they develop and release applications. The combination of public clouds and physical back-end infrastructures are a means to get applications out faster. However, these hybrid solutions complicate DevOps adoption, with application delivery pipelines that span across complex hybrid cloud and non-cloud environments. Check out this …

  • On-demand Event Event Date: October 29, 2014 It's well understood how critical version control is for code. However, its importance to DevOps isn't always recognized. The 2014 DevOps Survey of Practice shows that one of the key predictors of DevOps success is putting all production environment artifacts into version control. In this webcast, Gene Kim discusses these survey findings and shares woeful tales of artifact management gone wrong! Gene also shares examples of how high-performing DevOps …

Most Popular Programming Stories

More for Developers

RSS Feeds