homescreenpluginsrv/hspstools/src/hspsodtdump.cpp
changeset 0 79c6a41cd166
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/homescreenpluginsrv/hspstools/src/hspsodtdump.cpp	Thu Dec 17 08:54:17 2009 +0200
@@ -0,0 +1,188 @@
+/*
+* Copyright (c) 2008 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:  Implementation of ChspsOdtDump.
+*
+*/
+
+
+#include "hspsodtdump.h"
+#include "hspslogbus.h"
+#include <hspsodt.h>
+#include <hspsdomdocument.h>
+#include <hspsdomlist.h>
+#include <hspsdomdepthiterator.h>
+#include <hspsdomnode.h>
+#include <hspsdomattribute.h>
+#include <hspsresource.h>
+#include <utf.h>
+
+//----------------------------------------------------------------------------
+// ChspsOdtDump::Dump()
+// ----------------------------------------------------------------------------
+//
+#ifdef HSPS_BUILD_LOG_IMPLEMENTATION
+EXPORT_C void ChspsOdtDump::Dump( ChspsODT& aOdt, ChspsLogBus& aLogBus )
+    {    
+    TRAP_IGNORE( DumpL( aOdt, aLogBus ) );
+    }
+#else
+EXPORT_C void ChspsOdtDump::Dump( ChspsODT& /*aOdt*/, ChspsLogBus& /*aLogBus*/ )
+    {    
+    }
+#endif
+
+//----------------------------------------------------------------------------
+// ChspsOdtDump::DumpL()
+// ----------------------------------------------------------------------------
+//
+#ifdef HSPS_BUILD_LOG_IMPLEMENTATION
+void ChspsOdtDump::DumpL( ChspsODT& aOdt, ChspsLogBus& aLogBus )
+    {            
+    __UHEAP_MARK;
+        ChspsDomDocument& domDocument = aOdt.DomDocument();
+    
+        aLogBus.LogText( _L( "### DOM DUMP START ###" ) );
+    
+        TInt attrCount(0);
+        // TInt propCount(0);
+        
+        ChspsDomDepthIterator* iter = ChspsDomDepthIterator::NewL( *domDocument.RootNode() );
+        CleanupStack::PushL( iter );
+        
+        _LIT8(KDelim, "\t" );
+        ChspsDomNode* nodeParent( NULL );
+        ChspsDomNode* node = iter->First();
+        while ( node )    
+            {
+            const TInt depth = GetNodeDepth( node );
+                            
+            HBufC8 *nameBuf = GetFixedTextLC( node->Name(), depth, KDelim, ETrue );
+            CleanupStack::PushL( nameBuf );
+            const TDesC8& name = nameBuf->Des();
+            
+            aLogBus.LogText( _L8("%S\n"), &name );              
+            
+            ChspsDomList& attrList = node->AttributeList();
+            TInt length( attrList.Length() );
+            attrCount += length;
+            //_LOGTFRM1(_L8(" Attribute count: %d\n"), length );
+            for( TInt i=0; i<length; i++ )
+                {
+                ChspsDomAttribute* attr = static_cast<ChspsDomAttribute*>( attrList.Item(i) );
+                
+                HBufC8 *attrBuf = GetFixedTextLC( attr->Name(), depth,  KDelim, EFalse );
+                CleanupStack::PushL( attrBuf );
+                const TDesC8& attrName = attrBuf->Des();
+                
+                const TDesC8& attrValue = attr->Value();
+                                        
+                aLogBus.LogText( _L8("%S=%S\n"), &attrName, &attrValue );
+                
+                CleanupStack::PopAndDestroy( attrBuf );
+                }
+            
+            if ( node->Parent() )
+                {
+                nodeParent = node;
+                }
+            if ( node != nodeParent )
+                {
+                
+                }
+            node = iter->NextL();
+            
+            CleanupStack::PopAndDestroy( nameBuf );
+            }
+        CleanupStack::PopAndDestroy( iter );
+
+       aLogBus.LogText( _L( "### DOM DUMP END ###" ) );        
+
+       aLogBus.LogText( _L8("**** Resources: ") );
+       
+       for( TInt index=0; index < aOdt.ResourceCount(); index++ )
+           {
+           ChspsResource* r = &aOdt.ResourceL(index);     
+           TBuf8<512> name;
+           CnvUtfConverter::ConvertFromUnicodeToUtf8( name, r->FileName() );               
+           aLogBus.LogText( _L8( "%D) %S\n" ), index, &name );
+           }
+       
+       aLogBus.LogText( _L8("**** Resources END ") );        
+       
+    __UHEAP_MARKEND;    
+    }
+#else
+void ChspsOdtDump::DumpL( ChspsODT& /*aOdt*/, ChspsLogBus& /*aLogBus*/ )
+    {    
+    }
+#endif
+
+//----------------------------------------------------------------------------
+// ChspsOdtDump::GetNodeDepth()
+// ----------------------------------------------------------------------------
+//
+#ifdef HSPS_BUILD_LOG_IMPLEMENTATION
+TInt ChspsOdtDump::GetNodeDepth( ChspsDomNode *aNode )
+    {
+    TInt depth = 0;
+    ChspsDomNode* node( aNode );
+    while( node )
+        {
+        node = node->Parent();
+        if ( node )
+            {
+            depth++;
+            }
+        }
+    return depth;
+    }
+#else
+TInt ChspsOdtDump::GetNodeDepth( ChspsDomNode* /*aNode*/ )
+    {
+    return 0;
+    }
+#endif
+
+//----------------------------------------------------------------------------
+// ChspsOdtDump::GetFixedTextLC()
+// ----------------------------------------------------------------------------
+//
+#ifdef HSPS_BUILD_LOG_IMPLEMENTATION
+HBufC8* ChspsOdtDump::GetFixedTextLC( const TDesC8& aText,
+                                      const TInt aDepth,
+                                      const TDesC8& aDelim,
+                                      TBool aShowHighlight )
+    {
+    HBufC8 *buf = HBufC8::NewL( aDepth * aDelim.Length() + aText.Length() + 1 + 1 );    
+    TInt i = 0;
+    for( ; i < aDepth; i++ )
+        {
+        buf->Des().Append( aDelim );
+        }
+    if ( !aShowHighlight )
+        {
+        buf->Des().Append( _L("*") );
+        }
+    buf->Des().Append( aText );
+    return buf;
+    }
+#else
+HBufC8* ChspsOdtDump::GetFixedTextLC( const TDesC8& /*aText*/,
+                                      const TInt /*aDepth*/,
+                                      const TDesC8& /*aDelim*/,
+                                      TBool /*aShowHighlight*/ )
+    {
+    return NULL;
+    }
+#endif