epoc32/include/logwrap.h
author William Roberts <williamr@symbian.org>
Tue, 16 Mar 2010 16:12:26 +0000
branchSymbian2
changeset 2 2fe1408b6811
parent 0 061f57f2323e
child 4 837f303aceeb
permissions -rw-r--r--
Final list of Symbian^2 public API header files
williamr@2
     1
// Copyright (c) 2003-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 __LOGWRAP_H__
williamr@2
    17
#define __LOGWRAP_H__
williamr@2
    18
williamr@2
    19
#include <e32base.h>
williamr@2
    20
#include <f32file.h>
williamr@2
    21
#include <barsc2.h> // For CResourceFile
williamr@2
    22
#include <logcntdef.h>
williamr@2
    23
#include <d32dbms.h>
williamr@2
    24
williamr@2
    25
#ifndef __WINC__
williamr@2
    26
#include <logwrap.rsg>
williamr@2
    27
#endif
williamr@2
    28
williamr@2
    29
/**
williamr@2
    30
String lengths
williamr@2
    31
@internalAll
williamr@2
    32
*/
williamr@2
    33
const TInt KLogMaxRemotePartyLength = 64;
williamr@2
    34
const TInt KLogMaxDirectionLength = 64;
williamr@2
    35
const TInt KLogMaxStatusLength = 64;
williamr@2
    36
const TInt KLogMaxSubjectLength = 64;
williamr@2
    37
const TInt KLogMaxDescriptionLength = 64;
williamr@2
    38
const TInt KLogMaxSharedStringLength = 64;
williamr@2
    39
const TInt KLogMaxNumberLength = 100;
williamr@2
    40
williamr@2
    41
/** 
williamr@2
    42
Big enough to contain any of the above strings
williamr@2
    43
Defines a modifiable buffer descriptor into which a standard string from the 
williamr@2
    44
resource in the logwrap.dll resource file can be safely put.
williamr@2
    45
williamr@2
    46
@see CLogClient::GetString()
williamr@2
    47
@publishedAll
williamr@2
    48
@released
williamr@2
    49
*/
williamr@2
    50
typedef TBuf<64> TLogString;
williamr@2
    51
williamr@2
    52
/** 
williamr@2
    53
Type definitions
williamr@2
    54
The unique event ID associated with a log event.
williamr@2
    55
williamr@2
    56
@see CLogEvent
williamr@2
    57
@see CLogViewDuplicate
williamr@2
    58
@see CLogViewRecent
williamr@2
    59
@see CLogClient
williamr@2
    60
@see CLogBase 
williamr@2
    61
@publishedAll
williamr@2
    62
@released
williamr@2
    63
*/
williamr@2
    64
typedef TInt32	TLogId;
williamr@2
    65
/** 
williamr@2
    66
The duration type of an event.
williamr@2
    67
williamr@2
    68
@see CLogEvent
williamr@2
    69
@see CLogFilter
williamr@2
    70
@publishedAll
williamr@2
    71
@released
williamr@2
    72
*/
williamr@2
    73
typedef TInt8	TLogDurationType;
williamr@2
    74
typedef TInt8	TLogRecentList;
williamr@2
    75
typedef TUint16 TLogSize;
williamr@2
    76
typedef TUint8	TLogRecentSize;
williamr@2
    77
/** 
williamr@2
    78
Duration of an event, expressed as the number of seconds since the time of 
williamr@2
    79
the event.
williamr@2
    80
williamr@2
    81
@see CLogEvent
williamr@2
    82
@publishedAll
williamr@2
    83
@released
williamr@2
    84
*/
williamr@2
    85
typedef TUint32	TLogDuration;
williamr@2
    86
typedef TUint32	TLogAge;
williamr@2
    87
/** 
williamr@2
    88
Link value relating a log event to an entity in another application.
williamr@2
    89
williamr@2
    90
@see CLogEvent
williamr@2
    91
@publishedAll
williamr@2
    92
@released
williamr@2
    93
*/
williamr@2
    94
typedef TUint32	TLogLink;
williamr@2
    95
typedef TInt16	TLogStringId;
williamr@2
    96
typedef TInt16	TLogTypeId;
williamr@2
    97
/** 
williamr@2
    98
The duration type of an event.
williamr@2
    99
williamr@2
   100
@see CLogEvent
williamr@2
   101
@see CLogFilter
williamr@2
   102
@publishedAll
williamr@2
   103
@released
williamr@2
   104
*/
williamr@2
   105
typedef TInt8	TLogDurationType;
williamr@2
   106
/** 
williamr@2
   107
Event flags.
williamr@2
   108
williamr@2
   109
@see CLogEvent
williamr@2
   110
@see CLogFilter
williamr@2
   111
@publishedAll
williamr@2
   112
@released
williamr@2
   113
*/
williamr@2
   114
typedef TUint8	TLogFlags;
williamr@2
   115
williamr@2
   116
/**
williamr@2
   117
@internalAll
williamr@2
   118
*/
williamr@2
   119
typedef TUint32	TLogViewId;
williamr@2
   120
williamr@2
   121
/**
williamr@2
   122
Limits
williamr@2
   123
@internalAll
williamr@2
   124
*/
williamr@2
   125
const TLogId KLogNullId = -1;
williamr@2
   126
const TLogDurationType KLogNullDurationType = -1;
williamr@2
   127
const TLogDuration KLogNullDuration = 0;
williamr@2
   128
const TLogLink KLogNullLink = 0;
williamr@2
   129
const TLogRecentList KLogNullRecentList = -1;
williamr@2
   130
const TLogStringId KLogNullStringId = -1;
williamr@2
   131
const TLogTypeId KLogNullTypeId = -1;
williamr@2
   132
const TLogFlags KLogNullFlags = 0;
williamr@2
   133
const TLogFlags KLogFlagsMask = 0xF;
williamr@2
   134
const TInt KLogFlagsCount = 4;
williamr@2
   135
const TInt KLogNeverUsedId = -2;
williamr@2
   136
williamr@2
   137
/**
williamr@2
   138
@internalAll
williamr@2
   139
*/
williamr@2
   140
const TInt KLogActiveDoNotCompleteIfActive = KMaxTInt-1;
williamr@2
   141
williamr@2
   142
//**********************************
williamr@2
   143
// CLogActive
williamr@2
   144
//**********************************
williamr@2
   145
williamr@2
   146
class CLogActive : public CActive
williamr@2
   147
/** 
williamr@2
   148
Common active object behaviour.
williamr@2
   149
williamr@2
   150
This is an abstract class that defines common active object behaviour for 
williamr@2
   151
the log engine classes.
williamr@2
   152
@publishedAll
williamr@2
   153
@released
williamr@2
   154
*/
williamr@2
   155
	{
williamr@2
   156
public:
williamr@2
   157
	IMPORT_C ~CLogActive();
williamr@2
   158
	//
williamr@2
   159
protected:
williamr@2
   160
	IMPORT_C CLogActive(TInt aPriority);
williamr@2
   161
	IMPORT_C void Queue(TRequestStatus& aStatus);
williamr@2
   162
	IMPORT_C void Complete(TInt aStatus);
williamr@2
   163
	IMPORT_C void DoCancel();
williamr@2
   164
	//
williamr@2
   165
private:
williamr@2
   166
	//
williamr@2
   167
	IMPORT_C void RunL();
williamr@2
   168
	virtual void DoRunL()=0;
williamr@2
   169
	IMPORT_C virtual void DoComplete(TInt&);
williamr@2
   170
	//
williamr@2
   171
private:
williamr@2
   172
	TRequestStatus* iReport;
williamr@2
   173
	};
williamr@2
   174
williamr@2
   175
//**********************************
williamr@2
   176
// CLogEvent
williamr@2
   177
//**********************************
williamr@2
   178
williamr@2
   179
class CLogEvent : public CBase
williamr@2
   180
/** 
williamr@2
   181
Encapsulates the details of an event.
williamr@2
   182
williamr@2
   183
Where time is used, it must be specified as UTC rather than local time.
williamr@2
   184
williamr@2
   185
@publishedAll
williamr@2
   186
@released
williamr@2
   187
*/
williamr@2
   188
	{
williamr@2
   189
public:
williamr@2
   190
	IMPORT_C static CLogEvent* NewL();
williamr@2
   191
	IMPORT_C ~CLogEvent();
williamr@2
   192
	//
williamr@2
   193
public:
williamr@2
   194
	inline TLogId Id() const;
williamr@2
   195
	inline void SetId(TLogId aId);
williamr@2
   196
	//
williamr@2
   197
	inline TUid EventType() const;
williamr@2
   198
	inline void SetEventType(TUid aId);
williamr@2
   199
	//
williamr@2
   200
	inline const TDesC& RemoteParty() const;
williamr@2
   201
	inline void SetRemoteParty(const TDesC& aRemote);
williamr@2
   202
	//
williamr@2
   203
	inline const TDesC& Direction() const;
williamr@2
   204
	inline void SetDirection(const TDesC& aDirection);
williamr@2
   205
	//
williamr@2
   206
	inline const TTime& Time() const;
williamr@2
   207
	inline void SetTime(const TTime& aTime);
williamr@2
   208
	//
williamr@2
   209
	inline TLogDurationType DurationType() const;
williamr@2
   210
	inline void SetDurationType(TLogDurationType aDurationType);
williamr@2
   211
	//
williamr@2
   212
	inline TLogDuration Duration() const;
williamr@2
   213
	inline void SetDuration(TLogDuration aDuration);
williamr@2
   214
	//
williamr@2
   215
	inline const TDesC& Status() const;
williamr@2
   216
	inline void SetStatus(const TDesC& aStatus);
williamr@2
   217
	//
williamr@2
   218
	inline const TDesC& Subject() const;
williamr@2
   219
	inline void SetSubject(const TDesC& aSubject);
williamr@2
   220
	//
williamr@2
   221
	inline const TDesC& Number() const;
williamr@2
   222
	inline void SetNumber(const TDesC& aNumber);
williamr@2
   223
	//
williamr@2
   224
	inline TLogContactItemId Contact() const;
williamr@2
   225
	inline void SetContact(TLogContactItemId  aContact);
williamr@2
   226
	//
williamr@2
   227
	inline TLogLink Link() const;
williamr@2
   228
	inline void SetLink(TLogLink aLink);
williamr@2
   229
	//
williamr@2
   230
	inline const TDesC& Description() const;
williamr@2
   231
	inline void SetDescription(const TDesC& aDescription);
williamr@2
   232
	//
williamr@2
   233
	inline TLogFlags Flags() const;
williamr@2
   234
	inline void SetFlags(TLogFlags aFlags);
williamr@2
   235
	inline void ClearFlags(TLogFlags aFlags);
williamr@2
   236
	//
williamr@2
   237
	inline const TDesC8& Data() const;
williamr@2
   238
	IMPORT_C void SetDataL(RReadStream& aStream, TInt aLen);
williamr@2
   239
	IMPORT_C void SetDataL(const TDesC8& aData);
williamr@2
   240
	//
williamr@2
   241
	IMPORT_C void CopyL(const CLogEvent& aEvent);
williamr@2
   242
williamr@2
   243
	IMPORT_C void InternalizeL(RReadStream& aStream);
williamr@2
   244
	IMPORT_C void ExternalizeL(RWriteStream& aStream) const;
williamr@2
   245
williamr@2
   246
	//
williamr@2
   247
private:
williamr@2
   248
	CLogEvent();
williamr@2
   249
	void ConstructL();
williamr@2
   250
	void InternalizeBufL(RReadStream& aStream, HBufC*& aDes);
williamr@2
   251
	//
williamr@2
   252
private:
williamr@2
   253
	TLogId iId;
williamr@2
   254
	TUid iEventType;
williamr@2
   255
	TTime iTime;
williamr@2
   256
	TLogDurationType iDurationType;
williamr@2
   257
	TLogDuration iDuration;
williamr@2
   258
	TLogContactItemId  iContact;
williamr@2
   259
	TLogLink iLink;
williamr@2
   260
	TLogFlags iFlags;
williamr@2
   261
	HBufC* iDescription;
williamr@2
   262
	HBufC* iRemoteParty;
williamr@2
   263
	HBufC* iDirection;
williamr@2
   264
	HBufC* iStatus;
williamr@2
   265
	HBufC* iSubject;
williamr@2
   266
	HBufC* iNumber;
williamr@2
   267
	HBufC8* iData;
williamr@2
   268
	};
williamr@2
   269
williamr@2
   270
//**********************************
williamr@2
   271
// CLogBase
williamr@2
   272
//**********************************
williamr@2
   273
williamr@2
   274
class CLogBase : public CLogActive
williamr@2
   275
/** 
williamr@2
   276
Base class for the log engine implementation.
williamr@2
   277
williamr@2
   278
This class defines the interface that client code uses to perform simple actions 
williamr@2
   279
on the log database.
williamr@2
   280
williamr@2
   281
The class provides default implementations for the event handling functions. 
williamr@2
   282
The Log Engine, i.e. an instance of CLogClient, is derived from this class 
williamr@2
   283
and provides implementations for the event handling functions.
williamr@2
   284
williamr@2
   285
The class also deals with some aspects of resource file handling.
williamr@2
   286
williamr@2
   287
An instance of this class is constructed by the log wrapper, CLogWrapper, 
williamr@2
   288
if the phone does not implement logging.
williamr@2
   289
williamr@2
   290
An instance of this class is never constructed by clients.
williamr@2
   291
williamr@2
   292
@see CLogClient
williamr@2
   293
@see CLogWrapper
williamr@2
   294
@publishedAll
williamr@2
   295
@released
williamr@2
   296
*/
williamr@2
   297
	{
williamr@2
   298
public:
williamr@2
   299
	IMPORT_C CLogBase(TInt aPriority);
williamr@2
   300
	IMPORT_C ~CLogBase();
williamr@2
   301
	//
williamr@2
   302
	IMPORT_C virtual void GetEvent(CLogEvent& aEvent, TRequestStatus& aStatus);
williamr@2
   303
	IMPORT_C virtual void AddEvent(CLogEvent& aEvent, TRequestStatus& aStatus);
williamr@2
   304
	IMPORT_C virtual void ChangeEvent(const CLogEvent& aEvent, TRequestStatus& aStatus);
williamr@2
   305
	IMPORT_C virtual void DeleteEvent(TLogId aId, TRequestStatus& aStatus);
williamr@2
   306
	//
williamr@2
   307
	IMPORT_C virtual TInt GetString(TDes& aString, TInt aId) const;
williamr@2
   308
	//
williamr@2
   309
protected:
williamr@2
   310
	IMPORT_C void LoadResourcesL(RFs& aFs);
williamr@2
   311
	inline const CResourceFile* ResourceFile() const;
williamr@2
   312
	//
williamr@2
   313
private:
williamr@2
   314
	void DoRunL();
williamr@2
   315
	//
williamr@2
   316
private:
williamr@2
   317
	CResourceFile* iResourceFile;
williamr@2
   318
	
williamr@2
   319
	//
williamr@2
   320
private:
williamr@2
   321
	IMPORT_C virtual void CLogBase_Reserved1();
williamr@2
   322
	TAny* CLogBase_Reserved;
williamr@2
   323
	};
williamr@2
   324
williamr@2
   325
//**********************************
williamr@2
   326
// CLogWrapper
williamr@2
   327
//**********************************
williamr@2
   328
williamr@2
   329
class CLogWrapper : public CBase
williamr@2
   330
/** 
williamr@2
   331
The log wrapper.
williamr@2
   332
williamr@2
   333
As some UI variants do not use a Log Engine, the log wrapper provides a consistent 
williamr@2
   334
interface to clients that need to work, without being changed, with multiple 
williamr@2
   335
UI variants.
williamr@2
   336
williamr@2
   337
The log wrapper is provided in its own DLL, the logwrap.dll.
williamr@2
   338
williamr@2
   339
If a Log Engine is not installed on a phone, the log wrapper creates an instance 
williamr@2
   340
of the CLogBase class, whose event handling requests complete with KErrNotSupported 
williamr@2
   341
and whose functions return KErrNotSupported.
williamr@2
   342
williamr@2
   343
If a Log Engine is installed on a phone, the log wrapper creates an instance 
williamr@2
   344
of the CLogClient class, provided in a separate DLL, the logcli.dll . The 
williamr@2
   345
CLogClient class derives from CLogBase and provides implementations for the 
williamr@2
   346
event handling requests and functions.
williamr@2
   347
williamr@2
   348
@see CLogBase
williamr@2
   349
@see CLogClient
williamr@2
   350
@publishedAll
williamr@2
   351
@released
williamr@2
   352
*/
williamr@2
   353
	{
williamr@2
   354
public:
williamr@2
   355
	IMPORT_C static CLogWrapper* NewL(RFs& aFs, TInt aPriority = CActive::EPriorityStandard);
williamr@2
   356
	IMPORT_C ~CLogWrapper();
williamr@2
   357
	//
williamr@2
   358
	inline CLogBase& Log();
williamr@2
   359
	IMPORT_C TBool ClientAvailable() const;
williamr@2
   360
	//
williamr@2
   361
private:
williamr@2
   362
	CLogWrapper();
williamr@2
   363
	void ConstructL(RFs& aFs, TInt aPriority);
williamr@2
   364
	//
williamr@2
   365
private:
williamr@2
   366
	CLogBase* iBase;
williamr@2
   367
	};
williamr@2
   368
williamr@2
   369
#include <logwrap.inl>
williamr@2
   370
#include <logeng.h>
williamr@2
   371
williamr@2
   372
#endif