remotecontrol/avrcp/remconbeareravrcp/src/avrcpfragmenter.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) 2007-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
20ac952a623c 201040_02
hgs
parents:
diff changeset
    17
20ac952a623c 201040_02
hgs
parents:
diff changeset
    18
/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    19
 @file
20ac952a623c 201040_02
hgs
parents:
diff changeset
    20
 @internalComponent
20ac952a623c 201040_02
hgs
parents:
diff changeset
    21
 @released
20ac952a623c 201040_02
hgs
parents:
diff changeset
    22
*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    23
20ac952a623c 201040_02
hgs
parents:
diff changeset
    24
#include "avrcpfragmenter.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    25
#include "controlcommand.h"
20ac952a623c 201040_02
hgs
parents:
diff changeset
    26
#include <e32debug.h>
20ac952a623c 201040_02
hgs
parents:
diff changeset
    27
20ac952a623c 201040_02
hgs
parents:
diff changeset
    28
// Maximum size of data in a fragment response
20ac952a623c 201040_02
hgs
parents:
diff changeset
    29
static const int KFragmentDataLength = KAVCMaxVendorDependentPayload - KAVRCPMinVendorDependentResponseLen;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    30
20ac952a623c 201040_02
hgs
parents:
diff changeset
    31
20ac952a623c 201040_02
hgs
parents:
diff changeset
    32
CAVRCPFragmenter* CAVRCPFragmenter::NewL()
20ac952a623c 201040_02
hgs
parents:
diff changeset
    33
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    34
	CAVRCPFragmenter* self = new (ELeave) CAVRCPFragmenter();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    35
	self->Construct();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    36
	return self;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    37
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    38
20ac952a623c 201040_02
hgs
parents:
diff changeset
    39
TBool CAVRCPFragmenter::InFragmentedState()
20ac952a623c 201040_02
hgs
parents:
diff changeset
    40
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    41
	return iInFragmentedState;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    42
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    43
20ac952a623c 201040_02
hgs
parents:
diff changeset
    44
void CAVRCPFragmenter::Reset()
20ac952a623c 201040_02
hgs
parents:
diff changeset
    45
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    46
	iStart = KAVRCPMinVendorDependentResponseLen;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    47
	iInFragmentedState = EFalse;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    48
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    49
20ac952a623c 201040_02
hgs
parents:
diff changeset
    50
void CAVRCPFragmenter::AssignPayload(const RBuf8& aPayload)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    51
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    52
	// Assign the allocated memory containing the reponse to
20ac952a623c 201040_02
hgs
parents:
diff changeset
    53
	// this class, allowing the caller to Close() aPayload.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    54
	iPayload.Close();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    55
	iPayload.Assign(aPayload);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    56
	iInFragmentedState = ETrue;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    57
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    58
20ac952a623c 201040_02
hgs
parents:
diff changeset
    59
TPtr8 CAVRCPFragmenter::GetNextFragmentHeader()
20ac952a623c 201040_02
hgs
parents:
diff changeset
    60
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    61
	if (! InFragmentedState())
20ac952a623c 201040_02
hgs
parents:
diff changeset
    62
		return TPtr8(0,0,0);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    63
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
    64
	// Fragmentation byte is 2nd byte of response; poke this
20ac952a623c 201040_02
hgs
parents:
diff changeset
    65
	// and set the length correctly
20ac952a623c 201040_02
hgs
parents:
diff changeset
    66
	if (iStart == KAVRCPMinVendorDependentResponseLen)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    67
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    68
		iPayload[1] = EFragmentStart;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    69
		iPayload[2] = (KFragmentDataLength >> 8) & 0xff;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    70
		iPayload[3] = (KFragmentDataLength) & 0xff;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    71
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    72
	else if (LastFragment())
20ac952a623c 201040_02
hgs
parents:
diff changeset
    73
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    74
		iPayload[1] = EFragmentEnd;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    75
		TInt length = iPayload.Length() - iStart;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    76
		iPayload[2] = (length >> 8) & 0xff;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    77
		iPayload[3] = (length) & 0xff;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    78
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    79
	else
20ac952a623c 201040_02
hgs
parents:
diff changeset
    80
		{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    81
		iPayload[1] = EFragmentContinue;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    82
		iPayload[2] = (KFragmentDataLength >> 8) & 0xff;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    83
		iPayload[3] = (KFragmentDataLength) & 0xff;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    84
		}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    85
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
    86
	// Return the first 4 bytes, which contain the PDU id,
20ac952a623c 201040_02
hgs
parents:
diff changeset
    87
	// fragmentation status and parameter length (2 bytes)
20ac952a623c 201040_02
hgs
parents:
diff changeset
    88
	return iPayload.MidTPtr(0, KAVRCPMinVendorDependentResponseLen);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    89
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
    90
20ac952a623c 201040_02
hgs
parents:
diff changeset
    91
TPtr8 CAVRCPFragmenter::GetNextFragment()
20ac952a623c 201040_02
hgs
parents:
diff changeset
    92
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    93
	if (! InFragmentedState())
20ac952a623c 201040_02
hgs
parents:
diff changeset
    94
		return TPtr8(0,0,0);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    95
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
    96
	// Sigh. MidTPtr() PANICs if the 2nd argument is too large.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    97
	// Other APIs (e.g. Java, STL) just return to end of string.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    98
	TInt fragmentSize = KFragmentDataLength;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    99
	if (LastFragment())
20ac952a623c 201040_02
hgs
parents:
diff changeset
   100
		fragmentSize = iPayload.Length() - iStart;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   101
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
   102
	TPtr8 fragment = iPayload.MidTPtr(iStart, fragmentSize);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   103
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
   104
	if (LastFragment())
20ac952a623c 201040_02
hgs
parents:
diff changeset
   105
		Reset();
20ac952a623c 201040_02
hgs
parents:
diff changeset
   106
	else
20ac952a623c 201040_02
hgs
parents:
diff changeset
   107
		iStart += fragmentSize;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   108
	return fragment;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   109
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   110
20ac952a623c 201040_02
hgs
parents:
diff changeset
   111
TBool CAVRCPFragmenter::LastFragment()
20ac952a623c 201040_02
hgs
parents:
diff changeset
   112
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   113
	if (iStart + KFragmentDataLength > iPayload.Length())
20ac952a623c 201040_02
hgs
parents:
diff changeset
   114
		return ETrue;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   115
	else
20ac952a623c 201040_02
hgs
parents:
diff changeset
   116
		return EFalse;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   117
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   118
20ac952a623c 201040_02
hgs
parents:
diff changeset
   119
TInt CAVRCPFragmenter::GetPDU()
20ac952a623c 201040_02
hgs
parents:
diff changeset
   120
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   121
	return iPayload[0];
20ac952a623c 201040_02
hgs
parents:
diff changeset
   122
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   123
20ac952a623c 201040_02
hgs
parents:
diff changeset
   124
void CAVRCPFragmenter::Construct()
20ac952a623c 201040_02
hgs
parents:
diff changeset
   125
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   126
	Reset();
20ac952a623c 201040_02
hgs
parents:
diff changeset
   127
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   128