wvuing/wvuieng/EngSrc/CCAErrorData.cpp
changeset 0 094583676ce7
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/wvuing/wvuieng/EngSrc/CCAErrorData.cpp	Thu Dec 17 08:41:52 2009 +0200
@@ -0,0 +1,334 @@
+/*
+* Copyright (c) 2002-2005 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:  Holds error message information
+*
+*/
+
+// INCLUDE FILES
+#include    "CCAErrorData.h"
+#include    "ChatDebugPrint.h"
+
+#include    <impsdetailed.h>
+#include    <impserrors.h>
+#include    <badesca.h>
+
+const TInt KErrorDataArrayGranularity = 3;
+
+// ================= MEMBER FUNCTIONS =======================
+
+// Two-phased constructor.
+CCAErrorData* CCAErrorData::NewL( const CImpsDetailedResult& aDetailedResult )
+    {
+    CCAErrorData* self = new ( ELeave ) CCAErrorData();
+
+    CleanupStack::PushL( self );
+    self->ConstructL( aDetailedResult );
+    CleanupStack::Pop( self );
+
+    return self;
+    }
+
+// Two-phased constructor.
+CCAErrorData* CCAErrorData::NewL(
+    TInt                aCode,
+    const TDesC&        aDescription,
+    const CPtrC16Array* aUserIDs,
+    const CPtrC16Array* aGroupIDs,
+    const CPtrC16Array* aMessageIDs,
+    const CPtrC16Array* aScreenNames,
+    const CPtrC16Array* aScreenNameGroup )
+    {
+    CCAErrorData* self = new ( ELeave ) CCAErrorData();
+
+    CleanupStack::PushL( self );
+    self->ConstructL(
+        aCode,
+        aDescription,
+        aUserIDs,
+        aGroupIDs,
+        aMessageIDs,
+        aScreenNames,
+        aScreenNameGroup );
+
+    CleanupStack::Pop( self );
+
+    return self;
+    }
+
+
+// Destructor
+CCAErrorData::~CCAErrorData()
+    {
+    delete iDescription;
+
+    if ( iUserIDs )
+        {
+        iUserIDs->Reset();
+        }
+    delete iUserIDs;
+
+    if ( iGroupIDs )
+        {
+        iGroupIDs->Reset();
+        }
+    delete iGroupIDs;
+
+    if ( iMsgIDs )
+        {
+        iMsgIDs->Reset();
+        }
+    delete iMsgIDs;
+
+    if ( iScreenNames )
+        {
+        iScreenNames->Reset();
+        }
+    delete iScreenNames;
+
+    if ( iScreenNameGroup )
+        {
+        iScreenNameGroup->Reset();
+        }
+    delete iScreenNameGroup;
+    }
+
+// ---------------------------------------------------------
+// CCAErrorData::Code
+// ---------------------------------------------------------
+//
+EXPORT_C TInt CCAErrorData::Code() const
+    {
+    // In case we get error code in specification format => 531 e.g.
+    if ( iCode > 0 )
+        {
+        // Imps_ERROR_BASE is negative so "+"
+        return ( - iCode + Imps_ERROR_BASE );
+        }
+
+    return iCode;
+    }
+
+// ---------------------------------------------------------
+// CCAErrorData::Description
+// ---------------------------------------------------------
+//
+EXPORT_C const TDesC& CCAErrorData::Description() const
+    {
+    return *iDescription;
+    }
+
+// ---------------------------------------------------------
+// CCAErrorData::UserIDs
+// ---------------------------------------------------------
+//
+EXPORT_C const CDesCArray& CCAErrorData::UserIDs() const
+    {
+    return *iUserIDs;
+    }
+
+// ---------------------------------------------------------
+// CCAErrorData::GroupIDs
+// ---------------------------------------------------------
+//
+EXPORT_C const CDesCArray& CCAErrorData::GroupIDs() const
+    {
+    return *iGroupIDs;
+    }
+
+// ---------------------------------------------------------
+// CCAErrorData::MessageIDs
+// ---------------------------------------------------------
+//
+EXPORT_C const CDesCArray& CCAErrorData::MessageIDs() const
+    {
+    return *iMsgIDs;
+    }
+
+// ---------------------------------------------------------
+// CCAErrorData::ScreenNames
+// ---------------------------------------------------------
+//
+EXPORT_C const CDesCArray& CCAErrorData::ScreenNames() const
+    {
+    return *iScreenNames;
+    }
+
+// ---------------------------------------------------------
+// CCAErrorData::ScreenNameGroup
+// ---------------------------------------------------------
+//
+EXPORT_C const CDesCArray& CCAErrorData::ScreenNameGroup() const
+    {
+    return *iScreenNameGroup;
+    }
+
+
+// Symbian OS default constructor can leave.
+void CCAErrorData::ConstructL( const CImpsDetailedResult& aDetailedResult )
+    {
+    // Set all the data available
+    SetCode( aDetailedResult.Code() );
+
+    iDescription = aDetailedResult.Descriptor().AllocL();
+
+    SetUserIDsL( aDetailedResult.UserIds() );
+
+    SetGroupIDsL( aDetailedResult.GroupIds() );
+
+    SetMessageIDsL( aDetailedResult.MessageIds() );
+
+    SetScreenNamesL( aDetailedResult.SNames() );
+
+    SetScreenNamesGroupsL( aDetailedResult.SNameGroups() );
+
+    }
+
+// Symbian OS default constructor can leave.
+void CCAErrorData::ConstructL(
+    TInt                aCode,
+    const TDesC&        aDescription,
+    const CPtrC16Array* aUserIDs,
+    const CPtrC16Array* aGroupIDs,
+    const CPtrC16Array* aMessageIDs,
+    const CPtrC16Array* aScreenNames,
+    const CPtrC16Array* aScreenNameGroup )
+    {
+    // Set all the data available
+    SetCode( aCode );
+
+    iDescription = aDescription.AllocL();
+
+    SetUserIDsL( aUserIDs );
+
+    SetGroupIDsL( aGroupIDs );
+
+    SetMessageIDsL( aMessageIDs );
+
+    SetScreenNamesL( aScreenNames );
+
+    SetScreenNamesGroupsL( aScreenNameGroup );
+    }
+
+// C++ default constructor can NOT contain any code, that
+// might leave.
+//
+CCAErrorData::CCAErrorData()
+    {
+    }
+
+// ---------------------------------------------------------
+// CCAErrorData::SetCode
+// ---------------------------------------------------------
+//
+void CCAErrorData::SetCode( TInt aCode )
+    {
+    iCode = aCode;
+    }
+
+// ---------------------------------------------------------
+// CCAErrorData::SetUserIDsL
+// ---------------------------------------------------------
+//
+void CCAErrorData::SetUserIDsL( const CPtrC16Array* aUserIDs )
+    {
+    iUserIDs = new ( ELeave ) CDesCArrayFlat( KErrorDataArrayGranularity );
+    // Get User WV IDs
+    if ( aUserIDs )
+        {
+        TInt count( aUserIDs->MdcaCount() );
+        for ( TInt arrayIndex( 0 ); arrayIndex < count; ++arrayIndex )
+            {
+            iUserIDs->AppendL( aUserIDs->MdcaPoint( arrayIndex ) );
+            }
+        }
+    }
+
+
+// ---------------------------------------------------------
+// CCAErrorData::SetGroupIDsL
+// ---------------------------------------------------------
+//
+void CCAErrorData::SetGroupIDsL( const CPtrC16Array* aGroupIDs )
+    {
+    iGroupIDs = new ( ELeave ) CDesCArrayFlat( KErrorDataArrayGranularity );
+    // Get group WV IDs
+    if ( aGroupIDs )
+        {
+        TInt count( aGroupIDs->MdcaCount() );
+        for ( TInt arrayIndex( 0 ); arrayIndex < count; ++arrayIndex )
+            {
+            iGroupIDs->AppendL( aGroupIDs->MdcaPoint( arrayIndex ) );
+            }
+        }
+    }
+
+
+// ---------------------------------------------------------
+// CCAErrorData::SetMessageIDsL
+// ---------------------------------------------------------
+//
+void CCAErrorData::SetMessageIDsL( const CPtrC16Array* aMessageIDs )
+    {
+    iMsgIDs = new ( ELeave ) CDesCArrayFlat( KErrorDataArrayGranularity );
+    // Get message ids
+    if ( aMessageIDs )
+        {
+        TInt count( aMessageIDs->MdcaCount() );
+        for ( TInt arrayIndex( 0 ); arrayIndex < count; ++arrayIndex )
+            {
+            iMsgIDs->AppendL( aMessageIDs->MdcaPoint( arrayIndex ) );
+            }
+        }
+    }
+
+// ---------------------------------------------------------
+// CCAErrorData::SetScreenNamesL
+// ---------------------------------------------------------
+//
+void CCAErrorData::SetScreenNamesL( const CPtrC16Array* aScreenNames )
+    {
+    iScreenNames = new ( ELeave ) CDesCArrayFlat( KErrorDataArrayGranularity );
+    // Get screen names
+    if ( aScreenNames )
+        {
+        TInt count( aScreenNames->MdcaCount() );
+        for ( TInt arrayIndex( 0 ); arrayIndex < count; ++arrayIndex )
+            {
+            iScreenNames->AppendL( aScreenNames->MdcaPoint( arrayIndex ) );
+            }
+        }
+    }
+
+
+// ---------------------------------------------------------
+// CCAErrorData::SetScreenNamesGroupsL
+// ---------------------------------------------------------
+//
+void CCAErrorData::SetScreenNamesGroupsL(
+    const CPtrC16Array* aScreenNameGroups )
+    {
+    iScreenNameGroup =
+        new ( ELeave ) CDesCArrayFlat( KErrorDataArrayGranularity );
+    // Get groups of screen names
+    if ( aScreenNameGroups )
+        {
+        TInt count( aScreenNameGroups->MdcaCount() );
+        for ( TInt arrayIndex( 0 ); arrayIndex < count; ++arrayIndex )
+            {
+            iScreenNameGroup->AppendL(
+                aScreenNameGroups->MdcaPoint( arrayIndex ) );
+            }
+        }
+    }
+//  End of File