remotecontrol/avrcp/remconbeareravrcp/src/playerstatewatcher.cpp
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-2009 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
//
20ac952a623c 201040_02
hgs
parents:
diff changeset
    15
20ac952a623c 201040_02
hgs
parents:
diff changeset
    16
#include "mediabrowse.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    17
#include "avrcputils.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    18
#include "commandhandlerinterface.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    19
#include "internalcommand.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    20
#include "mediabrowse.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    21
#include "playerstatewatcher.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    22
#include "remconcommandinterface.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    23
#include "avrcplog.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    24
#include "playerinformation.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    25
20ac952a623c 201040_02
hgs
parents:
diff changeset
    26
CPlayerWatcherBase::CPlayerWatcherBase(MRemConCommandInterface& aCommandInterface)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    27
	: iCommandInterface(aCommandInterface), iCommands()
20ac952a623c 201040_02
hgs
parents:
diff changeset
    28
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    29
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    30
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    31
20ac952a623c 201040_02
hgs
parents:
diff changeset
    32
CPlayerWatcherBase::~CPlayerWatcherBase()
20ac952a623c 201040_02
hgs
parents:
diff changeset
    33
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    34
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    35
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    36
20ac952a623c 201040_02
hgs
parents:
diff changeset
    37
void CPlayerWatcherBase::StopWatchingPlayer(TRemConClientId aClientId)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    38
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    39
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    40
	CInternalCommand** cmdPtr = iCommands.Find(aClientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    41
	if (cmdPtr) // This may be NULL if we've already stopped watching the player as a result of reciving a reject
20ac952a623c 201040_02
hgs
parents:
diff changeset
    42
	    {
20ac952a623c 201040_02
hgs
parents:
diff changeset
    43
        CInternalCommand* cmd = *cmdPtr;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    44
        
20ac952a623c 201040_02
hgs
parents:
diff changeset
    45
        TUint transId = cmd->RemConCommandId();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    46
        iCommandInterface.MrcciCommandExpired(transId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    47
    
20ac952a623c 201040_02
hgs
parents:
diff changeset
    48
        iCommands.Remove(aClientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    49
        cmd->DecrementUsers();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    50
	    }
20ac952a623c 201040_02
hgs
parents:
diff changeset
    51
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    52
20ac952a623c 201040_02
hgs
parents:
diff changeset
    53
void CPlayerWatcherBase::MessageSent(CAvrcpCommand& /*aCommand*/, TInt /*aSendResult*/)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    54
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    55
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    56
	__DEBUG_ONLY(AVRCP_PANIC(ELowerInterfaceUsedOnInternalHandler));
20ac952a623c 201040_02
hgs
parents:
diff changeset
    57
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    58
20ac952a623c 201040_02
hgs
parents:
diff changeset
    59
void CPlayerWatcherBase::MaxPacketSize(TInt /*aMtu*/)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    60
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    61
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    62
	__DEBUG_ONLY(AVRCP_PANIC(ELowerInterfaceUsedOnInternalHandler));
20ac952a623c 201040_02
hgs
parents:
diff changeset
    63
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    64
20ac952a623c 201040_02
hgs
parents:
diff changeset
    65
void CPlayerWatcherBase::ReceiveCommandL(const TDesC8& /*aMessageInformation*/, SymbianAvctp::TTransactionLabel /*aTransLabel*/, const TBTDevAddr& /*aAddr*/)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    66
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    67
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    68
	__DEBUG_ONLY(AVRCP_PANIC(ELowerInterfaceUsedOnInternalHandler));
20ac952a623c 201040_02
hgs
parents:
diff changeset
    69
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    70
20ac952a623c 201040_02
hgs
parents:
diff changeset
    71
CInternalCommand& CPlayerWatcherBase::FindCommand(TUid __DEBUG_ONLY(aInterfaceUid),
20ac952a623c 201040_02
hgs
parents:
diff changeset
    72
		TUint aTransactionId, TRemConClientId& aFoundClientId)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    73
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    74
	__ASSERT_DEBUG(aInterfaceUid == TUid::Uid(KRemConPlayerInformationUid) || aInterfaceUid == TUid::Uid(KRemConMediaBrowseApiUid), AVRCP_PANIC(EResponseForWrongInterface));
20ac952a623c 201040_02
hgs
parents:
diff changeset
    75
	THashMapIter<TRemConClientId, CInternalCommand*> commandIter(iCommands);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    76
20ac952a623c 201040_02
hgs
parents:
diff changeset
    77
	CInternalCommand* command = NULL;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    78
	while(commandIter.NextValue())
20ac952a623c 201040_02
hgs
parents:
diff changeset
    79
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    80
		command = *commandIter.CurrentValue();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    81
		if(command->RemConCommandId() == aTransactionId)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    82
			{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    83
			aFoundClientId = *commandIter.CurrentKey();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    84
			break;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    85
			}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    86
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    87
20ac952a623c 201040_02
hgs
parents:
diff changeset
    88
	// If command is NULL we reached the end of our iter without finding the match
20ac952a623c 201040_02
hgs
parents:
diff changeset
    89
	__ASSERT_DEBUG(command, AVRCP_PANIC(EUnmatchedResponseFromRemCon));
20ac952a623c 201040_02
hgs
parents:
diff changeset
    90
20ac952a623c 201040_02
hgs
parents:
diff changeset
    91
	return *command;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    92
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    93
20ac952a623c 201040_02
hgs
parents:
diff changeset
    94
TInt CPlayerWatcherBase::SendRemConResponse(TUid aInterfaceUid, TUint aTransactionId, RBuf8& aData)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    95
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    96
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    97
20ac952a623c 201040_02
hgs
parents:
diff changeset
    98
	TRemConClientId clientId;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    99
	CInternalCommand& command = FindCommand(aInterfaceUid, aTransactionId, clientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   100
20ac952a623c 201040_02
hgs
parents:
diff changeset
   101
	ReceiveUpdate(command, clientId, aData);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   102
20ac952a623c 201040_02
hgs
parents:
diff changeset
   103
	return KErrNone;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   104
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   105
20ac952a623c 201040_02
hgs
parents:
diff changeset
   106
void CPlayerWatcherBase::SendReject(TUid aInterfaceUid, TUint aTransactionId)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   107
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   108
	TRemConClientId clientId;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   109
	(void)FindCommand(aInterfaceUid, aTransactionId, clientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   110
20ac952a623c 201040_02
hgs
parents:
diff changeset
   111
	ReceiveReject(clientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   112
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   113
20ac952a623c 201040_02
hgs
parents:
diff changeset
   114
void CPlayerWatcherBase::Disconnect()
20ac952a623c 201040_02
hgs
parents:
diff changeset
   115
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   116
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   117
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   118
20ac952a623c 201040_02
hgs
parents:
diff changeset
   119
CPlayStatusWatcher* CPlayStatusWatcher::NewL(MPlayStatusObserver& aObserver, MRemConCommandInterface& aCommandInterface)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   120
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   121
	LOG_STATIC_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   122
	CPlayStatusWatcher* watcher = new(ELeave)CPlayStatusWatcher(aObserver, aCommandInterface);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   123
	return watcher;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   124
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   125
20ac952a623c 201040_02
hgs
parents:
diff changeset
   126
CPlayStatusWatcher::CPlayStatusWatcher(MPlayStatusObserver& aObserver,
20ac952a623c 201040_02
hgs
parents:
diff changeset
   127
		MRemConCommandInterface& aCommandInterface)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   128
	: CPlayerWatcherBase(aCommandInterface), iObserver(aObserver)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   129
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   130
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   131
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   132
20ac952a623c 201040_02
hgs
parents:
diff changeset
   133
CPlayStatusWatcher::~CPlayStatusWatcher()
20ac952a623c 201040_02
hgs
parents:
diff changeset
   134
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   135
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   136
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   137
20ac952a623c 201040_02
hgs
parents:
diff changeset
   138
void CPlayStatusWatcher::StartWatchingPlayerL(TRemConClientId aClientId)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   139
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   140
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   141
	__ASSERT_DEBUG(!iCommands.Find(aClientId), AVRCP_PANIC(EAlreadyWatchingPlayer));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   142
20ac952a623c 201040_02
hgs
parents:
diff changeset
   143
	CInternalCommand* command = CInternalCommand::NewL(TUid::Uid(KRemConPlayerInformationUid),
20ac952a623c 201040_02
hgs
parents:
diff changeset
   144
			0,
20ac952a623c 201040_02
hgs
parents:
diff changeset
   145
			EGetPlayStatusUpdate,
20ac952a623c 201040_02
hgs
parents:
diff changeset
   146
			KNullDesC8);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   147
20ac952a623c 201040_02
hgs
parents:
diff changeset
   148
	CleanupStack::PushL(command);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   149
	iCommands.InsertL(aClientId, command);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   150
	CleanupStack::Pop(command);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   151
	command->IncrementUsers();
20ac952a623c 201040_02
hgs
parents:
diff changeset
   152
20ac952a623c 201040_02
hgs
parents:
diff changeset
   153
	// Initially request uid notification relative to stopped
20ac952a623c 201040_02
hgs
parents:
diff changeset
   154
	SendPlayStatusUpdateRequest(*command, aClientId, MPlayerEventsObserver::EStopped);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   155
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   156
20ac952a623c 201040_02
hgs
parents:
diff changeset
   157
void CPlayStatusWatcher::SendPlayStatusUpdateRequest(CInternalCommand& aCommand, TRemConClientId& aClientId, MPlayerEventsObserver::TPlaybackStatus aPlaybackStatus)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   158
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   159
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   160
20ac952a623c 201040_02
hgs
parents:
diff changeset
   161
	RRemConPlayerInformationGetPlayStatusUpdateRequest request;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   162
	request.iStatus = aPlaybackStatus;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   163
20ac952a623c 201040_02
hgs
parents:
diff changeset
   164
	TBuf8<sizeof(MPlayerEventsObserver::TPlaybackStatus)> buf;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   165
	TRAPD(err, request.WriteL(buf));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   166
20ac952a623c 201040_02
hgs
parents:
diff changeset
   167
	// We know how big the request is so this should never fail
20ac952a623c 201040_02
hgs
parents:
diff changeset
   168
	__ASSERT_DEBUG(err == KErrNone, AVRCP_PANIC(EUidUpdateRequestWriteFailure));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   169
20ac952a623c 201040_02
hgs
parents:
diff changeset
   170
	TUint transId = iCommandInterface.MrcciNewTransactionId();
20ac952a623c 201040_02
hgs
parents:
diff changeset
   171
	TRAP(err, aCommand.ResetL(transId, buf));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   172
20ac952a623c 201040_02
hgs
parents:
diff changeset
   173
	if(err == KErrNone)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   174
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   175
		iCommandInterface.MrcciNewCommand(aCommand, aClientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   176
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   177
	else
20ac952a623c 201040_02
hgs
parents:
diff changeset
   178
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   179
		// Doom
20ac952a623c 201040_02
hgs
parents:
diff changeset
   180
		iObserver.MpsoError(aClientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   181
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   182
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   183
20ac952a623c 201040_02
hgs
parents:
diff changeset
   184
void CPlayStatusWatcher::ReceiveUpdate(CInternalCommand& aCommand, TRemConClientId aClientId, RBuf8& aData)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   185
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   186
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   187
20ac952a623c 201040_02
hgs
parents:
diff changeset
   188
	// Read 4 byte Big-Endian error code before the payload
20ac952a623c 201040_02
hgs
parents:
diff changeset
   189
	RAvrcpIPCError errorResponse;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   190
	TRAPD(err, errorResponse.ReadL(aData));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   191
	err = err ? err : errorResponse.iError;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   192
20ac952a623c 201040_02
hgs
parents:
diff changeset
   193
	RRemConPlayerInformationGetPlayStatusUpdateResponse response;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   194
	if(!err)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   195
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   196
		// Parse the rest of the response (minus error code)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   197
		TRAP(err, response.ReadL(aData.RightTPtr(aData.Length() - KLengthErrorResponse)));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   198
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   199
20ac952a623c 201040_02
hgs
parents:
diff changeset
   200
	aData.Close(); // data has been used now
20ac952a623c 201040_02
hgs
parents:
diff changeset
   201
20ac952a623c 201040_02
hgs
parents:
diff changeset
   202
	if(!err)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   203
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   204
		iObserver.MpsoPlayStatusChanged(aClientId, response.iStatus);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   205
		SendPlayStatusUpdateRequest(aCommand, aClientId, response.iStatus);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   206
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   207
	else
20ac952a623c 201040_02
hgs
parents:
diff changeset
   208
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   209
		// Should never get here with a valid player.  This client is
20ac952a623c 201040_02
hgs
parents:
diff changeset
   210
		// sending us junk.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   211
		iObserver.MpsoError(aClientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   212
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   213
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   214
20ac952a623c 201040_02
hgs
parents:
diff changeset
   215
void CPlayStatusWatcher::ReceiveReject(TRemConClientId aClientId)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   216
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   217
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   218
	iObserver.MpsoError(aClientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   219
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   220
20ac952a623c 201040_02
hgs
parents:
diff changeset
   221
CUidWatcher* CUidWatcher::NewL(MUidObserver& aObserver,
20ac952a623c 201040_02
hgs
parents:
diff changeset
   222
		MRemConCommandInterface& aCommandInterface)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   223
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   224
	LOG_STATIC_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   225
	CUidWatcher* watcher = new(ELeave)CUidWatcher(aObserver, aCommandInterface);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   226
	return watcher;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   227
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   228
20ac952a623c 201040_02
hgs
parents:
diff changeset
   229
CUidWatcher::CUidWatcher(MUidObserver& aObserver,
20ac952a623c 201040_02
hgs
parents:
diff changeset
   230
		MRemConCommandInterface& aCommandInterface)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   231
	: CPlayerWatcherBase(aCommandInterface), iObserver(aObserver)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   232
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   233
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   234
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   235
20ac952a623c 201040_02
hgs
parents:
diff changeset
   236
CUidWatcher::~CUidWatcher()
20ac952a623c 201040_02
hgs
parents:
diff changeset
   237
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   238
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   239
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   240
20ac952a623c 201040_02
hgs
parents:
diff changeset
   241
void CUidWatcher::StartWatchingPlayerL(TRemConClientId aClientId)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   242
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   243
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   244
	__ASSERT_DEBUG(!iCommands.Find(aClientId), AVRCP_PANIC(EAlreadyWatchingPlayer));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   245
20ac952a623c 201040_02
hgs
parents:
diff changeset
   246
	CInternalCommand* command = CInternalCommand::NewL(TUid::Uid(KRemConMediaBrowseApiUid),
20ac952a623c 201040_02
hgs
parents:
diff changeset
   247
			0,
20ac952a623c 201040_02
hgs
parents:
diff changeset
   248
			EMediaLibraryStateCookieUpdateOperationId,
20ac952a623c 201040_02
hgs
parents:
diff changeset
   249
			KNullDesC8);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   250
20ac952a623c 201040_02
hgs
parents:
diff changeset
   251
	CleanupStack::PushL(command);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   252
	iCommands.InsertL(aClientId, command);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   253
	CleanupStack::Pop(command);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   254
	command->IncrementUsers();
20ac952a623c 201040_02
hgs
parents:
diff changeset
   255
20ac952a623c 201040_02
hgs
parents:
diff changeset
   256
	// Initially request uid notification relative to 0 uid counter
20ac952a623c 201040_02
hgs
parents:
diff changeset
   257
	SendUidUpdateRequest(*command, aClientId, 0);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   258
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   259
20ac952a623c 201040_02
hgs
parents:
diff changeset
   260
void CUidWatcher::SendUidUpdateRequest(CInternalCommand& aCommand, TRemConClientId& aClientId, TUint16 aUidCounter)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   261
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   262
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   263
	RRemConUidsChangedRequest request;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   264
	request.iInitialUidCounter = aUidCounter;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   265
	TBuf8<sizeof(TUint16)> buf;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   266
	TRAPD(err, request.WriteL(buf));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   267
	// We know how big the request is so this should never fail
20ac952a623c 201040_02
hgs
parents:
diff changeset
   268
	__ASSERT_DEBUG(err == KErrNone, AVRCP_PANIC(EUidUpdateRequestWriteFailure));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   269
20ac952a623c 201040_02
hgs
parents:
diff changeset
   270
	TUint transId = iCommandInterface.MrcciNewTransactionId();
20ac952a623c 201040_02
hgs
parents:
diff changeset
   271
	TRAP(err, aCommand.ResetL(transId, buf));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   272
20ac952a623c 201040_02
hgs
parents:
diff changeset
   273
	if(err == KErrNone)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   274
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   275
		iCommandInterface.MrcciNewCommand(aCommand, aClientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   276
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   277
	else
20ac952a623c 201040_02
hgs
parents:
diff changeset
   278
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   279
		// Doom
20ac952a623c 201040_02
hgs
parents:
diff changeset
   280
		iObserver.MuoError(aClientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   281
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   282
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   283
20ac952a623c 201040_02
hgs
parents:
diff changeset
   284
void CUidWatcher::ReceiveUpdate(CInternalCommand& aCommand, TRemConClientId aClientId, RBuf8& aData)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   285
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   286
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   287
	RRemConUidsChangedResponse response;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   288
	TRAPD(err, response.ReadL(aData));
20ac952a623c 201040_02
hgs
parents:
diff changeset
   289
	aData.Close(); // data has been used now
20ac952a623c 201040_02
hgs
parents:
diff changeset
   290
20ac952a623c 201040_02
hgs
parents:
diff changeset
   291
	if(!err)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   292
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   293
		iObserver.MuoUidChanged(aClientId, response.iUidCounter);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   294
		SendUidUpdateRequest(aCommand, aClientId, response.iUidCounter);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   295
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   296
	else
20ac952a623c 201040_02
hgs
parents:
diff changeset
   297
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   298
		// Should never get here with a valid player.  This client is
20ac952a623c 201040_02
hgs
parents:
diff changeset
   299
		// sending us junk.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   300
		iObserver.MuoError(aClientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   301
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   302
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   303
20ac952a623c 201040_02
hgs
parents:
diff changeset
   304
void CUidWatcher::ReceiveReject(TRemConClientId aClientId)
20ac952a623c 201040_02
hgs
parents:
diff changeset
   305
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   306
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   307
	iObserver.MuoError(aClientId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   308
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   309
20ac952a623c 201040_02
hgs
parents:
diff changeset
   310
20ac952a623c 201040_02
hgs
parents:
diff changeset
   311