diff -r 000000000000 -r f72a12da539e idlehomescreen/inc/tracer.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/idlehomescreen/inc/tracer.h Thu Dec 17 08:40:49 2009 +0200 @@ -0,0 +1,90 @@ +/* +* Copyright (c) 2007 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of "Eclipse Public License v1.0" +* which accompanies this distribution, and is available +* at the URL "http://www.eclipse.org/legal/epl-v10.html". +* +* Initial Contributors: +* Nokia Corporation - initial contribution. +* +* Contributors: +* +* Description: +* +*/ +#ifndef __TTRACER_H__ +#define __TTRACER_H__ + +#include +#include +#include + +//#ifdef _DEBUG +#define TRACER_ENABLED +//#else +//#undef TRACER_ENABLED +//#endif + +/** Macro to initialise the tracer. Set the indentation level to zero. */ +#ifdef TRACER_ENABLED +#define INITTRACE TTracer t +#else +#define INITTRACE +#endif + +/** Macro to trace the function calls. + * @param a Text to display. Usually class::function */ +#ifdef TRACER_ENABLED +#define TRACE(a) TTracer t(_L(a)) +#else +#define TRACE(a) +#endif + +/** Macro to print a string to the trace window. + * @param a Text to print. + */ +#ifdef TRACER_ENABLED +#define TRACESTR(a) TTracer::Print(_L(a)) +#else +#define TRACESTR +#endif + +/** + * @ingroup group_xnutils + * + * Class for tracing function calls. Indentation shows the call tree. + * Also the entry and leave points are time labeled, show timing info is available. + */ +class TTracer +{ +public: + /** Initialising constructor. */ + IMPORT_C TTracer(); + + /** Tracing constructor. + * Writes time lable and "Enter: " + the given string. + */ + IMPORT_C TTracer(TPtrC aString); + + /** Destructor. + * Writes time lable and "Leave: " + the given string. + */ + IMPORT_C ~TTracer(); + + /** Prints the given string to the trace window. + * @param a Text to print. + */ + IMPORT_C static void Print(TPtrC aString); +// static TInt Print(TRefByValue aFmt,...); + +private: + RFs iFs; + + TBuf<255> iString; +// RFileLogger iFLogger; +}; + + +#endif // __TTRACER_H__