meetingrequest/mrgui/src/resmrstatic.cpp
branchRCL_3
changeset 12 4ce476e64c59
parent 11 0396474f30f5
child 13 8592a65ad3fb
--- a/meetingrequest/mrgui/src/resmrstatic.cpp	Mon Mar 15 12:39:10 2010 +0200
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,329 +0,0 @@
-/*
-* Copyright (c) 2007-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:  Static Tls data storage
-*
-*/
-
-
-#include "emailtrace.h"
-#include "resmrstatic.h"
-
-#include "cesmrcontactmenuhandler.h"
-#include "cesmrcontactmanagerhandler.h"
-#include "cfsmailclient.h"
-#include "cfsmailbox.h"
-// <cmail> Removed profiling </cmail>
-
-/**
- * Storage stuct for RESMRStatic.
- */
-struct TESMRStaticData
-    {
-    TInt iInstanceCount;
-    TInt iContactManagerHandlerCount;
-    CESMRContactManagerHandler* iContactManagerHandler;
-    TInt iContactMenuHandlerCount;
-    CESMRContactMenuHandler* iContactMenuHandler;
-    CFSMailClient* iFSMailClient;
-    CFSMailBox* iFSMailBox;
-
-    TInt iPbkxContactListingServiceCount;
-    TInt iCurrentFieldIndex;
-    TInt iFSMailBoxCount;
-    };
-
-// ---------------------------------------------------------------------------
-// Cleanup operation for RPointerArray.
-// @param aArray Pointer to RPointerArray.
-// ---------------------------------------------------------------------------
-//
-void MailboxPointerArrayCleanup( TAny* aArray )
-    {
-    // just to avoid warnings when MR not supported
-    RPointerArray<CFSMailBox>* entryArray =
-        static_cast<RPointerArray<CFSMailBox>*>( aArray );
-
-    entryArray->ResetAndDestroy();
-    entryArray->Close();
-    }
-
-// ======== MEMBER FUNCTIONS ========
-
-// ---------------------------------------------------------------------------
-// RESMRStatic::RESMRStatic
-// ---------------------------------------------------------------------------
-//
-EXPORT_C RESMRStatic::RESMRStatic( )
-    {
-    FUNC_LOG;
-    //do nothing
-    }
-
-// ---------------------------------------------------------------------------
-// RESMRStatic::~RESMRStatic
-// ---------------------------------------------------------------------------
-//
-EXPORT_C RESMRStatic::~RESMRStatic( )
-    {
-    FUNC_LOG;
-    if ( iStaticData )
-        {
-        delete iStaticData->iContactMenuHandler;
-        iStaticData->iContactMenuHandler = NULL;
-
-        delete iStaticData->iContactManagerHandler;
-        iStaticData->iContactManagerHandler = NULL;
-        }
-    }
-
-// ---------------------------------------------------------------------------
-// RESMRStatic::ConnectL
-// ---------------------------------------------------------------------------
-//
-EXPORT_C void RESMRStatic::ConnectL( )
-    {
-    FUNC_LOG;
-    if (iStaticData )
-        {
-        // already connected
-        return;
-        }
-
-    // Retrieve Tls pointer
-    iStaticData = (TESMRStaticData*) Dll::Tls();
-
-    // If Tls pointer was not set, create new static stuct
-    // with NULL values
-    if ( !iStaticData )
-        {
-        iStaticData = new (ELeave) TESMRStaticData();
-        memset ( iStaticData, 0, sizeof( TESMRStaticData) );
-        Dll::SetTls ( iStaticData );
-        }
-    ++iStaticData->iInstanceCount;
-    }
-
-// ---------------------------------------------------------------------------
-// RESMRStatic::Close
-// ---------------------------------------------------------------------------
-//
-EXPORT_C void RESMRStatic::Close( )
-    {
-    FUNC_LOG;
-    if (iStaticData )
-        {
-        if (iUsedTypes & EContactMenuHandler )
-            {
-            --iStaticData->iContactMenuHandlerCount;
-            if (iStaticData->iContactMenuHandlerCount == 0 )
-                {
-                if ( iStaticData->iContactManagerHandlerCount == 0 )
-                    {
-                    // Delete both Handlers when both are ready to delete
-                    // and Contact Manager Handler should be deleted last
-                    // because the Menu Handler has dependency to it.
-                    delete iStaticData->iContactMenuHandler;
-                    iStaticData->iContactMenuHandler = NULL;
-
-                    delete iStaticData->iContactManagerHandler;
-                    iStaticData->iContactManagerHandler = NULL;
-                    }
-                }
-            }
-
-        // If ContactManagerHandlerL was used
-        if (iUsedTypes & EContactManagerHandler )
-            {
-            // Decrease counter
-            --iStaticData->iContactManagerHandlerCount;
-
-            // If this was last instance using pointer
-            if ( iStaticData->iContactManagerHandlerCount == 0 )
-                {
-                if ( iStaticData->iContactMenuHandlerCount == 0 )
-                    {
-                    delete iStaticData->iContactMenuHandler;
-                    iStaticData->iContactMenuHandler = NULL;
-                    // Delete instance
-                    delete iStaticData->iContactManagerHandler;
-                    iStaticData->iContactManagerHandler = NULL;
-                    }
-                }
-            }
-        
-        // If FSMailClientL or FSMailBox was used
-        if (iUsedTypes & EMailBoxHandler )
-            {
-            // Decrease counter
-            --iStaticData->iFSMailBoxCount;
-
-            // If this was last instance using pointer
-            if (iStaticData->iFSMailBoxCount == 0 )
-                {
-                // Owned by CFSMailClient
-                delete iStaticData->iFSMailBox;
-                iStaticData->iFSMailBox = NULL;
-
-                // Delete instance
-                if ( iStaticData->iFSMailClient )
-                    {
-                    iStaticData->iFSMailClient->Close();
-                    iStaticData->iFSMailClient = NULL;
-                    }
-                }
-            }
-
-        // Decrease instance counter
-        --iStaticData->iInstanceCount;
-
-        // If this was last instance using pointer
-        if (iStaticData->iInstanceCount == 0 )
-            {
-            delete iStaticData;
-            Dll::FreeTls ( );
-            }
-        iStaticData = NULL;
-        }
-    }
-
-// ---------------------------------------------------------------------------
-// RESMRStatic::ContactManagerHandlerL
-// ---------------------------------------------------------------------------
-//
-EXPORT_C CESMRContactManagerHandler& RESMRStatic::ContactManagerHandlerL( )
-    {
-    FUNC_LOG;
-    if ( !iStaticData->iContactManagerHandler )
-        {
-        iStaticData->iContactManagerHandler = 
-			CESMRContactManagerHandler::NewL();
-        }
-
-    if (!(iUsedTypes & EContactManagerHandler) )
-        {
-        ++iStaticData->iContactManagerHandlerCount;
-        iUsedTypes |= EContactManagerHandler;
-        }
-    return *iStaticData->iContactManagerHandler;
-    }
-
-// ---------------------------------------------------------------------------
-// RESMRStatic::ContactMenuHandlerL
-// ---------------------------------------------------------------------------
-//
-EXPORT_C CESMRContactMenuHandler& RESMRStatic::ContactMenuHandlerL( )
-    {
-    FUNC_LOG;
-    if ( !iStaticData->iContactMenuHandler )
-        {
-        iStaticData->iContactMenuHandler =
-            CESMRContactMenuHandler::NewL( ContactManagerHandlerL() );
-        }
-
-    if (!(iUsedTypes & EContactMenuHandler) )
-        {
-        ++iStaticData->iContactMenuHandlerCount;
-        iUsedTypes |= EContactMenuHandler;
-        }
-
-    return *iStaticData->iContactMenuHandler;
-    }
-
-// ---------------------------------------------------------------------------
-// RESMRStatic::CurrentFieldIndex
-// ---------------------------------------------------------------------------
-//
-EXPORT_C TInt RESMRStatic::CurrentFieldIndex()
-    {
-    FUNC_LOG;
-    return iStaticData->iCurrentFieldIndex;
-    }
-
-// ---------------------------------------------------------------------------
-// RESMRStatic::SetCurrentFieldIndex
-// ---------------------------------------------------------------------------
-//
-EXPORT_C void RESMRStatic::SetCurrentFieldIndex(TInt aFieldIndex)
-    {
-    FUNC_LOG;
-    iStaticData->iCurrentFieldIndex = aFieldIndex;
-    }
-
-// ---------------------------------------------------------------------------
-// RESMRStatic::MailBoxL
-// ---------------------------------------------------------------------------
-//
-EXPORT_C CFSMailBox& RESMRStatic::MailBoxL( const TDesC& aAddress )
-    {
-    FUNC_LOG;
-    if ( !iStaticData->iFSMailBox )
-        {
-        CFSMailClient& fsMailClient = FSMailClientL();
-
-        // Loop throug all mailboxes in this plug-in
-        RPointerArray<CFSMailBox> mailboxes; // codescanner::resourcenotoncleanupstack
-        CleanupStack::PushL(
-                TCleanupItem(
-                        MailboxPointerArrayCleanup,
-                        &mailboxes    ) );
-
-        // With null uid we get all mailboxes
-        TFSMailMsgId msgId;
-        fsMailClient.ListMailBoxes(
-                msgId, mailboxes );
-
-        TInt mailboxCount( mailboxes.Count() );
-        for ( TInt j(0);
-              j < mailboxCount && !iStaticData->iFSMailBox;
-              ++j )
-            {
-            TPtrC mailboxOwnerAddName(
-                    mailboxes[j]->OwnMailAddress().GetEmailAddress() );
-            if ( mailboxOwnerAddName.Compare( aAddress ) == 0 )
-                {
-                // Correct mailbox is found
-                iStaticData->iFSMailBox = mailboxes[j];
-                mailboxes.Remove(j);
-                }
-            }
-        CleanupStack::PopAndDestroy(); // mailboxes
-
-        if ( !iStaticData->iFSMailBox )
-            {
-            User::Leave( KErrAbort );
-            }
-        }
-
-    iUsedTypes |= EMailBoxHandler;
-    ++iStaticData->iFSMailBoxCount;
-    return *iStaticData->iFSMailBox;
-    }
-
-// ---------------------------------------------------------------------------
-// RESMRStatic::FSMailClientL
-// ---------------------------------------------------------------------------
-//
-CFSMailClient& RESMRStatic::FSMailClientL( )
-    {
-    FUNC_LOG;
-    if (!iStaticData->iFSMailClient)
-        {
-        iStaticData->iFSMailClient = CFSMailClient::NewL ( );
-        }
-
-    return *iStaticData->iFSMailClient;
-    }
-
-// EOF
-