tzservices/tzserver/Include/vtzrules.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 13 Oct 2010 14:43:04 +0300
branchRCL_3
changeset 82 4610cd70c542
parent 0 2e3d3ce01487
permissions -rw-r--r--
Revision: 201039 Kit: 201041

// Copyright (c) 2005-2009 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:
//

#ifndef __VTZRULES_H__
#define __VTZRULES_H__

#include <e32base.h>
#include <s32strm.h>
#include <tzdefines.h>
#include <tz.h>

class CVTzActualisedRules;
class TVTzActualisedRule; 

const TInt KVTzRulesGranularity = 4;

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 *	Time zone rules
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */

/**
Encapsulates one time zone rule.

@publishedAll
@released
*/
class TTzRule
	{
public:
	IMPORT_C TTzRule(TInt16 aFromYear, TInt16 aToYear, TInt16 aOldOffset, TInt16 aNewOffset, TMonth aMonth, TTzRuleDay aDayRule, 
				TUint8 aDayOfMonth, TUint8 aDayOfWeek, TTzTimeReference aTimeReference, TUint16 aTimeOfChange);
	IMPORT_C TTzRule();
	IMPORT_C TTzRule(const TTzRule& aRule);
	IMPORT_C TTzRule(TTimeWithReference aFromYear, TTimeWithReference aToYear, TInt16 aOldOffset, TInt16 aNewOffset, TMonth aMonth, TTzRuleDay aDayRule, 
				TUint8 aDayOfMonth, TUint8 aDayOfWeek, TTzTimeReference aTimeReference, TUint16 aTimeOfChange);

	
	void ExternalizeL(RWriteStream& aStream) const;
	void InternalizeL(RReadStream& aStream);		
	TBool RuleApplies(const TTime& aStart, const TTime& aEnd) const;		
		
	IMPORT_C TVTzActualisedRule Actualise(TInt aYear) const;    // deprecated, replace by the L version
	IMPORT_C TVTzActualisedRule ActualiseL(TInt aYear) const;   
	
public:
	TTimeWithReference iFrom;		// first date the rule applies
	TTimeWithReference iTo;			// last date the rule applies
	TInt16		iOldLocalTimeOffset; // local time offset (in minutes) BEFORE the change (local time = UTC + DST)
	TInt16		iNewLocalTimeOffset; // local time offset (in minutes) AFTER the change
	TMonth		iMonth;
	TTzRuleDay	iDayRule;		// format in which the rule is expressed
	TUint8		iDayOfMonth;
	TUint8		iDayOfWeek;
	TTzTimeReference iTimeReference;
	TUint16		iTimeOfChange;	// number of minutes since midnight
	TUint32		iReserved;
	};
	


/**
Encapsulates a collection of time zone rules, and includes the period covered by the rules
and the standard time offset at the start of that period.

@publishedAll
@released
*/
class CTzRules : public CBase
	{
public:
	IMPORT_C static CTzRules* NewL();
	IMPORT_C static CTzRules* NewL(TInt aStartYear, TInt aEndYear);
	IMPORT_C static CTzRules* NewL(RReadStream& aStream);
	IMPORT_C ~CTzRules();
	IMPORT_C TBool RulesApply(const TTime& aTime) const;
	IMPORT_C void AddRuleL(TTzRule aRule);
	IMPORT_C void RemoveRule(TInt aIndex);
	IMPORT_C TTzRule& operator[](TInt aIndex);
	IMPORT_C TInt Count() const;
	IMPORT_C TInt StartYear() const;
	IMPORT_C TInt EndYear() const;
	IMPORT_C void SetStartYear(TInt aYear);
	IMPORT_C void SetEndYear(TInt aYear);
	IMPORT_C void ExternalizeL(RWriteStream& aStream) const;
	IMPORT_C void InternalizeL(RReadStream& aStream);
	IMPORT_C TInt InitialStdTimeOffset() const;
	IMPORT_C void SetInitialStdTimeOffset(TInt aOffset);
	IMPORT_C void ConvertToUtcL(TTime& aLocalTime) const;
	IMPORT_C void ConvertToLocalL(TTime& aUtcTime) const;
	IMPORT_C CTzRules* CloneL() const;
	IMPORT_C TBool IsEqualTo(const CTzRules& aRules) const;
	
	IMPORT_C void GetActualisedRulesL(CVTzActualisedRules& aActRules) const;
	IMPORT_C TInt ConvertTime(CVTzActualisedRules& aRules, TTime& aTime, TTzTimeReference aTimerRef) const;
	
	IMPORT_C TInt GetOffsetL(const TTime& aTime, TTzTimeReference aTimeRef) const;
	IMPORT_C TInt SizeOfObject() const;
	IMPORT_C void CopyL(const CTzRules& aTzRule);
		
private:
	CTzRules();
	CTzRules(TInt aStartYear, TInt aEndYear);
	void AddActualisedRulesL(CVTzActualisedRules& aActRules, TInt aYear) const;
	TInt CompareTimesWithRef(TTime aTimeA, TTzTimeReference aTimeARef,
						     TTime aTimeB, TTzTimeReference aTimeBRef, TInt aStdOffset, TInt aWallOffset,
						     TTimeIntervalMinutes* aMinutesDifference) const;

private:
	TInt16 iStartYear;
	TInt16 iEndYear;
	RArray<TTzRule> iRules;
	TInt iInitialStdTimeOffset;
	
	mutable CVTzActualisedRules* iActualisedRulesCache;
	};



/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 *	Actualised time zone rules
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */

/**
Encapsulates a local time change.

@publishedAll
@released
*/
class TVTzActualisedRule
	{
public:	
	IMPORT_C TVTzActualisedRule(TTime aTimeOfChange, TInt aNewOffset, TTzTimeReference aTimeReference);
	IMPORT_C TVTzActualisedRule();
		
	IMPORT_C void operator=(TVTzActualisedRule aRule);
	static TInt Order(const TVTzActualisedRule& aLeft, const TVTzActualisedRule& aRight);	
	
public:
	TTime iTimeOfChange;
	TInt32  iNewOffset;
	TTzTimeReference iTimeReference;
	};
	
	
/**
Encapsulates a collection of the local time changes occurring during a range of years.

@publishedAll
@released
*/
NONSHARABLE_CLASS(CVTzActualisedRules) : public CBase
	{
public:
	IMPORT_C static CVTzActualisedRules* NewL(TInt aStartYear, TInt aEndYear);
	IMPORT_C ~CVTzActualisedRules();
	IMPORT_C void AddRuleL(const TVTzActualisedRule& aRule);
	IMPORT_C TInt Count() const;
	IMPORT_C TVTzActualisedRule& operator[](TInt aIndex) const;

	IMPORT_C TInt StartYear() const;
	IMPORT_C TInt EndYear() const;
	
	IMPORT_C TBool IsDaylightSavingOn(TTime& aTime) const;
	IMPORT_C TInt GetOffsetFromRuleL(const TTime& aTime, TTzTimeReference aTimeRef) const;
	
private:
	CVTzActualisedRules(TInt aStartYear, TInt aEndYear);
	CVTzActualisedRules();
	TInt CompareTimesWithRef(TTime aRolloverTime, TTzTimeReference aTimeRefRollover, 
							 TTime aUserTime, TTzTimeReference aTimeRefUser,
							 TInt aOldWallOffset, TTimeIntervalMinutes& aDiffMinutes) const;
	
private:
	TInt32 iStartYear;		// years covered by 
	TInt32 iEndYear;		// the actualised rules
	RArray<TVTzActualisedRule> iRules;	
	};

#endif