photosgallery/logging/client/src/glxlogger.cpp
changeset 0 4e91876724a2
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/photosgallery/logging/client/src/glxlogger.cpp	Thu Dec 17 08:45:44 2009 +0200
@@ -0,0 +1,82 @@
+/*
+* Copyright (c) 2008-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:    Logging utility for MC Photos
+*
+*/
+
+
+
+
+// CLASS HEADER
+#include "glxlogger.h"
+
+// EXTERNAL INCLUDES
+#include <e32debug.h>
+#include <flogger.h>
+
+// INTERNAL INCLUDES
+//#include "glxlogchunk.h"
+
+namespace GlxLogger
+    {
+    /// constants
+    const TInt KMaxLoggingBufferLength = 256;
+/*#ifndef __WINSCW__
+    /// writeable buffer, this requires static data
+    TBuf8< KMaxLoggingBufferLength > gWriteBuffer;
+    _LIT( KGlxLoggingDirectory, "MCPhotos" );
+    _LIT( KGlxLoggingFileName, "debug_%d.log" );
+#endif*/
+
+/**
+ * TDes overflow handler
+ * Default overflow handler panics and we dont want to do 
+ * that in logging so need to implement our own handler.
+ */ 
+class TDes8OverFlowHandler : public TDes8Overflow
+    {
+    public: // from TDes8Overflow
+        /// @ref TDes8Overflow::Overflow
+        void Overflow( TDes8& /*aDes*/ )
+            {
+            // do nothing, we cant allocate so just eat the error
+            }
+    };
+
+// -----------------------------------------------------------------------------
+// GlxLogger::WriteFormat
+// -----------------------------------------------------------------------------
+EXPORT_C void WriteFormat( TRefByValue< const TDesC8 > aFmt, ... )
+    {
+    /// writeable buffer, in emulator this is in stack
+    TBuf8< KMaxLoggingBufferLength > gWriteBuffer;
+    // take the ellipsis parameter
+    VA_LIST args;
+    VA_START( args, aFmt );
+    // create overflow handler
+    TDes8OverFlowHandler overflowhandler;
+    // clear old data by setting length to zero
+    gWriteBuffer.SetLength( 0 );
+    // append the parameters to the descriptor
+    gWriteBuffer.AppendFormatList( aFmt, args, &overflowhandler );
+    // end the ellipsis handling
+    VA_END( args );
+    
+    TBuf16<256> buffer;
+    buffer.Copy(gWriteBuffer);
+    RDebug::Print(_L("MCPhotos:-%S"),&buffer);
+    
+    } // namespace
+    
+} // namespace