1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
1.2 +++ b/os/ossrv/genericservices/taskscheduler/SCHSVR/SchLogger.h Fri Jun 15 03:10:57 2012 +0200
1.3 @@ -0,0 +1,117 @@
1.4 +// Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
1.5 +// All rights reserved.
1.6 +// This component and the accompanying materials are made available
1.7 +// under the terms of "Eclipse Public License v1.0"
1.8 +// which accompanies this distribution, and is available
1.9 +// at the URL "http://www.eclipse.org/legal/epl-v10.html".
1.10 +//
1.11 +// Initial Contributors:
1.12 +// Nokia Corporation - initial contribution.
1.13 +//
1.14 +// Contributors:
1.15 +//
1.16 +// Description:
1.17 +//
1.18 +
1.19 +#ifndef __SCHLOGGER_H__
1.20 +#define __SCHLOGGER_H__
1.21 +
1.22 +#ifdef __SCHLOGGING__
1.23 + #pragma message(__FILE__ ": (15) WARNING! Schedule logging is enabled")
1.24 +
1.25 + // System includes
1.26 + #include <f32file.h>
1.27 +
1.28 + /**
1.29 + Literal constants
1.30 + @internalComponent
1.31 + */
1.32 + _LIT(KSchSvrLogFile, "SCHSVR.TXT");
1.33 + _LIT(KSchSvrLogFolder, "SCHSVR");
1.34 +
1.35 + //
1.36 + // ------> CSheduleServerLog (header)
1.37 + //
1.38 + class CSheduleServerLog : public CBase
1.39 + /**
1.40 + @internalComponent
1.41 + */
1.42 + {
1.43 + //
1.44 + public: // CONSTRUCT / DESTRUCT
1.45 + //
1.46 + static CSheduleServerLog* NewL(const TDesC& aLogFileName);
1.47 + ~CSheduleServerLog();
1.48 +
1.49 + //
1.50 + private: // INTERNAL CONSTRUCT
1.51 + //
1.52 + CSheduleServerLog();
1.53 + void ConstructL(const TDesC& aLogFileName);
1.54 +
1.55 + //
1.56 + public: // ACCESS
1.57 + //
1.58 + void Log(TRefByValue<const TDesC> aFmt,...);
1.59 + void LogList(TRefByValue<const TDesC> aFmt, VA_LIST aList);
1.60 + void SeekEnd();
1.61 +
1.62 + //
1.63 + private: // INTERNAL
1.64 + //
1.65 + void Write(const TDesC& aText);
1.66 + void Write(const TDesC& aFmt, VA_LIST& aList);
1.67 + void WriteWithTimeStamp(const TDesC& aText);
1.68 + void NewLine();
1.69 +
1.70 + //
1.71 + private: // MEMBER DATA
1.72 + //
1.73 + RFs iFs;
1.74 + RFile iFile;
1.75 + };
1.76 +
1.77 +
1.78 + /**
1.79 + Defines
1.80 + @internalComponent
1.81 + */
1.82 + #define LOGSTRING(AAA) \
1.83 + { _LIT(tempLogDes, AAA); reinterpret_cast<CSheduleServerLog*>(Dll::Tls())->Log(tempLogDes()); }
1.84 + #define LOGSTRING2(AAA,BBB) \
1.85 + { _LIT(tempLogDes, AAA); reinterpret_cast<CSheduleServerLog*>(Dll::Tls())->Log(TRefByValue<const TDesC>(tempLogDes()),BBB); }
1.86 + #define LOGSTRING3(AAA,BBB,CCC) \
1.87 + { _LIT(tempLogDes, AAA); reinterpret_cast<CSheduleServerLog*>(Dll::Tls())->Log(TRefByValue<const TDesC>(tempLogDes()),BBB,CCC); }
1.88 + #define LOGSTRING4(AAA,BBB,CCC,DDD) \
1.89 + { _LIT(tempLogDes, AAA); reinterpret_cast<CSheduleServerLog*>(Dll::Tls())->Log(TRefByValue<const TDesC>(tempLogDes()),BBB,CCC,DDD); }
1.90 + #define LOGSTRING5(AAA,BBB,CCC,DDD,EEE) \
1.91 + { _LIT(tempLogDes, AAA); reinterpret_cast<CSheduleServerLog*>(Dll::Tls())->Log(TRefByValue<const TDesC>(tempLogDes()),BBB,CCC,DDD,EEE); }
1.92 + #define LOGSTRING6(AAA,BBB,CCC,DDD,EEE,FFF) \
1.93 + { _LIT(tempLogDes, AAA); reinterpret_cast<CSheduleServerLog*>(Dll::Tls())->Log(TRefByValue<const TDesC>(tempLogDes()),BBB,CCC,DDD,EEE,FFF); }
1.94 + #define LOGSTRING7(AAA,BBB,CCC,DDD,EEE,FFF,GGG) \
1.95 + { _LIT(tempLogDes, AAA); reinterpret_cast<CSheduleServerLog*>(Dll::Tls())->Log(TRefByValue<const TDesC>(tempLogDes()),BBB,CCC,DDD,EEE,FFF,GGG); }
1.96 + #define LOGSTRING8(AAA,BBB,CCC,DDD,EEE,FFF,GGG,HHH) \
1.97 + { _LIT(tempLogDes, AAA); reinterpret_cast<CSheduleServerLog*>(Dll::Tls())->Log(TRefByValue<const TDesC>(tempLogDes()),BBB,CCC,DDD,EEE,FFF,GGG,HHH); }
1.98 + #define LOGSTRING9(AAA,BBB,CCC,DDD,EEE,FFF,GGG,HHH,III) \
1.99 + { _LIT(tempLogDes, AAA); reinterpret_cast<CSheduleServerLog*>(Dll::Tls())->Log(TRefByValue<const TDesC>(tempLogDes()),BBB,CCC,DDD,EEE,FFF,GGG,HHH,III); }
1.100 + #define LOGSTRING10(AAA,BBB,CCC,DDD,EEE,FFF,GGG,HHH,III, JJJ) \
1.101 + { _LIT(tempLogDes, AAA); reinterpret_cast<CSheduleServerLog*>(Dll::Tls())->Log(TRefByValue<const TDesC>(tempLogDes()),BBB,CCC,DDD,EEE,FFF,GGG,HHH,III,JJJ); }
1.102 +
1.103 +
1.104 +#else
1.105 +
1.106 + // Defines
1.107 + #define LOGSTRING(AAA)
1.108 + #define LOGSTRING2(AAA,BBB)
1.109 + #define LOGSTRING3(AAA,BBB,CCC)
1.110 + #define LOGSTRING4(AAA,BBB,CCC,DDD)
1.111 + #define LOGSTRING5(AAA,BBB,CCC,DDD,EEE)
1.112 + #define LOGSTRING6(AAA,BBB,CCC,DDD,EEE,FFF)
1.113 + #define LOGSTRING7(AAA,BBB,CCC,DDD,EEE,FFF,GGG)
1.114 + #define LOGSTRING8(AAA,BBB,CCC,DDD,EEE,FFF,GGG,HHH)
1.115 + #define LOGSTRING9(AAA,BBB,CCC,DDD,EEE,FFF,GGG,HHH,III)
1.116 + #define LOGSTRING10(AAA,BBB,CCC,DDD,EEE,FFF,GGG,HHH,III, JJJ)
1.117 +
1.118 +#endif
1.119 +
1.120 +#endif