accessoryservices/remotecontrolfw/server/src/targetclientprocess.cpp
author hgs
Thu, 23 Sep 2010 10:05:41 +0300
changeset 70 653a8b91b95e
permissions -rw-r--r--
201037
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
70
hgs
parents:
diff changeset
     1
// Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     2
// All rights reserved.
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     7
//
hgs
parents:
diff changeset
     8
// Initial Contributors:
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    10
//
hgs
parents:
diff changeset
    11
// Contributors:
hgs
parents:
diff changeset
    12
//
hgs
parents:
diff changeset
    13
// Description:
hgs
parents:
diff changeset
    14
// Server-side representation of a target client, which may have multiple 
hgs
parents:
diff changeset
    15
// sessions associated with it.
hgs
parents:
diff changeset
    16
// 
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#include <e32base.h>
hgs
parents:
diff changeset
    20
#include <bluetooth/logger.h>
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include "server.h"
hgs
parents:
diff changeset
    23
#include "bearermanager.h"
hgs
parents:
diff changeset
    24
#include "remconmessage.h"
hgs
parents:
diff changeset
    25
#include "targetsession.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
#include "targetclientprocess.h"
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
#ifdef __FLOG_ACTIVE
hgs
parents:
diff changeset
    30
_LIT8(KLogComponent, LOG_COMPONENT_REMCON_SERVER);
hgs
parents:
diff changeset
    31
#endif
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
#ifdef _DEBUG
hgs
parents:
diff changeset
    34
PANICCATEGORY("tgclient");
hgs
parents:
diff changeset
    35
#endif
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
TBool TargetSessionCompareUsingSupportedInterface(const TUid* aInterfaceUid, const CRemConTargetSession& aSession)
hgs
parents:
diff changeset
    38
	{
hgs
parents:
diff changeset
    39
	return aSession.InterfaceSupported(*aInterfaceUid);
hgs
parents:
diff changeset
    40
	}
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
TBool TargetSessionCompareUsingSupportedMessage(const CRemConMessage* aMessage, const CRemConTargetSession& aSession)
hgs
parents:
diff changeset
    43
	{
hgs
parents:
diff changeset
    44
	return aSession.SupportedMessage(*aMessage);
hgs
parents:
diff changeset
    45
	}
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
CRemConTargetClientProcess* CRemConTargetClientProcess::NewLC(TClientInfo& aClientInfo, TRemConClientId aClientId, CRemConServer& aServer, CBearerManager& aBearerManager)
hgs
parents:
diff changeset
    48
	{
hgs
parents:
diff changeset
    49
	LOG_STATIC_FUNC
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
	CRemConTargetClientProcess* result = new (ELeave) CRemConTargetClientProcess(aClientInfo, aClientId, aServer, aBearerManager);
hgs
parents:
diff changeset
    52
	CleanupStack::PushL(result);
hgs
parents:
diff changeset
    53
	return result;
hgs
parents:
diff changeset
    54
	}
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
CRemConTargetClientProcess::CRemConTargetClientProcess(TClientInfo& aClientInfo, TRemConClientId aClientId, CRemConServer& aServer, CBearerManager& aBearerManager)
hgs
parents:
diff changeset
    57
	: iClientInfo(aClientInfo),
hgs
parents:
diff changeset
    58
	iClientId(aClientId),
hgs
parents:
diff changeset
    59
	iServer(aServer),
hgs
parents:
diff changeset
    60
	iBearerManager(aBearerManager),
hgs
parents:
diff changeset
    61
	iPlayerInfoSet(EFalse),
hgs
parents:
diff changeset
    62
	iTargetSessions(KMaxNumberTargetSessions)
hgs
parents:
diff changeset
    63
	{
hgs
parents:
diff changeset
    64
	LOG_FUNC
hgs
parents:
diff changeset
    65
	}
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
CRemConTargetClientProcess::~CRemConTargetClientProcess()
hgs
parents:
diff changeset
    68
	{
hgs
parents:
diff changeset
    69
	LOG_FUNC
hgs
parents:
diff changeset
    70
hgs
parents:
diff changeset
    71
	iPlayerName.Close();
hgs
parents:
diff changeset
    72
	iTargetSessions.Close();
hgs
parents:
diff changeset
    73
	iServer.TargetClientClosed(*this);
hgs
parents:
diff changeset
    74
	}
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
CRemConTargetSession* CRemConTargetClientProcess::NewSessionL(TUint aSessionId)
hgs
parents:
diff changeset
    77
	{
hgs
parents:
diff changeset
    78
	LOG_FUNC
hgs
parents:
diff changeset
    79
	CRemConTargetSession* sess = NULL;
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
	// Only create a session if we havent reached our maximum.
hgs
parents:
diff changeset
    82
	if (TargetSessionCount() < KMaxNumberTargetSessions)
hgs
parents:
diff changeset
    83
		{
hgs
parents:
diff changeset
    84
		sess = CRemConTargetSession::NewL(*this, iServer, iBearerManager, aSessionId);
hgs
parents:
diff changeset
    85
		}
hgs
parents:
diff changeset
    86
	else
hgs
parents:
diff changeset
    87
		{
hgs
parents:
diff changeset
    88
		LEAVEIFERRORL(KErrOverflow);
hgs
parents:
diff changeset
    89
		}
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
	return sess;
hgs
parents:
diff changeset
    92
	}
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
TInt CRemConTargetClientProcess::TargetSessionOpened(CRemConTargetSession& aSession)
hgs
parents:
diff changeset
    96
	{
hgs
parents:
diff changeset
    97
	LOG_FUNC
hgs
parents:
diff changeset
    98
	LOG1(_L("\t&aSession = 0x%08x"), &aSession)
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
	// Register the session by appending it to our array and asking the server to
hgs
parents:
diff changeset
   101
	// make an item for it in the record of which points in the connection history 
hgs
parents:
diff changeset
   102
	// sessions are interested in.
hgs
parents:
diff changeset
   103
	ASSERT(iTargetSessions.Count() < KMaxNumberTargetSessions);	// Should have been caught by now.
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
	// The append should never fail because the RPointerArray was constructed with a granularity of 
hgs
parents:
diff changeset
   106
	// KMaxNumberTargetSessions items.
hgs
parents:
diff changeset
   107
#ifdef _DEBUG	
hgs
parents:
diff changeset
   108
	TInt err = iTargetSessions.Append(&aSession);
hgs
parents:
diff changeset
   109
	ASSERT(err == KErrNone);
hgs
parents:
diff changeset
   110
#else
hgs
parents:
diff changeset
   111
	static_cast<void>(iTargetSessions.Append(&aSession));
hgs
parents:
diff changeset
   112
#endif
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
	TInt ret = iServer.RegisterTargetSessionPointerToConnHistory(aSession);
hgs
parents:
diff changeset
   115
			
hgs
parents:
diff changeset
   116
	if ( ret != KErrNone )
hgs
parents:
diff changeset
   117
		{
hgs
parents:
diff changeset
   118
		iTargetSessions.Remove(iTargetSessions.Count() - 1);
hgs
parents:
diff changeset
   119
		}
hgs
parents:
diff changeset
   120
	else
hgs
parents:
diff changeset
   121
		{
hgs
parents:
diff changeset
   122
		// Session successfully registered.
hgs
parents:
diff changeset
   123
		iServer.CancelShutdownTimer();
hgs
parents:
diff changeset
   124
		}
hgs
parents:
diff changeset
   125
	
hgs
parents:
diff changeset
   126
	LOG1(_L("\tret = %d"), ret)
hgs
parents:
diff changeset
   127
	return ret;
hgs
parents:
diff changeset
   128
	}
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
void CRemConTargetClientProcess::TargetSessionClosed(CRemConTargetSession& aSession)
hgs
parents:
diff changeset
   131
	{
hgs
parents:
diff changeset
   132
	LOG_FUNC
hgs
parents:
diff changeset
   133
	LOG1(_L("\t&aSession = 0x%08x"), &aSession)
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
	// Remove session from our list
hgs
parents:
diff changeset
   136
	TInt sessionIndex = iTargetSessions.Find(&aSession);
hgs
parents:
diff changeset
   137
hgs
parents:
diff changeset
   138
	if (sessionIndex > KErrNotFound)
hgs
parents:
diff changeset
   139
		{
hgs
parents:
diff changeset
   140
		iTargetSessions.Remove(sessionIndex);
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
		// Inform server that session has dropped. 			
hgs
parents:
diff changeset
   143
		iServer.TargetSessionClosed(*this, aSession);
hgs
parents:
diff changeset
   144
		
hgs
parents:
diff changeset
   145
		if (iTargetSessions.Count() > 0)
hgs
parents:
diff changeset
   146
		    {
hgs
parents:
diff changeset
   147
            iServer.TargetFeaturesUpdated(*this);
hgs
parents:
diff changeset
   148
		    }
hgs
parents:
diff changeset
   149
		
hgs
parents:
diff changeset
   150
		}
hgs
parents:
diff changeset
   151
	}
hgs
parents:
diff changeset
   152
hgs
parents:
diff changeset
   153
void CRemConTargetClientProcess::SetPlayerInformationL(const TPlayerTypeInformation& aPlayerType, const TDesC8& aPlayerName)
hgs
parents:
diff changeset
   154
	{
hgs
parents:
diff changeset
   155
	LOG_FUNC
hgs
parents:
diff changeset
   156
	ASSERT_DEBUG(!HasPlayerInformation());
hgs
parents:
diff changeset
   157
hgs
parents:
diff changeset
   158
	if (!HasPlayerInformation())
hgs
parents:
diff changeset
   159
		{
hgs
parents:
diff changeset
   160
		iPlayerName.CreateL(aPlayerName);
hgs
parents:
diff changeset
   161
		iPlayerType = aPlayerType;
hgs
parents:
diff changeset
   162
		iPlayerInfoSet = ETrue;
hgs
parents:
diff changeset
   163
		}
hgs
parents:
diff changeset
   164
	}
hgs
parents:
diff changeset
   165
hgs
parents:
diff changeset
   166
void CRemConTargetClientProcess::InterfacesRegistered()
hgs
parents:
diff changeset
   167
	{
hgs
parents:
diff changeset
   168
	LOG_FUNC
hgs
parents:
diff changeset
   169
hgs
parents:
diff changeset
   170
	// If this client has not been made available yet, do so now.
hgs
parents:
diff changeset
   171
	// Otherwise, notify the server that new interfaces have been registered. 
hgs
parents:
diff changeset
   172
	if (!iClientAvailable)
hgs
parents:
diff changeset
   173
		{
hgs
parents:
diff changeset
   174
		iServer.TargetClientAvailable(*this);	
hgs
parents:
diff changeset
   175
		iClientAvailable = ETrue;
hgs
parents:
diff changeset
   176
		}
hgs
parents:
diff changeset
   177
	else
hgs
parents:
diff changeset
   178
		{
hgs
parents:
diff changeset
   179
		iServer.TargetFeaturesUpdated(*this);
hgs
parents:
diff changeset
   180
		}
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
	}
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
TBool CRemConTargetClientProcess::IsInterfaceTypeRegisteredByAnotherSession(CRemConTargetSession& aSession, TUid aInterfaceUid) const
hgs
parents:
diff changeset
   185
	{
hgs
parents:
diff changeset
   186
	LOG_FUNC
hgs
parents:
diff changeset
   187
hgs
parents:
diff changeset
   188
	TUint sessionCount = iTargetSessions.Count();
hgs
parents:
diff changeset
   189
	for (TUint i=0; i < sessionCount; ++i)
hgs
parents:
diff changeset
   190
		{
hgs
parents:
diff changeset
   191
		if (aSession.Id() != iTargetSessions[i]->Id())
hgs
parents:
diff changeset
   192
			{
hgs
parents:
diff changeset
   193
			if (iTargetSessions[i]->InterfaceSupported(aInterfaceUid))
hgs
parents:
diff changeset
   194
				{
hgs
parents:
diff changeset
   195
				return ETrue;
hgs
parents:
diff changeset
   196
				}
hgs
parents:
diff changeset
   197
			}
hgs
parents:
diff changeset
   198
		}
hgs
parents:
diff changeset
   199
hgs
parents:
diff changeset
   200
	return EFalse;
hgs
parents:
diff changeset
   201
	}
hgs
parents:
diff changeset
   202
hgs
parents:
diff changeset
   203
TInt CRemConTargetClientProcess::ReceiveMessage(CRemConMessage& aMessage)
hgs
parents:
diff changeset
   204
	{
hgs
parents:
diff changeset
   205
	LOG_FUNC
hgs
parents:
diff changeset
   206
hgs
parents:
diff changeset
   207
	// Find the session supporting this message
hgs
parents:
diff changeset
   208
	CRemConTargetSession* sess = FindSessionForMessage(aMessage);
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
	if (sess)
hgs
parents:
diff changeset
   211
		{
hgs
parents:
diff changeset
   212
		// Session found. Check session is able to handle this message.
hgs
parents:
diff changeset
   213
		if (sess->CurrentReceiveMessage().Handle())
hgs
parents:
diff changeset
   214
			{
hgs
parents:
diff changeset
   215
			// Pass message to session and return the error code obtained.
hgs
parents:
diff changeset
   216
			return sess->WriteMessageToClient(aMessage);
hgs
parents:
diff changeset
   217
			}
hgs
parents:
diff changeset
   218
		else
hgs
parents:
diff changeset
   219
			{
hgs
parents:
diff changeset
   220
			// Session not able to handle message at this time.
hgs
parents:
diff changeset
   221
			return KErrNotReady;
hgs
parents:
diff changeset
   222
			}
hgs
parents:
diff changeset
   223
		}
hgs
parents:
diff changeset
   224
	else
hgs
parents:
diff changeset
   225
		{
hgs
parents:
diff changeset
   226
		// No session supports this message
hgs
parents:
diff changeset
   227
		return KErrArgument;
hgs
parents:
diff changeset
   228
		}
hgs
parents:
diff changeset
   229
	}
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231
void CRemConTargetClientProcess::ConnectionsChanged()
hgs
parents:
diff changeset
   232
	{
hgs
parents:
diff changeset
   233
	LOG_FUNC
hgs
parents:
diff changeset
   234
hgs
parents:
diff changeset
   235
	// Notify each session
hgs
parents:
diff changeset
   236
	TUint sessionCount = iTargetSessions.Count();
hgs
parents:
diff changeset
   237
	for (TUint i = 0; i < sessionCount; ++i)
hgs
parents:
diff changeset
   238
		{
hgs
parents:
diff changeset
   239
		iTargetSessions[i]->ConnectionsChanged();
hgs
parents:
diff changeset
   240
		}
hgs
parents:
diff changeset
   241
	}
hgs
parents:
diff changeset
   242
hgs
parents:
diff changeset
   243
TInt CRemConTargetClientProcess::SupportedInterfaces(RArray<TUid>& aUids)
hgs
parents:
diff changeset
   244
	{
hgs
parents:
diff changeset
   245
	LOG_FUNC
hgs
parents:
diff changeset
   246
	
hgs
parents:
diff changeset
   247
	TInt err = KErrNone;
hgs
parents:
diff changeset
   248
	aUids.Reset();
hgs
parents:
diff changeset
   249
hgs
parents:
diff changeset
   250
	// Gather the list of supported interfaces from each session.
hgs
parents:
diff changeset
   251
	TUint sessionCount = iTargetSessions.Count();
hgs
parents:
diff changeset
   252
	for (TUint i = 0 ; i < sessionCount && err == KErrNone; ++i)
hgs
parents:
diff changeset
   253
		{
hgs
parents:
diff changeset
   254
		err = iTargetSessions[i]->AppendSupportedInterfaces(aUids);
hgs
parents:
diff changeset
   255
		}
hgs
parents:
diff changeset
   256
hgs
parents:
diff changeset
   257
	return err;
hgs
parents:
diff changeset
   258
	}
hgs
parents:
diff changeset
   259
hgs
parents:
diff changeset
   260
TInt CRemConTargetClientProcess::SupportedBulkInterfaces(RArray<TUid>& aUids)
hgs
parents:
diff changeset
   261
	{
hgs
parents:
diff changeset
   262
	LOG_FUNC
hgs
parents:
diff changeset
   263
	
hgs
parents:
diff changeset
   264
	TInt err = KErrNone;
hgs
parents:
diff changeset
   265
	aUids.Reset();
hgs
parents:
diff changeset
   266
hgs
parents:
diff changeset
   267
	// Gather the list of supported bulk interfaces from each session.
hgs
parents:
diff changeset
   268
	TUint sessionCount = iTargetSessions.Count();
hgs
parents:
diff changeset
   269
	for (TUint i = 0 ; i < sessionCount && err == KErrNone; ++i)
hgs
parents:
diff changeset
   270
		{
hgs
parents:
diff changeset
   271
		err = iTargetSessions[i]->AppendSupportedBulkInterfaces(aUids);
hgs
parents:
diff changeset
   272
		}
hgs
parents:
diff changeset
   273
hgs
parents:
diff changeset
   274
	return err;
hgs
parents:
diff changeset
   275
	}
hgs
parents:
diff changeset
   276
hgs
parents:
diff changeset
   277
TInt CRemConTargetClientProcess::SupportedOperations(TUid aInterfaceUid, RArray<TUint>& aOperations)
hgs
parents:
diff changeset
   278
	{
hgs
parents:
diff changeset
   279
	LOG_FUNC
hgs
parents:
diff changeset
   280
hgs
parents:
diff changeset
   281
	// Find the session supporting this interface.
hgs
parents:
diff changeset
   282
	TInt sessIndex = FindSessionForInterface(aInterfaceUid);
hgs
parents:
diff changeset
   283
hgs
parents:
diff changeset
   284
	if (sessIndex >= KErrNone)
hgs
parents:
diff changeset
   285
		{
hgs
parents:
diff changeset
   286
		return iTargetSessions[sessIndex]->SupportedOperations(aInterfaceUid, aOperations);
hgs
parents:
diff changeset
   287
		}
hgs
parents:
diff changeset
   288
	else
hgs
parents:
diff changeset
   289
		{
hgs
parents:
diff changeset
   290
		// Interface not found, so operation not supported.
hgs
parents:
diff changeset
   291
		return KErrNotSupported;
hgs
parents:
diff changeset
   292
		}
hgs
parents:
diff changeset
   293
	}
hgs
parents:
diff changeset
   294
hgs
parents:
diff changeset
   295
CRemConTargetSession* CRemConTargetClientProcess::FindSessionForMessage(const CRemConMessage& aMessage)
hgs
parents:
diff changeset
   296
	{
hgs
parents:
diff changeset
   297
	LOG_FUNC
hgs
parents:
diff changeset
   298
hgs
parents:
diff changeset
   299
	TInt result = iTargetSessions.Find(aMessage, TargetSessionCompareUsingSupportedMessage);
hgs
parents:
diff changeset
   300
	if (result >= KErrNone)
hgs
parents:
diff changeset
   301
		{
hgs
parents:
diff changeset
   302
		return iTargetSessions[result];
hgs
parents:
diff changeset
   303
		}
hgs
parents:
diff changeset
   304
	else
hgs
parents:
diff changeset
   305
		{
hgs
parents:
diff changeset
   306
		return NULL;
hgs
parents:
diff changeset
   307
		}
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
	}
hgs
parents:
diff changeset
   310
hgs
parents:
diff changeset
   311
TInt CRemConTargetClientProcess::FindSessionForInterface(TUid aInterfaceUid) const
hgs
parents:
diff changeset
   312
	{
hgs
parents:
diff changeset
   313
	LOG_FUNC
hgs
parents:
diff changeset
   314
hgs
parents:
diff changeset
   315
	return iTargetSessions.Find(aInterfaceUid, TargetSessionCompareUsingSupportedInterface);
hgs
parents:
diff changeset
   316
	}
hgs
parents:
diff changeset
   317
hgs
parents:
diff changeset
   318
void CRemConTargetClientProcess::CompleteMessageForSession(const CRemConMessage& aMessage, CRemConTargetSession& aSession)
hgs
parents:
diff changeset
   319
	{
hgs
parents:
diff changeset
   320
	LOG_FUNC
hgs
parents:
diff changeset
   321
hgs
parents:
diff changeset
   322
	// Targets can only send responses or rejects.
hgs
parents:
diff changeset
   323
	switch (aMessage.MsgType())
hgs
parents:
diff changeset
   324
		{
hgs
parents:
diff changeset
   325
	case ERemConResponse:
hgs
parents:
diff changeset
   326
	case ERemConReject:
hgs
parents:
diff changeset
   327
		aSession.CompleteSend();
hgs
parents:
diff changeset
   328
		break;
hgs
parents:
diff changeset
   329
	default:
hgs
parents:
diff changeset
   330
		ASSERT_DEBUG(EFalse);
hgs
parents:
diff changeset
   331
		break;
hgs
parents:
diff changeset
   332
		}
hgs
parents:
diff changeset
   333
hgs
parents:
diff changeset
   334
	}
hgs
parents:
diff changeset
   335
hgs
parents:
diff changeset
   336
void CRemConTargetClientProcess::MrcmsoMessageSendResult(const CRemConMessage& /*aMessage*/, TInt /*aError*/)
hgs
parents:
diff changeset
   337
	{
hgs
parents:
diff changeset
   338
	LOG_FUNC
hgs
parents:
diff changeset
   339
	
hgs
parents:
diff changeset
   340
	// This method should never be called, as it is not required to support target client processes.
hgs
parents:
diff changeset
   341
	ASSERT_DEBUG(EFalse);
hgs
parents:
diff changeset
   342
	}
hgs
parents:
diff changeset
   343
hgs
parents:
diff changeset
   344
void CRemConTargetClientProcess::MrcmsoMessageSendOneOrMoreAttempt(const CRemConMessage& aMessage, TUint aNumRemotes)
hgs
parents:
diff changeset
   345
	{
hgs
parents:
diff changeset
   346
	LOG_FUNC
hgs
parents:
diff changeset
   347
hgs
parents:
diff changeset
   348
	// Notifications should not be received for reject messages, as the client did not request these be sent.
hgs
parents:
diff changeset
   349
	ASSERT_DEBUG(aMessage.MsgType() != ERemConReject);
hgs
parents:
diff changeset
   350
	
hgs
parents:
diff changeset
   351
	// Find session and notify
hgs
parents:
diff changeset
   352
	CRemConTargetSession* sess = FindSessionForMessage(aMessage);
hgs
parents:
diff changeset
   353
	ASSERT_DEBUG(sess);
hgs
parents:
diff changeset
   354
	
hgs
parents:
diff changeset
   355
	// Session should not already be sending a message to n remotes
hgs
parents:
diff changeset
   356
	ASSERT_DEBUG(sess->NumRemotesToTry() == 0);
hgs
parents:
diff changeset
   357
hgs
parents:
diff changeset
   358
	sess->NumRemotes() = 0;
hgs
parents:
diff changeset
   359
	sess->NumRemotesToTry() = aNumRemotes;
hgs
parents:
diff changeset
   360
	sess->SendError() = KErrNone;
hgs
parents:
diff changeset
   361
	}
hgs
parents:
diff changeset
   362
hgs
parents:
diff changeset
   363
void CRemConTargetClientProcess::MrcmsoMessageSendOneOrMoreIncremental(const CRemConMessage& aMessage, TUint aNumRemotes)
hgs
parents:
diff changeset
   364
	{
hgs
parents:
diff changeset
   365
	LOG_FUNC
hgs
parents:
diff changeset
   366
hgs
parents:
diff changeset
   367
	// Notifications should not be received for reject messages, as the client did not request these be sent.
hgs
parents:
diff changeset
   368
	ASSERT_DEBUG(aMessage.MsgType() != ERemConReject);
hgs
parents:
diff changeset
   369
	
hgs
parents:
diff changeset
   370
	// Find session and notify
hgs
parents:
diff changeset
   371
	CRemConTargetSession* sess = FindSessionForMessage(aMessage);
hgs
parents:
diff changeset
   372
	ASSERT_DEBUG(sess);
hgs
parents:
diff changeset
   373
hgs
parents:
diff changeset
   374
	if (sess->NumRemotesToTry() == 0)
hgs
parents:
diff changeset
   375
		{
hgs
parents:
diff changeset
   376
		MrcmsoMessageSendOneOrMoreAttempt(aMessage,aNumRemotes);
hgs
parents:
diff changeset
   377
		}
hgs
parents:
diff changeset
   378
	else
hgs
parents:
diff changeset
   379
		{
hgs
parents:
diff changeset
   380
		// No send should have yet been attempted
hgs
parents:
diff changeset
   381
		ASSERT_DEBUG(sess->NumRemotes() == 0);
hgs
parents:
diff changeset
   382
hgs
parents:
diff changeset
   383
		sess->NumRemotesToTry() += aNumRemotes;
hgs
parents:
diff changeset
   384
		}
hgs
parents:
diff changeset
   385
	}
hgs
parents:
diff changeset
   386
	
hgs
parents:
diff changeset
   387
void CRemConTargetClientProcess::MrcmsoMessageSendOneOrMoreAttemptFailed(const CRemConMessage& aMessage, TInt aError)
hgs
parents:
diff changeset
   388
	{
hgs
parents:
diff changeset
   389
	LOG_FUNC
hgs
parents:
diff changeset
   390
hgs
parents:
diff changeset
   391
	// Notifications should not be received for reject messages, as the client did not request these be sent.
hgs
parents:
diff changeset
   392
	ASSERT_DEBUG(aMessage.MsgType() != ERemConReject);
hgs
parents:
diff changeset
   393
	
hgs
parents:
diff changeset
   394
	// Find session and notify
hgs
parents:
diff changeset
   395
	CRemConTargetSession* sess = FindSessionForMessage(aMessage);
hgs
parents:
diff changeset
   396
	ASSERT_DEBUG(sess);
hgs
parents:
diff changeset
   397
	
hgs
parents:
diff changeset
   398
	// Session should not already be sending a message to n remotes
hgs
parents:
diff changeset
   399
	ASSERT_DEBUG(sess->NumRemotesToTry() == 0);
hgs
parents:
diff changeset
   400
hgs
parents:
diff changeset
   401
	sess->NumRemotes() = 0;
hgs
parents:
diff changeset
   402
	sess->SendError() = aError;
hgs
parents:
diff changeset
   403
	CompleteMessageForSession(aMessage, *sess);
hgs
parents:
diff changeset
   404
	}
hgs
parents:
diff changeset
   405
hgs
parents:
diff changeset
   406
void CRemConTargetClientProcess::MrcmsoMessageSendOneOrMoreResult(const CRemConMessage& aMessage, TInt aError)
hgs
parents:
diff changeset
   407
	{
hgs
parents:
diff changeset
   408
	LOG_FUNC
hgs
parents:
diff changeset
   409
hgs
parents:
diff changeset
   410
	// Notifications should not be received for reject messages, as the client did not request these be sent.
hgs
parents:
diff changeset
   411
	ASSERT_DEBUG(aMessage.MsgType() != ERemConReject);
hgs
parents:
diff changeset
   412
	
hgs
parents:
diff changeset
   413
	// Find session and notify
hgs
parents:
diff changeset
   414
	CRemConTargetSession* sess = FindSessionForMessage(aMessage);
hgs
parents:
diff changeset
   415
	ASSERT_DEBUG(sess);
hgs
parents:
diff changeset
   416
	
hgs
parents:
diff changeset
   417
	// Ignore notification if client has been completed
hgs
parents:
diff changeset
   418
	if (sess->NumRemotesToTry() > 0)
hgs
parents:
diff changeset
   419
		{
hgs
parents:
diff changeset
   420
		// Only set error if different from KErrNone
hgs
parents:
diff changeset
   421
		if (aError == KErrNone)
hgs
parents:
diff changeset
   422
			{
hgs
parents:
diff changeset
   423
			++sess->NumRemotes();
hgs
parents:
diff changeset
   424
			}
hgs
parents:
diff changeset
   425
		else
hgs
parents:
diff changeset
   426
			{
hgs
parents:
diff changeset
   427
			sess->SendError() = aError;
hgs
parents:
diff changeset
   428
			}
hgs
parents:
diff changeset
   429
hgs
parents:
diff changeset
   430
		--sess->NumRemotesToTry();
hgs
parents:
diff changeset
   431
		if (sess->NumRemotesToTry() == 0)
hgs
parents:
diff changeset
   432
			{
hgs
parents:
diff changeset
   433
			CompleteMessageForSession(aMessage, *sess);
hgs
parents:
diff changeset
   434
			}
hgs
parents:
diff changeset
   435
		}
hgs
parents:
diff changeset
   436
	}
hgs
parents:
diff changeset
   437
hgs
parents:
diff changeset
   438
void CRemConTargetClientProcess::MrcmsoMessageSendOneOrMoreAbandoned(const CRemConMessage& aMessage)
hgs
parents:
diff changeset
   439
	{
hgs
parents:
diff changeset
   440
	LOG_FUNC
hgs
parents:
diff changeset
   441
	
hgs
parents:
diff changeset
   442
	// Notifications should not be received for reject messages, as the client did not request these be sent.
hgs
parents:
diff changeset
   443
	ASSERT_DEBUG(aMessage.MsgType() != ERemConReject);
hgs
parents:
diff changeset
   444
hgs
parents:
diff changeset
   445
	// Find session and notify
hgs
parents:
diff changeset
   446
	CRemConTargetSession* sess = FindSessionForMessage(aMessage);
hgs
parents:
diff changeset
   447
	ASSERT_DEBUG(sess);
hgs
parents:
diff changeset
   448
	
hgs
parents:
diff changeset
   449
	// Ignore notification if client has been completed
hgs
parents:
diff changeset
   450
	if (sess->NumRemotesToTry() > 0)
hgs
parents:
diff changeset
   451
		{
hgs
parents:
diff changeset
   452
		// Do not adjust NumRemotes() as the message was not sent (but we still don't error the client!)
hgs
parents:
diff changeset
   453
		--sess->NumRemotesToTry();
hgs
parents:
diff changeset
   454
		if (sess->NumRemotesToTry() == 0)
hgs
parents:
diff changeset
   455
			{
hgs
parents:
diff changeset
   456
			CompleteMessageForSession(aMessage, *sess);
hgs
parents:
diff changeset
   457
			}
hgs
parents:
diff changeset
   458
		}
hgs
parents:
diff changeset
   459
	}