libraries/iosrv/server/log.h
changeset 0 7f656887cf89
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libraries/iosrv/server/log.h	Wed Jun 23 15:52:26 2010 +0100
@@ -0,0 +1,72 @@
+// log.h
+// 
+// Copyright (c) 2006 - 2010 Accenture. All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of the "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:
+// Accenture - Initial contribution
+//
+
+#ifndef __LOG_H__
+#define __LOG_H__
+
+#include <e32base.h>
+#include <f32file.h>
+#include "server.h"
+
+#ifdef _DEBUG
+//#define IOSRV_LOGGING
+#endif
+
+#ifdef IOSRV_LOGGING
+
+#ifdef IOSRV_LOGGING_USES_CLOGGER // This is defined in the mmp
+#include <fshell/clogger.h>
+#endif
+
+#define LOG(x) x
+#define OBJ_NAME(x) TName objName((x).Name())
+
+class CIoLog : public CBase
+	{
+public:
+	static CIoLog* NewL(RFs& aFs);
+	~CIoLog();
+	static void StartServiceLC(const RMsg& aMessage);
+	static void LogCompletion(const RMsg& aMessage, TInt aError);
+	static void Write(const TDesC& aData);
+	static void Printf(TRefByValue<const TDesC> aFmt, ...);
+	static const TDesC* StringifyError(TInt aError);
+	static const TDesC* StringifyOpcode(TInt aOpCode);
+private:
+	CIoLog(RFs& aFs);
+	void ConstructL();
+	static CIoLog& Self();
+	static void EndService(TAny* aSelf);
+private:
+	RFs& iFs;
+#ifdef IOSRV_LOGGING_USES_CLOGGER
+	RClogger iClogger;
+#else
+	RFile iFile;
+	TBuf8<0x100> iNarrowBuf;
+#endif
+	TBuf<0x100> iScratchBuf;
+	TBool iInServiceL;
+	};
+
+#if !defined(__WINS__) || defined (EKA2)
+extern CIoLog* gLog;
+#endif
+
+#else
+
+#define LOG(x)
+#define OBJ_NAME(x)
+
+#endif // IOSRV_LOGGING
+
+#endif // __LOG_H__