remotecontrol/remotecontrolfw/client/common/remconbulkclient.h
author hgs
Wed, 13 Oct 2010 16:20:29 +0300
changeset 51 20ac952a623c
permissions -rw-r--r--
201040_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
51
20ac952a623c 201040_02
hgs
parents:
diff changeset
     1
// Copyright (c) 2008-2010 Nokia Corporation and/or its subsidiary(-ies).
20ac952a623c 201040_02
hgs
parents:
diff changeset
     2
// All rights reserved.
20ac952a623c 201040_02
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
20ac952a623c 201040_02
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
20ac952a623c 201040_02
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
20ac952a623c 201040_02
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
20ac952a623c 201040_02
hgs
parents:
diff changeset
     7
//
20ac952a623c 201040_02
hgs
parents:
diff changeset
     8
// Initial Contributors:
20ac952a623c 201040_02
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    10
//
20ac952a623c 201040_02
hgs
parents:
diff changeset
    11
// Contributors:
20ac952a623c 201040_02
hgs
parents:
diff changeset
    12
//
20ac952a623c 201040_02
hgs
parents:
diff changeset
    13
// Description:
20ac952a623c 201040_02
hgs
parents:
diff changeset
    14
// Remote Control bulk client side.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    15
//
20ac952a623c 201040_02
hgs
parents:
diff changeset
    16
20ac952a623c 201040_02
hgs
parents:
diff changeset
    17
20ac952a623c 201040_02
hgs
parents:
diff changeset
    18
20ac952a623c 201040_02
hgs
parents:
diff changeset
    19
/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    20
 @file
20ac952a623c 201040_02
hgs
parents:
diff changeset
    21
 @internalComponent
20ac952a623c 201040_02
hgs
parents:
diff changeset
    22
*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    23
20ac952a623c 201040_02
hgs
parents:
diff changeset
    24
#ifndef REMCONBULKCLIENT_H
20ac952a623c 201040_02
hgs
parents:
diff changeset
    25
#define REMCONBULKCLIENT_H
20ac952a623c 201040_02
hgs
parents:
diff changeset
    26
20ac952a623c 201040_02
hgs
parents:
diff changeset
    27
#include <e32base.h>
20ac952a623c 201040_02
hgs
parents:
diff changeset
    28
#include <remcon/messagetype.h>
20ac952a623c 201040_02
hgs
parents:
diff changeset
    29
#include "remconserver.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    30
20ac952a623c 201040_02
hgs
parents:
diff changeset
    31
/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    32
The abstract base class for RemCon session handles.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    33
*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    34
NONSHARABLE_CLASS(RRemConBulk) : public RSessionBase
20ac952a623c 201040_02
hgs
parents:
diff changeset
    35
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    36
public:
20ac952a623c 201040_02
hgs
parents:
diff changeset
    37
	IMPORT_C RRemConBulk();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    38
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
    39
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    40
	Connect the handle to the server.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    41
	Must be called before all other methods (except Version and Close).
20ac952a623c 201040_02
hgs
parents:
diff changeset
    42
	@return Error.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    43
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    44
	IMPORT_C TInt Connect();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    45
20ac952a623c 201040_02
hgs
parents:
diff changeset
    46
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    47
	Getter for the version of the server.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    48
	@return Version of the server.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    49
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    50
	IMPORT_C TVersion Version() const;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    51
20ac952a623c 201040_02
hgs
parents:
diff changeset
    52
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    53
	Sends a message (command or response) to the remote device.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    54
	Note that currently only responses are supported, but the API
20ac952a623c 201040_02
hgs
parents:
diff changeset
    55
	is generic enough for both types of message.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    56
	@param aStatus TRequestStatus for asynchronous completion.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    57
	@param aInterfaceUid The UID of the interface to which the message 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    58
	belongs.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    59
	@param aOperationId The ID of the message. RemCon needs to know this, 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    60
	separately from the arbitrary data, so it can (a) match up any incoming 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    61
	response to this client (if the message is a command), and (b) match this 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    62
	message up to the target (if this message is a response).
20ac952a623c 201040_02
hgs
parents:
diff changeset
    63
	@param aData Data associated with the message.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    64
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    65
	IMPORT_C void Send(TRequestStatus& aStatus, 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    66
		TUid aInterfaceUid, 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    67
		TUint aOperationId, 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    68
		const TDesC8& aData = KNullDesC8());
20ac952a623c 201040_02
hgs
parents:
diff changeset
    69
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
    70
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    71
	Sends a message (command or response) unreliably to the remote device.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    72
	Note that currently only reponses are supported, by the API is 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    73
	generic enough for both types of message.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    74
	@param aInterfaceUid The UID of the interface to which the message 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    75
	belongs.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    76
	@param aOperationId The ID of the message. RemCon needs to know this, 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    77
	separately from the arbitrary data, so it can (a) match up any incoming 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    78
	response to this client (if the message is a command), and (b) match this 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    79
	message up to the target (if this message is a response).
20ac952a623c 201040_02
hgs
parents:
diff changeset
    80
	@param aData Data associated with the message.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    81
	@return Error - this is the first point of error.  A message may error
20ac952a623c 201040_02
hgs
parents:
diff changeset
    82
	after this function returns (that error will not be reported).
20ac952a623c 201040_02
hgs
parents:
diff changeset
    83
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    84
	IMPORT_C TInt SendUnreliable(TUid aInterfaceUid, 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    85
			TUint aOperationId,
20ac952a623c 201040_02
hgs
parents:
diff changeset
    86
			const TDesC8& aData = KNullDesC8());
20ac952a623c 201040_02
hgs
parents:
diff changeset
    87
20ac952a623c 201040_02
hgs
parents:
diff changeset
    88
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    89
	Cancels interest in the completion of an outstanding Send operation.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    90
	@return KErrNone.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    91
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    92
	IMPORT_C TInt SendCancel();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    93
20ac952a623c 201040_02
hgs
parents:
diff changeset
    94
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    95
	Receive a message (command or response) from the remote device. Note that 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    96
	RemCon server queues both commands and responses so that none are ever 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    97
	thrown away just because the client didn't have a Receive outstanding when 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    98
	they arrived.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    99
	@param aStatus TRequestStatus for asynchronous completion.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   100
	@param aInterfaceUid The UID of the interface to which the message 
20ac952a623c 201040_02
hgs
parents:
diff changeset
   101
	belongs.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   102
	@param aOperationId The ID of the message.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   103
	@param aData Data associated with the message.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   104
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
   105
	IMPORT_C void Receive(TRequestStatus& aStatus, 
20ac952a623c 201040_02
hgs
parents:
diff changeset
   106
		TUid& aInterfaceUid,
20ac952a623c 201040_02
hgs
parents:
diff changeset
   107
		TUint& aOperationId,
20ac952a623c 201040_02
hgs
parents:
diff changeset
   108
		TDes8& aData);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   109
20ac952a623c 201040_02
hgs
parents:
diff changeset
   110
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
   111
	Cancels interest in the completion of an outstanding Receive operation.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   112
	@return KErrNone.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   113
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
   114
	IMPORT_C TInt ReceiveCancel();
20ac952a623c 201040_02
hgs
parents:
diff changeset
   115
20ac952a623c 201040_02
hgs
parents:
diff changeset
   116
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
   117
	Marks the start of heap cell checking in the server's heap. In release 
20ac952a623c 201040_02
hgs
parents:
diff changeset
   118
	builds, just returns KErrNone.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   119
	@return Error.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   120
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
   121
	IMPORT_C TInt __DbgMarkHeap();
20ac952a623c 201040_02
hgs
parents:
diff changeset
   122
20ac952a623c 201040_02
hgs
parents:
diff changeset
   123
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
   124
	Checks that the number of allocated cells on the server's heap is correct. 
20ac952a623c 201040_02
hgs
parents:
diff changeset
   125
	The server is panicked if not. In release builds, just returns KErrNone.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   126
	@param aCount The expected number of allocated heap cells.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   127
	@return Error.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   128
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
   129
	IMPORT_C TInt __DbgCheckHeap(TInt aCount);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   130
20ac952a623c 201040_02
hgs
parents:
diff changeset
   131
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
   132
	Marks the end of heap cell checking. Checks that the number of heap cells 
20ac952a623c 201040_02
hgs
parents:
diff changeset
   133
	allocated since the last __DbgMarkHeap() is aCount; the most common value 
20ac952a623c 201040_02
hgs
parents:
diff changeset
   134
	to pass here is zero. In release builds, just returns KErrNone.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   135
	@param aCount The expected number of allocated heap cells.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   136
	@return Error.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   137
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
   138
	IMPORT_C TInt __DbgMarkEnd(TInt aCount);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   139
20ac952a623c 201040_02
hgs
parents:
diff changeset
   140
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
   141
	Simulates memory allocation failure in the server. In release builds, just 
20ac952a623c 201040_02
hgs
parents:
diff changeset
   142
	returns KErrNone.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   143
	@param aCount The number of allocations after which memory allocation 
20ac952a623c 201040_02
hgs
parents:
diff changeset
   144
	should fail.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   145
	@return Error.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   146
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
   147
	IMPORT_C TInt __DbgFailNext(TInt aCount);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   148
20ac952a623c 201040_02
hgs
parents:
diff changeset
   149
private: // owned
20ac952a623c 201040_02
hgs
parents:
diff changeset
   150
	/** 
20ac952a623c 201040_02
hgs
parents:
diff changeset
   151
	Used by Send.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   152
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
   153
	TPckgBuf<TOperationInformation> iOpInfoPckg;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   154
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
   155
	/** 
20ac952a623c 201040_02
hgs
parents:
diff changeset
   156
	Used by Receive.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   157
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
   158
	TPckg<TUint> iUidPckg;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   159
	TPckg<TUint> iOpIdPckg;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   160
	};
20ac952a623c 201040_02
hgs
parents:
diff changeset
   161
20ac952a623c 201040_02
hgs
parents:
diff changeset
   162
#endif // REMCONBULKCLIENT_H