diff -r 000000000000 -r b16258d2340f applayerprotocols/httptransportfw/utils/timerlogger.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/applayerprotocols/httptransportfw/utils/timerlogger.h Tue Feb 02 01:09:52 2010 +0200 @@ -0,0 +1,68 @@ +// Copyright (c) 2007-2009 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: +// + +/** + @file + @internalComponent +*/ +#ifndef __TIMERLOGGER_H__ +#define __TIMERLOGGER_H__ + +#include +#include +#include + +// Uncomment the below line to generate performance logger +// #define __LOG_PERFORMANCE + +/** A utility used in HTTP for performing HTTPIOP performance tests in release builds. Log file is placed in the +directory %EPOCROOT%/epoc32/winscw/c/logs/http +@internalComponent +@released +*/ +class TTimerLogger : public TDesOverflow +{ +public: // methods + IMPORT_C ~TTimerLogger(); + IMPORT_C void StartTimer(); + IMPORT_C void EndTimer(const TDesC&); + IMPORT_C void TestName(const TDesC&); + +private: + IMPORT_C virtual void Overflow(TDes& aDes); + void LogIt(const TDesC& aComment); + +private: // attributes + + RFs iFs; + RFile iFile; + TTime iStartTime; + TTime iEndTime; +}; +#if defined __LOG_PERFORMANCE +// HTTP Logging macros +#define __DECLARE_PERFORMANCE_LOG mutable TTimerLogger iTLogger; +#define __START_PERFORMANCE_LOGGER() iTLogger.StartTimer() +#define __END_PERFORMANCE_LOGGER(C) iTLogger.EndTimer(C) +#define __TESTNAME(C) iTLogger.TestName(C); + +#else +#define __DECLARE_PERFORMANCE_LOG +#define __START_PERFORMANCE_LOGGER() +#define __END_PERFORMANCE_LOGGER(C) +#define __TESTNAME(C) + +#endif //__LOG_PERFORMANCE +#endif // __TIMERLOGGER_H__