epoc32/include/mw/asshdalarm.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:27:01 +0100
branchSymbian2
changeset 3 e1b950c65cb4
parent 2 epoc32/include/asshdalarm.h@2fe1408b6811
child 4 837f303aceeb
permissions -rw-r--r--
Attempt to represent the S^2->S^3 header reorganisation as a series of "hg rename" operations
williamr@2
     1
// Copyright (c) 1999-2009 Nokia Corporation and/or its subsidiary(-ies).
williamr@2
     2
// All rights reserved.
williamr@2
     3
// This component and the accompanying materials are made available
williamr@2
     4
// 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
williamr@2
     5
// which accompanies this distribution, and is available
williamr@2
     6
// at the URL "http://www.symbianfoundation.org/legal/licencesv10.html".
williamr@2
     7
//
williamr@2
     8
// Initial Contributors:
williamr@2
     9
// Nokia Corporation - initial contribution.
williamr@2
    10
//
williamr@2
    11
// Contributors:
williamr@2
    12
//
williamr@2
    13
// Description:
williamr@2
    14
//
williamr@2
    15
williamr@2
    16
#ifndef __ASSHDALARM_H__
williamr@2
    17
#define __ASSHDALARM_H__
williamr@2
    18
williamr@2
    19
williamr@2
    20
// System includes
williamr@2
    21
#include <e32base.h>
williamr@2
    22
#include <s32strm.h>
williamr@2
    23
williamr@2
    24
// User includes
williamr@2
    25
#include <asshddefs.h>
williamr@2
    26
williamr@2
    27
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
    28
// ----> TASShdAlarm (header)
williamr@2
    29
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
    30
williamr@2
    31
/** The Alarm publish and subscribe category
williamr@2
    32
@publishedPartner
williamr@2
    33
@released
williamr@2
    34
*/
williamr@2
    35
const TUid KAlarmServerPubSubCategory = { 0x101f5027 };
williamr@2
    36
williamr@2
    37
/** Used for subcribing missed alarms or time zone changes
williamr@2
    38
@publishedPartner
williamr@2
    39
@released
williamr@2
    40
*/
williamr@2
    41
const TUint KMissingAlarmPubSubKey = 100;
williamr@2
    42
williamr@2
    43
/** The publish and subscribe data for KMissingAlarmPubSubKey
williamr@2
    44
@publishedPartner
williamr@2
    45
@released
williamr@2
    46
*/
williamr@2
    47
struct TMissedAlarmPubSubData
williamr@2
    48
	{
williamr@2
    49
	/** The value indicating the changes. 
williamr@2
    50
	1 - Time zone has been changes but there are no missed alarms
williamr@2
    51
	2 - Some alarms have been missed after system time or time zone has changed.
williamr@2
    52
	*/
williamr@2
    53
	TUint8 iValue;
williamr@2
    54
	
williamr@2
    55
	/** The time that system time change took place, in universal (UTC) time */
williamr@2
    56
	TTime iTimeOfChangeUtc;
williamr@2
    57
	};
williamr@2
    58
williamr@2
    59
/** Used for subscribing to data used when searching for instances in Calendar
williamr@2
    60
@publishedPartner
williamr@2
    61
@released
williamr@2
    62
*/
williamr@2
    63
const TUint KSkippedAlarmInstancesPubSubKey = 101;
williamr@2
    64
williamr@2
    65
/** The publish and subscribe data for KMissingAlarmInstancesPubSubKey
williamr@2
    66
@publishedPartner
williamr@2
    67
@released
williamr@2
    68
*/
williamr@2
    69
struct TASShdAlarmedInstanceParams
williamr@2
    70
	{
williamr@2
    71
	/** The start of the time range in local time. */ 
williamr@2
    72
	TTime iLocalStartTime;
williamr@2
    73
williamr@2
    74
	/** The end of the time range in local time. */
williamr@2
    75
	TTime iLocalEndTime;
williamr@2
    76
	
williamr@2
    77
	/** The alarm time types to include. */
williamr@2
    78
	TASShdAlarmTimeType iTimeType;
williamr@2
    79
	};
williamr@2
    80
williamr@2
    81
williamr@2
    82
class TASShdAlarm
williamr@2
    83
/** A client-side alarm object. 
williamr@2
    84
williamr@2
    85
It contains all of the information needed to create an alarm in 
williamr@2
    86
the Alarm Server. 
williamr@2
    87
@publishedAll
williamr@2
    88
@released
williamr@2
    89
*/
williamr@2
    90
	{
williamr@2
    91
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
    92
public:										// CONSTRUCT
williamr@2
    93
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
    94
williamr@2
    95
	IMPORT_C TASShdAlarm();
williamr@2
    96
williamr@2
    97
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
    98
public:										// INTERNALIZE / EXTERNALIZE
williamr@2
    99
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   100
williamr@2
   101
	IMPORT_C void InternalizeL(RReadStream& aStream);
williamr@2
   102
williamr@2
   103
	IMPORT_C void ExternalizeL(RWriteStream& aStream) const;
williamr@2
   104
williamr@2
   105
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   106
public:										// READ-ONLY ACCESS
williamr@2
   107
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   108
williamr@2
   109
	inline TAlarmStatus	Status() const				
williamr@2
   110
	/** Returns the alarm status. 
williamr@2
   111
	
williamr@2
   112
	@return Alarm status. */
williamr@2
   113
		{ return iStatus; }
williamr@2
   114
williamr@2
   115
	inline TAlarmState State() const
williamr@2
   116
	/** Returns the alarm state. 
williamr@2
   117
	
williamr@2
   118
	@return Alarm state. */
williamr@2
   119
		{ return iState; }
williamr@2
   120
williamr@2
   121
	inline TBool HasAssociatedData() const;
williamr@2
   122
williamr@2
   123
	inline TBool HasOwningSession() const;
williamr@2
   124
williamr@2
   125
	inline TBool HasBecomeOrphaned() const;
williamr@2
   126
	
williamr@2
   127
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   128
public:										// READ-ONLY & MODIFIABLE
williamr@2
   129
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   130
williamr@2
   131
	IMPORT_C void Reset();
williamr@2
   132
williamr@2
   133
	inline TAlarmId& Id()
williamr@2
   134
	/** Returns a writable version of the alarm's unique identifier. 
williamr@2
   135
	
williamr@2
   136
	@return Reference to the unique identifier. */
williamr@2
   137
		{ return iAlarmId; }
williamr@2
   138
williamr@2
   139
	inline TAlarmId	Id() const
williamr@2
   140
	/** Return the alarm's unique identifier. 
williamr@2
   141
	
williamr@2
   142
	@return The unique identifier. */
williamr@2
   143
		{ return iAlarmId; }
williamr@2
   144
		
williamr@2
   145
//The Secure ID is only used in the secured platform
williamr@2
   146
		
williamr@2
   147
	// adds a SID to the alarms private field
williamr@2
   148
	inline void SetSid(const TSecureId& aSecureID) 
williamr@2
   149
		{iTASShdAlarmSID = aSecureID;}
williamr@2
   150
williamr@2
   151
	//	returns the SID of the alarm's creator
williamr@2
   152
	inline TSecureId GetSid() const 
williamr@2
   153
		{return iTASShdAlarmSID;}
williamr@2
   154
williamr@2
   155
	inline TTime& NextDueTime()
williamr@2
   156
	/** Returns a writable version of the next time the alarm is scheduled to expire. 
williamr@2
   157
	
williamr@2
   158
	@return Next expiry time. */
williamr@2
   159
		{ return iNextDueTime; }
williamr@2
   160
williamr@2
   161
	inline const TTime&	NextDueTime() const
williamr@2
   162
	/** Returns the next time that the alarm is scheduled to expire. 
williamr@2
   163
	
williamr@2
   164
	@return Next expiry time. */
williamr@2
   165
		{ return iNextDueTime; }
williamr@2
   166
williamr@2
   167
	inline TTime& OriginalExpiryTime()
williamr@2
   168
	/** Returns a writable version of the alarm's original expiry time. 
williamr@2
   169
	
williamr@2
   170
	@return Original expiry time. */
williamr@2
   171
		{ return iOriginalExpiryTime; }
williamr@2
   172
williamr@2
   173
	inline const TTime& OriginalExpiryTime() const
williamr@2
   174
	/** Returns the alarm's original expiry time. 
williamr@2
   175
	
williamr@2
   176
	The original expiry time is the same as the next due time, unless the alarm 
williamr@2
   177
	has been snoozed. In that case, the original expiry time is the time when 
williamr@2
   178
	the alarm first expired, and the next due time is when it is to re-awaken 
williamr@2
   179
	after the snooze. 
williamr@2
   180
	
williamr@2
   181
	@return Original expiry time. */
williamr@2
   182
		{ return iOriginalExpiryTime; }
williamr@2
   183
williamr@2
   184
	inline TAlarmCategory& Category()
williamr@2
   185
	/** Returns a writable version of the alarm's category. 
williamr@2
   186
	
williamr@2
   187
	Clients can use the category to tag each alarm with a specific code. This 
williamr@2
   188
	allows clients to identify all related alarms, such as all alarms associated 
williamr@2
   189
	with a particular application or application engine. 
williamr@2
   190
	
williamr@2
   191
	@return Alarm category. */
williamr@2
   192
		{ return iCategory; }
williamr@2
   193
williamr@2
   194
	inline TAlarmCategory Category() const 
williamr@2
   195
	/** Return this alarm's category. 
williamr@2
   196
	
williamr@2
   197
	@return Alarm category. */
williamr@2
   198
		{ return iCategory; }
williamr@2
   199
williamr@2
   200
	inline TAlarmCharacteristicsFlags& Characteristics() 
williamr@2
   201
	/** Returns a writable version of the alarm's characteristics. 
williamr@2
   202
	
williamr@2
   203
	@return Alarm characteristics bit flags. */
williamr@2
   204
		{ return iCharacteristics; }
williamr@2
   205
williamr@2
   206
	inline TAlarmCharacteristicsFlags Characteristics() const 
williamr@2
   207
	/** Returns the alarm's characteristics 
williamr@2
   208
	
williamr@2
   209
	@return Alarm characteristics bit flags. */
williamr@2
   210
		{ return iCharacteristics; }
williamr@2
   211
williamr@2
   212
	inline TAlarmRepeatDefinition& RepeatDefinition() 
williamr@2
   213
	/** Returns a writable version of the alarm's repeat definition. 
williamr@2
   214
	
williamr@2
   215
	The repeat definition controls the alarm's behaviour after it has expired. 
williamr@2
   216
	For example, you can set the repeat definition so that the server automatically 
williamr@2
   217
	queues the alarm to expire again in exactly 24 hours time.
williamr@2
   218
	
williamr@2
   219
	@return Alarm repeat definition. */
williamr@2
   220
		{ return iRepeatDefinition; }
williamr@2
   221
williamr@2
   222
	inline TAlarmRepeatDefinition RepeatDefinition() const 
williamr@2
   223
	/** Returns the repeat definition for the alarm. 
williamr@2
   224
	
williamr@2
   225
	@return The alarm's repeat definition. */
williamr@2
   226
		{ return iRepeatDefinition; }
williamr@2
   227
williamr@2
   228
	inline TAlarmMessage& Message()	
williamr@2
   229
	/** Returns a writable version of the alarm's message. 
williamr@2
   230
	
williamr@2
   231
	The message is usually displayed in the application UI 
williamr@2
   232
	when the alarm expires.
williamr@2
   233
	
williamr@2
   234
	@return Reference to the alarm's associated message. */
williamr@2
   235
		{ return iMessage; }
williamr@2
   236
williamr@2
   237
	inline const TAlarmMessage& Message() const 
williamr@2
   238
	/** Returns the alarm's message. 
williamr@2
   239
	
williamr@2
   240
	The message is usually displayed in the application UI when the alarm expires. 
williamr@2
   241
	
williamr@2
   242
	@return Reference to the alarm's associated message. */
williamr@2
   243
		{ return iMessage; }
williamr@2
   244
williamr@2
   245
	inline TAlarmSoundName& SoundName() 
williamr@2
   246
	/** Return a writable version of the alarm sound's filename. 
williamr@2
   247
	
williamr@2
   248
	@return Reference to the alarm's sound filename. */
williamr@2
   249
		{ return iSoundName; }
williamr@2
   250
williamr@2
   251
	inline const TAlarmSoundName& SoundName() const	
williamr@2
   252
	/** Returns the alarm's sound filename. 
williamr@2
   253
	
williamr@2
   254
	@return Sound filename. */
williamr@2
   255
		{ return iSoundName; }
williamr@2
   256
		
williamr@2
   257
	inline TAlarmDayOrTimed DayOrTimed() const
williamr@2
   258
	/** Returns the alarm session type. 
williamr@2
   259
	
williamr@2
   260
	@return Alarm session type. */
williamr@2
   261
		{ return iDayOrTimed; }
williamr@2
   262
williamr@2
   263
		
williamr@2
   264
	inline TAlarmDayOrTimed&	DayOrTimed()	
williamr@2
   265
	/** Returns a writable version of the alarm type, i.e. day, timed
williamr@2
   266
	
williamr@2
   267
	@return iDayOrTimed. */	
williamr@2
   268
	{ return iDayOrTimed; }
williamr@2
   269
williamr@2
   270
   
williamr@2
   271
	IMPORT_C void SetUtcNextDueTime(TTime aUtcTime);
williamr@2
   272
	
williamr@2
   273
	IMPORT_C void SetDeQueueIfDueTimeInPast();
williamr@2
   274
	
williamr@2
   275
	IMPORT_C TInt SetAlarmDays(TUint8 aAlarmDays);
williamr@2
   276
	IMPORT_C TUint8 AlarmDays() const;
williamr@2
   277
	IMPORT_C void SetContinuous(TBool aContinuous);
williamr@2
   278
	IMPORT_C TBool Continuous();
williamr@2
   279
	
williamr@2
   280
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   281
public:										// CLIENT DATA ACCESS
williamr@2
   282
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   283
williamr@2
   284
	inline TBitFlags16& ClientFlags()
williamr@2
   285
	/** Returns a writable version of the alarm's client flags. 
williamr@2
   286
	
williamr@2
   287
	The client flags may be used for any client-specific data - 
williamr@2
   288
	the alarm server does not use them.
williamr@2
   289
williamr@2
   290
	@return Reference to the alarm's bit flags. */
williamr@2
   291
		{ return iClientFlags; }
williamr@2
   292
williamr@2
   293
	inline TBitFlags16 ClientFlags() const 
williamr@2
   294
	/** Returns this alarm's client flags. 
williamr@2
   295
	
williamr@2
   296
	@return Reference to the alarm's bit flags. */
williamr@2
   297
		{ return iClientFlags; }
williamr@2
   298
williamr@2
   299
	inline TInt	ClientData1() const 
williamr@2
   300
	/** Returns the client data from slot 1 for this alarm. 
williamr@2
   301
	
williamr@2
   302
	@return The first client-specific integer. */
williamr@2
   303
		{ return iClientData1; }
williamr@2
   304
williamr@2
   305
	inline TInt& ClientData1() 
williamr@2
   306
	/** Returns a writable version of the client data from slot 1 for this alarm. 
williamr@2
   307
	
williamr@2
   308
	@return Reference to the first client-specific integer. */
williamr@2
   309
		{ return iClientData1; }
williamr@2
   310
williamr@2
   311
	inline TInt ClientData2() const
williamr@2
   312
	/** Returns the client data from slot 2 for this alarm. 
williamr@2
   313
	
williamr@2
   314
	@return The second client-specific integer. */
williamr@2
   315
		{ return iClientData2; }
williamr@2
   316
williamr@2
   317
	inline TInt& ClientData2() 
williamr@2
   318
	/** Returns the client data from slot 2 for this alarm. 
williamr@2
   319
	
williamr@2
   320
	@return The second client-specific integer. */
williamr@2
   321
		{ return iClientData2; }
williamr@2
   322
		
williamr@2
   323
	inline TBool IsFloating() const
williamr@2
   324
	/** Tests whether the alarm is floating. 
williamr@2
   325
williamr@2
   326
	Floating alarms expire at a given wall-clock time regardless of the current locale and
williamr@2
   327
	whether any daylight saving time rules are in force.
williamr@2
   328
		
williamr@2
   329
	@return True if the alarm is floating.
williamr@2
   330
	*/
williamr@2
   331
	{ return iCharacteristics.IsClear(EAlarmCharacteristicsIsFixed); }
williamr@2
   332
	
williamr@2
   333
williamr@2
   334
williamr@2
   335
williamr@2
   336
williamr@2
   337
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   338
protected:									// INTERNAL FLAGS
williamr@2
   339
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   340
williamr@2
   341
	/*
williamr@2
   342
	 * @internalAll
williamr@2
   343
	 */
williamr@2
   344
	enum TASShdAlarmFlags
williamr@2
   345
		{
williamr@2
   346
williamr@2
   347
		/*
williamr@2
   348
		 * @internalAll
williamr@2
   349
		 */
williamr@2
   350
		EASShdAlarmFlagsHasAssociatedData	= 0,
williamr@2
   351
williamr@2
   352
		/*
williamr@2
   353
		 * @internalAll
williamr@2
   354
		 */
williamr@2
   355
		EASShdAlarmFlagsHasOwningSession	= 1,
williamr@2
   356
williamr@2
   357
		/*
williamr@2
   358
		 * @internalAll
williamr@2
   359
		 */
williamr@2
   360
		EASShdAlarmFlagsHasBecomeOrphaned	= 2,
williamr@2
   361
		
williamr@2
   362
		/*
williamr@2
   363
		 * @internalAll Set if alarm is disabled manually so that can not be enabled when
williamr@2
   364
		 * locale changes.
williamr@2
   365
		 */
williamr@2
   366
		EASShdAlarmFlagsPermanentDisabled	= 4
williamr@2
   367
williamr@2
   368
		};
williamr@2
   369
williamr@2
   370
private:
williamr@2
   371
	/*
williamr@2
   372
	 * @internalComponent
williamr@2
   373
	 */
williamr@2
   374
	enum TASShdAlarmFlags2
williamr@2
   375
		{
williamr@2
   376
		EASShdAlarmFlag2Wakeup				= 0,
williamr@2
   377
		};
williamr@2
   378
williamr@2
   379
	enum TASShdAlarmFlags2AlarmRepeatExtensions
williamr@2
   380
		{
williamr@2
   381
		EASShdAlarmFlag2AlarmDayMonday		= 1,
williamr@2
   382
		EASShdAlarmFlag2AlarmDayTuesday		= 2,
williamr@2
   383
		EASShdAlarmFlag2AlarmDayWednesday	= 3,
williamr@2
   384
		EASShdAlarmFlag2AlarmDayThursday	= 4,
williamr@2
   385
		EASShdAlarmFlag2AlarmDayFriday		= 5,
williamr@2
   386
		EASShdAlarmFlag2AlarmDaySaturday	= 6,
williamr@2
   387
		EASShdAlarmFlag2AlarmDaySunday		= 7,
williamr@2
   388
		EASShdAlarmFlag2Continuous			= 8
williamr@2
   389
		};
williamr@2
   390
williamr@2
   391
		
williamr@2
   392
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   393
protected:									// MEMBER DATA
williamr@2
   394
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   395
williamr@2
   396
	/*
williamr@2
   397
	 * Various flags - used internally by the alarm object
williamr@2
   398
	 */
williamr@2
   399
	TBitFlags8 iFlags;
williamr@2
   400
williamr@2
   401
	/*
williamr@2
   402
	 * This represents the desired behaviour for a given alarm.
williamr@2
   403
	 * The Alarm Server uses this information to control the
williamr@2
   404
	 * behaviour of the alarm.
williamr@2
   405
	 *
williamr@2
   406
	 * @see TAlarmCharacteristics
williamr@2
   407
	 */
williamr@2
   408
	TAlarmCharacteristicsFlags iCharacteristics;
williamr@2
   409
williamr@2
   410
	/*
williamr@2
   411
	 * The unique identifier assoicated with each alarm maintained
williamr@2
   412
	 * by the alarm world server.
williamr@2
   413
	 */
williamr@2
   414
	TAlarmId iAlarmId;
williamr@2
   415
	
williamr@2
   416
	/*
williamr@2
   417
	 * The status of this alarm (e.g. enabled, disabled)
williamr@2
   418
	 */
williamr@2
   419
	TAlarmStatus iStatus;
williamr@2
   420
williamr@2
   421
	/*
williamr@2
   422
	 * The state of this alarm (e.g. queued, notifying, notified, snoozed etc)
williamr@2
   423
	 */
williamr@2
   424
	TAlarmState	iState;
williamr@2
   425
williamr@2
   426
	/*
williamr@2
   427
	 * The type of this alarm (e.g. day, timed)
williamr@2
   428
	 */
williamr@2
   429
	TAlarmDayOrTimed iDayOrTimed;
williamr@2
   430
williamr@2
   431
	/*
williamr@2
   432
	 * Controls how the alarm repeats after it has expired. Note that
williamr@2
   433
	 * session alarms are not allowed to repeat (they must be "once
williamr@2
   434
	 * only").
williamr@2
   435
	 */
williamr@2
   436
	TAlarmRepeatDefinition iRepeatDefinition;
williamr@2
   437
williamr@2
   438
	/*
williamr@2
   439
	 * This UID is supplied by the client and is used to indicate
williamr@2
   440
	 * the category that this alarm is part of. The Alarm Server
williamr@2
   441
	 * is category-agnostic, that is, this information is for
williamr@2
   442
	 * the client's use only
williamr@2
   443
	 */
williamr@2
   444
	TAlarmCategory iCategory;
williamr@2
   445
williamr@2
   446
	/*
williamr@2
   447
	 * The date and time at which this alarm is next due. For alarms
williamr@2
   448
	 * that haven't been snoozed, then this is the original due time.
williamr@2
   449
	 *
williamr@2
   450
	 * For alarms that have been snoozed, this is the time at which
williamr@2
   451
	 * the alarm will reawaken.
williamr@2
   452
	 */
williamr@2
   453
	TTime iNextDueTime;
williamr@2
   454
williamr@2
   455
	/*
williamr@2
   456
	 * This attribute is only used in the instance whereby an alarm
williamr@2
   457
	 * is snoozed. It represents the time at which the alarm first 
williamr@2
   458
	 * expired.
williamr@2
   459
	 */
williamr@2
   460
	TTime iOriginalExpiryTime;
williamr@2
   461
williamr@2
   462
	/*
williamr@2
   463
	 * The message associated with this alarm, typically used
williamr@2
   464
	 * in an application UI to inform the user as to the reason
williamr@2
   465
	 * for the alarm.
williamr@2
   466
	 */
williamr@2
   467
	TAlarmMessage iMessage;
williamr@2
   468
williamr@2
   469
	/*
williamr@2
   470
	 * A descriptor which holds the name of the sound file which
williamr@2
   471
	 * should be played when the alarm expires.
williamr@2
   472
	 */
williamr@2
   473
	TAlarmSoundName iSoundName;
williamr@2
   474
williamr@2
   475
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   476
protected:									// CLIENT SPECIFIC DATA
williamr@2
   477
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   478
williamr@2
   479
	/*
williamr@2
   480
	 * Flags for use by any particular client. These will
williamr@2
   481
	 * only be relevant to a client who can interpret them.
williamr@2
   482
	 */
williamr@2
   483
	TBitFlags16 iClientFlags;
williamr@2
   484
williamr@2
   485
	/*
williamr@2
   486
	 * For arbitrary client data 1
williamr@2
   487
	 */
williamr@2
   488
	TInt iClientData1;
williamr@2
   489
williamr@2
   490
	/*
williamr@2
   491
	 * For arbitrary client data 2
williamr@2
   492
	 */
williamr@2
   493
	TInt iClientData2;
williamr@2
   494
williamr@2
   495
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   496
private:									// BC PROOFING
williamr@2
   497
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   498
	TSecureId iTASShdAlarmSID;
williamr@2
   499
	/*
williamr@2
   500
	 * Various flags - used internally by the alarm object
williamr@2
   501
	 */
williamr@2
   502
	TBitFlags16 iFlags2;
williamr@2
   503
	TUint16 iTASShdAlarm_2;
williamr@2
   504
	TAny* iTASShdAlarm_3;
williamr@2
   505
	};
williamr@2
   506
williamr@2
   507
williamr@2
   508
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   509
// ----> TASShdAlarm (inline)
williamr@2
   510
///////////////////////////////////////////////////////////////////////////////////////
williamr@2
   511
williamr@2
   512
williamr@2
   513
/** Tests whether the alarm has any associated data. 
williamr@2
   514
	
williamr@2
   515
@return True if the alarm has associated data. */
williamr@2
   516
inline TBool TASShdAlarm::HasAssociatedData() const
williamr@2
   517
williamr@2
   518
	{
williamr@2
   519
	return iFlags.IsSet(EASShdAlarmFlagsHasAssociatedData);
williamr@2
   520
	}
williamr@2
   521
williamr@2
   522
williamr@2
   523
/** Tests whether the alarm has an active owning session.
williamr@2
   524
williamr@2
   525
@return True if the alarm has an active owning session. */
williamr@2
   526
inline TBool TASShdAlarm::HasOwningSession() const
williamr@2
   527
williamr@2
   528
	{
williamr@2
   529
	return iFlags.IsSet(EASShdAlarmFlagsHasOwningSession);
williamr@2
   530
	}
williamr@2
   531
williamr@2
   532
inline TBool TASShdAlarm::HasBecomeOrphaned() const
williamr@2
   533
/** Tests whether the alarm is orphaned. 
williamr@2
   534
williamr@2
   535
An alarm is ophaned if it used to have an owning session, but no longer does. 
williamr@2
   536
If an alarm is owned by a session, it is removed from the queue when the session 
williamr@2
   537
disconnects. However, orphaned alarms stay in the queue.
williamr@2
   538
	
williamr@2
   539
@return True if the alarm has becomed orphaned. */
williamr@2
   540
	{
williamr@2
   541
	return iFlags.IsSet(EASShdAlarmFlagsHasBecomeOrphaned);
williamr@2
   542
	}
williamr@2
   543
williamr@2
   544
williamr@2
   545
williamr@2
   546
#endif // #ifndef __ASSHDALARM_H__