epoc32/include/tz.h
author William Roberts <williamr@symbian.org>
Tue, 16 Mar 2010 16:12:26 +0000
branchSymbian2
changeset 2 2fe1408b6811
parent 0 061f57f2323e
permissions -rw-r--r--
Final list of Symbian^2 public API header files

// Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the License "Symbian Foundation License v1.0" to Symbian Foundation members and "Symbian Foundation End User License Agreement v1.0" to non-members
// which accompanies this distribution, and is available
// at the URL "http://www.symbianfoundation.org/legal/licencesv10.html".
//
// Initial Contributors:
// Nokia Corporation - initial contribution.
//
// Contributors:
//
// Description:
//

#ifndef __TIMEZONE_H__
#define __TIMEZONE_H__

#include <e32base.h>
#include <s32std.h>
#include <tzdefines.h>
#include <tzupdate.h>

class CTzChangeNotifier;
class CTzRules;
class CTzRuleHolder;

//-------------------------------------------------------------------------
/**
Encapsulates a time zone identifier.

The identifier may be either a name or a number.
@publishedAll
@released
@since 9.1
*/
class CTzId : public CBase
	{
public:

	IMPORT_C ~CTzId();
	
	/** 
	@internalComponent 
	*/
	IMPORT_C CTzId* CloneL() const;
	
	IMPORT_C static CTzId* NewL(TUint aNumericId);
	
	IMPORT_C static CTzId* NewL(const TDesC8& aNameIdentity);
	
	/** 
	@internalComponent 
	*/
	IMPORT_C static CTzId* NewL(RReadStream& aStream);
	
	/** 
	@internalComponent 
	*/
	IMPORT_C void SetId(TUint aNumericId);
	
	/** 
	@internalComponent 
	*/
	IMPORT_C void SetIdL(const TDesC8& aNameIdentity);
	
	/** 
	@internalComponent 
	*/
	IMPORT_C void InternalizeL(RReadStream& aStream);
	
	/** 
	@internalComponent 
	*/
	IMPORT_C void ExternalizeL(RWriteStream& aStream) const;

	IMPORT_C const TDesC8& TimeZoneNameID() const;
	
	IMPORT_C TUint TimeZoneNumericID() const;
	
	IMPORT_C TBool operator==(const CTzId& aTZId) const;

	inline TBool operator!=(const CTzId& aTZId) const;

public:
	static CTzId* NewL(TUint aReferenceId, const TDesC8& aZoneIdentity);
	void SetIdL(TUint aNumRefId, const TDesC8& aZoneIdentity);

private:
	void ConstructL(const TDesC8& aZoneIdentity);
	CTzId();
	CTzId(TUint aNumericId);

private:
	HBufC8* iZoneId;
	TUint32 iReferenceId;
	};


/** 
The client interface to the time zone server. 

This class performs two basic functions:
1. Converts between UTC time and local time.
2. Sets the current local time zone.

NOTE: The presence of a time zone server will alter the behaviour of the 
time zone related function calls User::SetUTCOffset() and 
User::SetUTCTimeAndOffset(). The time zone server is shutdown when the 
last session (RTz) is closed. Therefore, to maintain consistent time related behaviour, 
licensees may want to keep a system level time zone server session open at all times.

@see User

Exceptional cases occur when a user requests conversion 
for a non-existent local time or a double local time. 

Non-existent local times occur when the local time 
changes from winter to summer for DST.

For example, 01:59 local time is non-existent on the day of a change to BST
in Europe/London since the time changes directly from 12:59:59 to 2:00.

A double local time occurs when the local time changes from
summer to winter. 

For example, if the time changes at 02:00 AM BST to 01:00 AM GMT
then local times between 01:00 and 01:59 occur twice.

The conversion applies the DST offset if the local time value is double and applies
the standard UTC offset if the local time does not exists.

This decision makes the conversion process asymmetrical around
the discontinuity in the local time when there is a DST change.

An example conversion from a double local time to UTC and 
from UTC to a double local time is:

	01:59 AM BST => 00:59 AM UTC
	01:59 AM UTC => 01:59 AM GMT
	
An example conversion from a non-existent local time to UTC 
and from UTC to local time is:

    01:59 AM GMT => 01:59 AM UTC
    01:59 AM UTC => 02:59 AM BST 	
	

@publishedAll
@released
@since 9.1
*/
class RTz : public RSessionBase
	{
public:
	/**
	These enumerators are to describe different modes of the automatic 
	DST event handling.

	These are used both as arguments for the API SetAutoUpdateBehaviorL, 
	and as notifications for the publish and subscribe.
	*/
	enum TTzAutoDSTUpdateModes
		{
		/** No auto update notification when a DST event occurs. */
		ETZAutoDSTUpdateOff = 0,

		/** Automatic time update will occur and the client app will be notified. */
		ETZAutoDSTUpdateOn,

		/** Client app needs to confirm that the time should be updated whenever a DST event occurs. */
		ETZAutoDSTNotificationOnly,
		};

	enum TTzChanges
		{
		/** Used for notifying that the timezone database has changed.*/
		ETZDatabaseChanged = 1,
		/** Used for notifying that the system timezone database has changed.*/
		ETZSystemTimeZoneChanged,
		/** Used for notifying that the DST rule has changed. */
		ETZDSTRuleChanged,
		/** Used for notifying that an automatic time update has taken place. */
		ETZAutomaticTimeUpdate
		};

	enum TPanic
		{
		/** This panic indicates that the time zone server has not been found.*/
		EPanicServerNotFound = 1,
		/** This panic indicates that the server has died.*/
		EPanicServerDead,
		/** This panic indicates that the time zone ID is not set.*/
		EPanicTimeZoneNameIdNotSet,
		/** This panic indicates that an out of range index was accessed.*/
		EPanicRulesIndexOutofRange,
		/** This panic indicates that there are no rules present for this time zone.*/
		EPanicTimeNotCoveredByRules,
		/** This panic indicates that the time zone rules are unusable.*/
		EPanicBadTimeZoneRules,
		/** This panic indicates  that an unsupported time reference has been accessed.*/
		EPanicUnsupportedTimeReference,
		/** This panic indicates that the time zone ID is not supported.*/
		EPanicUnsupportedTimeZoneNoId,
		/** This panic indicates that a request for notification is already pending from the client.*/
		EPanicNotificationRequestPending,
		/** This panic indicates that an incorrect data has been sent to the server.*/
		EPanicInvalidArgument
		};
	
	/** 
	@internalComponent 
	*/
	IMPORT_C static void Panic(TPanic aPanic);
	
	/** 
	@internalTechnology
	*/
	IMPORT_C CTzId* GetTimeZoneIdL() const;
	
	/** 
	@internalTechnology
	*/
	IMPORT_C void SetTimeZoneL(CTzId& aZone) const;

	IMPORT_C void Close();
	
	IMPORT_C TInt Connect();

	IMPORT_C ~RTz();
	
	IMPORT_C RTz();
	
	IMPORT_C TInt ConvertToLocalTime(TTime& aTime) const;
	
	IMPORT_C TInt ConvertToLocalTime(TTime& aTime, const CTzId& aZone) const;

	IMPORT_C TInt ConvertToUniversalTime(TTime& aTime) const;
	
	IMPORT_C TInt ConvertToUniversalTime(TTime& aTime, const CTzId& aZone) const;
	
	IMPORT_C void GetOffsetsForTimeZoneIdsL(const RArray<TInt>& aTzNumericIds, RArray<TInt>& aOffsets) const; 
	
	IMPORT_C TInt AutoUpdateSettingL();
	
    IMPORT_C void SetAutoUpdateBehaviorL(TTzAutoDSTUpdateModes aUpdateEnabled);
    
    // Methods for setting the system time.
    IMPORT_C TInt SetHomeTime(const TTime& aLocalTime) const;

    IMPORT_C TBool IsDaylightSavingOnL(CTzId& aZone) const;
    
    IMPORT_C TBool IsDaylightSavingOnL(CTzId& aZone, const TTime& aUTCTime) const;

 	// Get Encoded Rules for Current Local Time Zone
	IMPORT_C CTzRules* GetTimeZoneRulesL(const TTime& aStartTime, const TTime& aEndTime, TTzTimeReference aTimeRef) const;
	
	IMPORT_C CTzRules* GetTimeZoneRulesL(const CTzId& aZone, const TTime& aStartTime, const TTime& aEndTime, TTzTimeReference aTimeRef) const;
	
	void RegisterTzChangeNotifier(TRequestStatus& aStatus) const;
	TInt CancelRequestForNotice() const;
	TVersion Version() const;
	
	IMPORT_C void NotifyHomeTimeZoneChangedL(const NTzUpdate::TTimeZoneChange& aChange) const;
	
	IMPORT_C void SetUnknownZoneTimeL(const TTime& aUTCTime, const TInt aUTCOffset);
	
	IMPORT_C void SetUnknownZoneTimeL(const TTime& aUTCTime, const TInt aUTCOffset, TBool aPersistInCenRep);

	IMPORT_C void __dbgClearCacheL(TBool aRestartCaching);

    TBool StartCachingL();
    TUint16 CurrentCachedTzId();

private:
	static TInt StartServer();
	TInt DoConnect();
	void doConvertL(const CTzId& aZone, TTime& aTime,
					TTzTimeReference aTimerRef) const;
	void doConvertL(TTime& aTime, 
					TTzTimeReference aTimerRef) const;
private:
	CTzRuleHolder* iRulesHolder;
	};

/**
Encapsulates a TTime and a TTzTimeReference.
Use, for example, for iCalendar's DTSTART.

@publishedAll
@released
*/
class TTimeWithReference
	{
public:
	static inline TTimeWithReference Max();
	inline TTimeWithReference();
	inline TTimeWithReference(TTime aTime, TTzTimeReference aTimeReference=ETzUtcTimeReference);
	inline TTimeWithReference(TDateTime aTime, TTzTimeReference aTimeReference=ETzUtcTimeReference);
	inline bool operator==(const TTimeWithReference& aTime) const;
	inline bool operator!=(const TTimeWithReference& aTime) const;

	TTime iTime;
	TTzTimeReference iTimeReference;
	};

/** Inequality operator.

@param aTZId The time zone ID to compare with this one.
@return True if the two IDs are different. False if they are the same.
*/
inline TBool CTzId::operator!=(const CTzId& aTZId) const
	{
	return (!operator==(aTZId));
	}

//////////////////////////////////
// TTimeWithReference
//////////////////////////////////
inline TTimeWithReference TTimeWithReference::Max()
	{
	return TTimeWithReference(
		TDateTime(9999,EDecember,30,23,59,59,0), 
		ETzUtcTimeReference);
	}

inline TTimeWithReference::TTimeWithReference() 
		: iTime(0), iTimeReference(ETzUtcTimeReference)
	{
	}
inline TTimeWithReference::TTimeWithReference(TTime aTime, TTzTimeReference aTimeReference)
		: iTime(aTime), iTimeReference(aTimeReference)
	{
	}
inline TTimeWithReference::TTimeWithReference(TDateTime aTime, TTzTimeReference aTimeReference)
		: iTime(aTime), iTimeReference(aTimeReference)
	{
	}
inline bool TTimeWithReference::operator==(const TTimeWithReference& aTime) const
	{
	return(aTime.iTime == iTime && aTime.iTimeReference == iTimeReference);
	}
inline bool TTimeWithReference::operator!=(const TTimeWithReference& aTime) const
	{
	return(!(*this == aTime));
	}
#endif