idlehomescreen/inc/tracer.h
changeset 0 f72a12da539e
--- /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 <e32std.h>
+#include <e32svr.h>
+#include <f32file.h>
+
+//#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<const TDesC> aFmt,...);
+
+private:
+    RFs iFs;
+
+	TBuf<255> iString;
+//	RFileLogger iFLogger;
+};
+
+
+#endif // __TTRACER_H__