--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/simpleengine/siputils/src/simpledebugutils.cpp	Tue Feb 02 01:05:17 2010 +0200
@@ -0,0 +1,213 @@
+/*
+* Copyright (c) 2006 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:    DEBUG utilities, for DEBUG version only
+*
+*/
+
+
+
+
+// INCLUDE FILES
+#include <e32std.h>
+#include <e32base.h>
+
+#ifdef _DEBUG
+#include <flogger.h>
+#include <e32debug.h>
+#include <apparc.h>
+#include <bautils.h>
+#endif  // _DEBUG
+
+#include "simpledebugutils.h"
+
+// ================= MEMBER FUNCTIONS =======================
+
+#ifdef _DEBUG
+
+//**********************************
+// TSimpleLogger
+//**********************************
+const TInt KLogBufferLength = 256;
+
+// ---------------------------------------------------------
+// TSimpleLogger::Log
+// ---------------------------------------------------------
+//
+void TSimpleLogger::Log(TRefByValue<const TDesC> aFmt,...) //lint !e960
+    {
+    VA_LIST list;
+    VA_START(list, aFmt); //lint !e960
+
+    // Print to log file
+    TBuf<KLogBufferLength> buf;
+    buf.FormatList(aFmt, list);
+
+    _LIT(KLogDir, "simple");
+    _LIT(KLogFile, "simple.txt");
+    // Write to log file
+    RFileLogger::Write(KLogDir, KLogFile, EFileLoggingModeAppend, buf);
+    
+    _LIT( KSimplePrefix,  "[simple] ");    
+    buf.Insert( 0, KSimplePrefix );
+    RDebug::RawPrint( buf );
+
+    }
+
+// ---------------------------------------------------------
+// TSimpleLogger::Dump
+// ---------------------------------------------------------
+//
+void TSimpleLogger::Dump( const TDesC8& aData, RFs& aFs, TInt aMode )
+    {
+    if ( !aData.Length() )
+        {
+        return;
+        }
+
+    _LIT(KLogDir, "c:\\logs\\simple\\");
+
+    TParse myParse;
+
+    // generate unique file name
+    TFileName fileName;
+    fileName = KLogDir;
+    if( BaflUtils::PathExists( aFs, fileName ) )
+        {
+        _LIT( KRelatedRcv, "Receive.xml");
+        _LIT( KRelatedSnt, "Sent.xml");
+        if ( aMode )
+            {
+            myParse.Set( fileName, &KRelatedRcv, NULL );
+            }
+        else
+            {
+            myParse.Set( fileName, &KRelatedSnt, NULL );
+            }
+        fileName = myParse.FullName();
+        if ( CApaApplication::GenerateFileName( aFs, fileName ))
+            {
+            return;
+            }
+
+        // write data into file
+        RFile file;
+        TInt xmlError = file.Create( aFs, fileName, EFileWrite | EFileShareExclusive );
+        if ( xmlError == KErrNone )
+            {
+            file.Write( aData );
+            file.Flush();
+            }
+
+        // done - close file
+        file.Close();
+
+        Log( _L("Dump: LogFile = %S"), &fileName );
+        }
+    }
+#endif  // _DEBUG
+
+
+//**********************************
+// CSimpleSettingFile
+//**********************************
+
+CSimpleSettingFile::~CSimpleSettingFile()
+    {
+    if ( iOpen )
+        {
+        iReader.Close();
+        }
+    iOpen = EFalse;
+    }
+
+CSimpleSettingFile::CSimpleSettingFile( RFs& aFs)
+: iFs( aFs ),
+  iOpen( EFalse )
+    {
+    }
+    
+#ifdef _DEBUG
+
+CSimpleSettingFile* CSimpleSettingFile::NewL(
+    RFs& aFs )
+    {
+    CSimpleSettingFile* self = new (ELeave) CSimpleSettingFile( aFs );
+    return self;
+    }
+
+void CSimpleSettingFile::OpenL(TDesC& aResFile)
+    {
+    // open a file
+    iFileName = aResFile;
+
+    TInt myError = iReader.Open( iFs,
+                             iFileName,
+                             EFileShareReadersOnly );
+
+    User::LeaveIfError( myError );
+    iOpen = ETrue;
+    }
+
+TPtrC8 CSimpleSettingFile::KeyValueL( const TDesC8& aKey )
+    {
+
+    TPtrC8 myKey;
+    TPtrC8 myValue;
+    TBool getIt(EFalse);
+    TInt err = 0;
+
+    // Reset the reader
+    OpenL( iFileName );
+
+    // Start to search
+    while ( !getIt)
+        {
+        TRAP ( err, ReadRowL( myKey, myValue ));
+        if ( err != KErrNone )
+            {
+            User::Leave( KErrNotFound );
+            }
+        if ( !myKey.CompareF( aKey ))
+            {
+            return myValue;
+            }
+        }
+    return TPtrC8();
+    }
+
+void CSimpleSettingFile::ReadRowL( TPtrC8& aKey, TPtrC8& aValue )
+    {
+    // READ ONE ROW
+    TChar delim( 10 );
+    iReader.ReadL( iRowBuffer, delim);
+    TInt length = iRowBuffer.Length();
+    if ( length > 2 )
+        {
+        // DROP CR+LF FROM THE END OF LINE
+        iRowBuffer.Delete( length - 2, 2 );
+
+        TInt pos = 0;
+        pos = iRowBuffer.Find( _L8("=") );
+        if ( pos > 0 )
+            {
+            aKey.Set( iRowBuffer.Left( pos ) );
+            // Cut off separator
+            aValue.Set( iRowBuffer.Mid( pos + 1 ) );
+            }
+        }
+    } 
+#endif  // _DEBUG   
+
+//  End of File
+