phonebookui/Phonebook2/inc/CPbk2MigrationInterface.h
author andy simpson <andrews@symbian.org>
Thu, 02 Sep 2010 15:35:50 +0100
branchRCL_3
changeset 64 c1e8ba0c2b16
parent 0 e686773b3f54
permissions -rw-r--r--
Merge after bad RCL_3 drop reverted

/*
* Copyright (c) 2005-2007 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:  Plug-in interface for Phonebook 2 migration support.
*
*/


#ifndef CPBK2MIGRATIONINTERFACE_H
#define CPBK2MIGRATIONINTERFACE_H

// INCLUDES
#include <e32base.h>
#include <ecom/ecom.h>
#include <Pbk2InternalUID.h>

// FORWARD DECLARATIONS
class CPbk2ViewState;
class CVPbkContactManager;


// CLASS DECLARATION

/**
 * Plug-in interface for Phonebook 2 migration support.
 *
 * @internal This interface is internal to Phonebook2.
 */
class CPbk2MigrationInterface : public CBase
    {
    public: // Constructor and destructor

        /**
         * Creates a new instance of this class.
         *
         * @param aContactManager   Virtual Phonebook contact manager.
         * @return  A new instance of this class.
         */
        static CPbk2MigrationInterface* NewLC(
                CVPbkContactManager& aContactManager );

        /**
         * Destructor.
         */
        ~CPbk2MigrationInterface();

    public: // Interface

        /**
         * Converts the data in a CPbkViewState format descriptor
         * to a CPbk2ViewState object.
         *
         * @param aCustomMessage    Custom message containing a descriptor
         *                          in Phonebook 1 view state format.
         * @param aViewState        View state object in Phonebook 2 format.
         */
        virtual void ConvertViewStateL(
                const TDesC8& aCustomMessage,
                CPbk2ViewState& aViewState ) = 0;

    protected: // Implementation
        CPbk2MigrationInterface();

    private: // Data
        /// Own: Destructor id key
        TUid iDtor_ID_Key;
    };

// INLINE FUNCTIONS

// --------------------------------------------------------------------------
// CPbk2MigrationInterface::CPbk2MigrationInterface
// --------------------------------------------------------------------------
//
inline CPbk2MigrationInterface::CPbk2MigrationInterface()
    {
    }

// --------------------------------------------------------------------------
// CPbk2MigrationInterface::~CPbk2MigrationInterface
// --------------------------------------------------------------------------
//
inline CPbk2MigrationInterface::~CPbk2MigrationInterface()
    {
    REComSession::DestroyedImplementation( iDtor_ID_Key );
    }

// --------------------------------------------------------------------------
// CPbk2MigrationInterface::NewLC
// --------------------------------------------------------------------------
//
inline CPbk2MigrationInterface* CPbk2MigrationInterface::NewLC(
        CVPbkContactManager& aContactManager )
    {
    TAny* ptr = REComSession::CreateImplementationL(
            TUid::Uid( KPbk2MigrationSupportImplementationUID ),
            _FOFF( CPbk2MigrationInterface, iDtor_ID_Key ),
            static_cast<TAny*>( &aContactManager ) );

    CPbk2MigrationInterface* impl =
            static_cast<CPbk2MigrationInterface*>( ptr );
    CleanupStack::PushL( impl );
    return impl;
    }

#endif // CPBK2MIGRATIONINTERFACE_H

// End of File