clock2/clockengines/clocktimesourceinterface/inc/clocktimesourceinterface.h
author hgs
Wed, 03 Nov 2010 17:12:22 +0530
changeset 89 b57382753122
permissions -rw-r--r--
201045
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
89
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2008 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:   The header file for the CClockTimeSourceInterface class.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef __CLOCK_TIMESOURCE_INTERFACE_H__
hgs
parents:
diff changeset
    19
#define __CLOCK_TIMESOURCE_INTERFACE_H__
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
// System includes
hgs
parents:
diff changeset
    22
#include <e32std.h>
hgs
parents:
diff changeset
    23
#include <e32base.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
// User includes
hgs
parents:
diff changeset
    26
#include "clocktimesourceinterface.hrh"
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// Forward declarations
hgs
parents:
diff changeset
    29
class MClockPluginObserver;
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
/** 
hgs
parents:
diff changeset
    32
* @brief This is an interface class that needs to be implemented by
hgs
parents:
diff changeset
    33
*        every ECOM based plugin which updates the device time.
hgs
parents:
diff changeset
    34
* @dll clocktimesourceinterface.dll
hgs
parents:
diff changeset
    35
*/
hgs
parents:
diff changeset
    36
class CClockTimeSourceInterface : public CBase
hgs
parents:
diff changeset
    37
	{
hgs
parents:
diff changeset
    38
	public:			// Constructor and Destructor
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
		/**
hgs
parents:
diff changeset
    41
		* @brief Two phases constructor, to construct the object of the 
hgs
parents:
diff changeset
    42
		*        ECOM implementation referred to by the aImpId.
hgs
parents:
diff changeset
    43
		* @param aImpId Implementation id of the ECOM implementation to be loaded.
hgs
parents:
diff changeset
    44
		* @return CClockTimeSourceInterface* Pointer to an instance of aImpId.
hgs
parents:
diff changeset
    45
		*/
hgs
parents:
diff changeset
    46
		IMPORT_C static CClockTimeSourceInterface* NewL( const TUid& aPluginId,
hgs
parents:
diff changeset
    47
    								  					 MClockPluginObserver* aObserver );
hgs
parents:
diff changeset
    48
		
hgs
parents:
diff changeset
    49
		/**
hgs
parents:
diff changeset
    50
		* @brief Destroy the object and release all memory objects
hgs
parents:
diff changeset
    51
		*/
hgs
parents:
diff changeset
    52
	  	IMPORT_C ~CClockTimeSourceInterface();
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
	public:			// New functions
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
	  	//IMPORT_C has been removed from below api's because we should not be exporting
hgs
parents:
diff changeset
    57
	  	//pure virtual functions
hgs
parents:
diff changeset
    58
	  	
hgs
parents:
diff changeset
    59
		/**
hgs
parents:
diff changeset
    60
		* @brief Gets the UTC Time, pure virtual, to be implemented by the plugin.
hgs
parents:
diff changeset
    61
		* @param aInterfaceAttribute anyone of enum TInterfaceAttribute defined in clocktimesourceinterface.hrh
hgs
parents:
diff changeset
    62
		* @param aTimeAttributes The type of data requested
hgs
parents:
diff changeset
    63
		*/
hgs
parents:
diff changeset
    64
		 virtual void GetTimeInformationL( TInterfaceAttribute aInterfaceAttribute,
hgs
parents:
diff changeset
    65
		                                           STimeAttributes* aTimeAttributes ) = 0;
hgs
parents:
diff changeset
    66
		
hgs
parents:
diff changeset
    67
		/**
hgs
parents:
diff changeset
    68
		* @brief Gets the UTC Time, pure virtual, to be implemented by the plugin.
hgs
parents:
diff changeset
    69
		* @param aInterfaceAttribute anyone of enum TInterfaceAttribute defined in clocktimesourceinterface.hrh
hgs
parents:
diff changeset
    70
		* @param aPtr TAny* to the type of data requested
hgs
parents:
diff changeset
    71
		*/
hgs
parents:
diff changeset
    72
		 virtual void NotifyOnTimeChange( TInterfaceAttribute aInterfaceAttribute ) = 0;
hgs
parents:
diff changeset
    73
		
hgs
parents:
diff changeset
    74
		/**
hgs
parents:
diff changeset
    75
		* @brief Returns the plugin implementation id. Unique for each plugin.
hgs
parents:
diff changeset
    76
		* @return TInt The Uid of the plugin.
hgs
parents:
diff changeset
    77
		*/
hgs
parents:
diff changeset
    78
		 virtual TInt GetPluginUid() = 0;
hgs
parents:
diff changeset
    79
		
hgs
parents:
diff changeset
    80
		/**
hgs
parents:
diff changeset
    81
		 * @brief Gets the time attributes if it is already available with source.
hgs
parents:
diff changeset
    82
		 */
hgs
parents:
diff changeset
    83
		virtual void GetDataIfAlreadyAvailableL() = 0;
hgs
parents:
diff changeset
    84
						
hgs
parents:
diff changeset
    85
	private:		// New functions
hgs
parents:
diff changeset
    86
	
hgs
parents:
diff changeset
    87
		/**
hgs
parents:
diff changeset
    88
		* @brief Symbiam OS 2nd Phase construct, performs the 2nd phase construction.
hgs
parents:
diff changeset
    89
		* @param aPluginId The UID of the plugin that needs to be constructed
hgs
parents:
diff changeset
    90
		* @param aObserver An observer of type MClockPluginObserver
hgs
parents:
diff changeset
    91
		*/
hgs
parents:
diff changeset
    92
		void ConstructL( MClockPluginObserver* aObserver );
hgs
parents:
diff changeset
    93
		
hgs
parents:
diff changeset
    94
	protected:		// Data
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
		/**
hgs
parents:
diff changeset
    97
		* @var iObserver
hgs
parents:
diff changeset
    98
		* @brief This is essentially the ClockServer which is waiting for notification from the implementations.
hgs
parents:
diff changeset
    99
		*/
hgs
parents:
diff changeset
   100
		MClockPluginObserver*           iObserver;
hgs
parents:
diff changeset
   101
		
hgs
parents:
diff changeset
   102
		/**
hgs
parents:
diff changeset
   103
		* @var iPluginId
hgs
parents:
diff changeset
   104
		* @brief The plugin UID.
hgs
parents:
diff changeset
   105
		*/
hgs
parents:
diff changeset
   106
		TUid                            iPluginId;
hgs
parents:
diff changeset
   107
		
hgs
parents:
diff changeset
   108
	private:       // Data
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
        /**
hgs
parents:
diff changeset
   111
        * @var iDtor_ID_key
hgs
parents:
diff changeset
   112
        * @brief Implementation UID of the Time updater implementation.
hgs
parents:
diff changeset
   113
        */
hgs
parents:
diff changeset
   114
        TUid                            iDtor_ID_key;
hgs
parents:
diff changeset
   115
	};
hgs
parents:
diff changeset
   116
hgs
parents:
diff changeset
   117
#endif		// __CLOCK_TIMESOURCE_INTERFACE_H__
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
// End of file