locationsystemui/locationsysui/posindicator/posreversegeocodeinterface/src/posreversegeocodeinterface.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 15:37:04 +0300
branchRCL_3
changeset 44 2b4ea9893b66
permissions -rw-r--r--
Revision: 201033 Kit: 201035

/*
* Copyright (c) 2010 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 Geo coding interface class.
*
*/

#include "posreversegeocodeinterface.h"
#include "posreversegeocodeinterface.hrh"

#include <ecom.h>

// static cleanup function
static void RImpleInfoPtrArrayCleanup( TAny* aArray )
    {
    static_cast<RImplInfoPtrArray*>( aArray )->ResetAndDestroy();
    }


//------------------------------------------------------------------------------
// CPosReverseGeocodeInterface::NewL
//------------------------------------------------------------------------------
EXPORT_C CPosReverseGeocodeInterface* CPosReverseGeocodeInterface::NewL( 
                                            MPosReverseGeocodeObserver& aObserver )
    {
    RImplInfoPtrArray implInfoPtrArray;
    TCleanupItem arrayCleanup( RImpleInfoPtrArrayCleanup, &implInfoPtrArray );
    CleanupStack::PushL(arrayCleanup);
    
    TUid implementationUID;
    
    REComSession::ListImplementationsL( TUid::Uid(KPosReverseGeoCodeInterfaceId),
                                        implInfoPtrArray );
    
    if( implInfoPtrArray.Count() == 0 )
        {
        implInfoPtrArray.ResetAndDestroy();
        User::Leave( KErrNotFound );
        }

    const CImplementationInformation* pluginInformation = implInfoPtrArray[0];
    implementationUID = pluginInformation->ImplementationUid();
                                            
    TAny* ptr = REComSession::CreateImplementationL( implementationUID,
                                                     _FOFF(CPosReverseGeocodeInterface,iDtor_ID_Key),
                                                     reinterpret_cast<TAny*>( &aObserver ));
    REComSession::FinalClose();
    CleanupStack::PopAndDestroy(); // arrayCleanup
    return reinterpret_cast<CPosReverseGeocodeInterface*>(ptr);
    }

//----------------------------------------------------------------------------------
// CPosReverseGeocodeInterface::~CPosReverseGeocodeInterface
//----------------------------------------------------------------------------------
EXPORT_C CPosReverseGeocodeInterface::~CPosReverseGeocodeInterface()
    {
    REComSession::DestroyedImplementation(iDtor_ID_Key);
    }