mds_plat/location_manager_api/inc/reversegeocoderplugin.inl
author hgs
Wed, 06 Oct 2010 15:08:08 +0300
changeset 60 79f826a55db2
parent 51 87e65c44ff3a
permissions -rw-r--r--
201039
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
51
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description: This is partial interface implementation which is 
hgs
parents:
diff changeset
    15
*              used by plugins. 
hgs
parents:
diff changeset
    16
* 
hgs
parents:
diff changeset
    17
*/
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
// INCLUDE FILES
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
#include <ecom/ecom.h>       // declares E-com framework classes
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    27
// CReverseGeoCoderPlugin::~CReverseGeoCoderPlugin()
hgs
parents:
diff changeset
    28
// Destroys the plugin implementation
hgs
parents:
diff changeset
    29
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    30
//
hgs
parents:
diff changeset
    31
inline CReverseGeoCoderPlugin::~CReverseGeoCoderPlugin()
hgs
parents:
diff changeset
    32
{
hgs
parents:
diff changeset
    33
    REComSession::DestroyedImplementation( iDtorKey );
hgs
parents:
diff changeset
    34
}
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    38
// CReverseGeoCoderPlugin::NewL()
hgs
parents:
diff changeset
    39
// Creates the instance of CReverseGeoCoderPlugin concrete implementation.
hgs
parents:
diff changeset
    40
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    41
//
hgs
parents:
diff changeset
    42
inline CReverseGeoCoderPlugin* CReverseGeoCoderPlugin::NewL()
hgs
parents:
diff changeset
    43
{
hgs
parents:
diff changeset
    44
		RImplInfoPtrArray aImplInfoArray;
hgs
parents:
diff changeset
    45
		REComSession::ListImplementationsL(KReversegeocodeInterfaceUid, aImplInfoArray);
hgs
parents:
diff changeset
    46
		
hgs
parents:
diff changeset
    47
		TInt count = aImplInfoArray.Count();
hgs
parents:
diff changeset
    48
		
hgs
parents:
diff changeset
    49
		if(!count) 
hgs
parents:
diff changeset
    50
			{
hgs
parents:
diff changeset
    51
			/* No implementations found for the reverse geocoding functionality */
hgs
parents:
diff changeset
    52
			User::Leave(KErrNotFound);
hgs
parents:
diff changeset
    53
			}
hgs
parents:
diff changeset
    54
			
hgs
parents:
diff changeset
    55
		/* One or more implementations found. Choose the first one */
hgs
parents:
diff changeset
    56
		const CImplementationInformation* plugin = aImplInfoArray[0];
hgs
parents:
diff changeset
    57
		TUid  pluginId = plugin->ImplementationUid();
hgs
parents:
diff changeset
    58
		
hgs
parents:
diff changeset
    59
		CReverseGeoCoderPlugin* self = reinterpret_cast<CReverseGeoCoderPlugin*>(
hgs
parents:
diff changeset
    60
	       		REComSession::CreateImplementationL(
hgs
parents:
diff changeset
    61
	           pluginId, _FOFF( CReverseGeoCoderPlugin,iDtorKey ) ) );
hgs
parents:
diff changeset
    62
	
hgs
parents:
diff changeset
    63
	    return self;
hgs
parents:
diff changeset
    64
}
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
// End of file