bluetoothappprofiles/avrcp/remconbeareravrcp/src/avrcpfragmenter.cpp
changeset 0 f63038272f30
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/bluetoothappprofiles/avrcp/remconbeareravrcp/src/avrcpfragmenter.cpp	Mon Jan 18 20:28:57 2010 +0200
@@ -0,0 +1,128 @@
+// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+//
+
+
+
+/**
+ @file
+ @internalComponent
+ @released
+*/
+
+#include "avrcpfragmenter.h"
+#include "controlcommand.h"
+#include <e32debug.h>
+
+// Maximum size of data in a fragment response
+static const int KFragmentDataLength = KAVCMaxVendorDependentPayload - KAVRCPMinVendorDependentResponseLen;
+
+
+CAVRCPFragmenter* CAVRCPFragmenter::NewL()
+	{
+	CAVRCPFragmenter* self = new (ELeave) CAVRCPFragmenter();
+	self->Construct();
+	return self;
+	}
+
+TBool CAVRCPFragmenter::InFragmentedState()
+	{
+	return iInFragmentedState;
+	}
+
+void CAVRCPFragmenter::Reset()
+	{
+	iStart = KAVRCPMinVendorDependentResponseLen;
+	iInFragmentedState = EFalse;
+	}
+
+void CAVRCPFragmenter::AssignPayload(const RBuf8& aPayload)
+	{
+	// Assign the allocated memory containing the reponse to
+	// this class, allowing the caller to Close() aPayload.
+	iPayload.Close();
+	iPayload.Assign(aPayload);
+	iInFragmentedState = ETrue;
+	}
+
+TPtr8 CAVRCPFragmenter::GetNextFragmentHeader()
+	{
+	if (! InFragmentedState())
+		return TPtr8(0,0,0);
+	
+	// Fragmentation byte is 2nd byte of response; poke this
+	// and set the length correctly
+	if (iStart == KAVRCPMinVendorDependentResponseLen)
+		{
+		iPayload[1] = EFragmentStart;
+		iPayload[2] = (KFragmentDataLength >> 8) & 0xff;
+		iPayload[3] = (KFragmentDataLength) & 0xff;
+		}
+	else if (LastFragment())
+		{
+		iPayload[1] = EFragmentEnd;
+		TInt length = iPayload.Length() - iStart;
+		iPayload[2] = (length >> 8) & 0xff;
+		iPayload[3] = (length) & 0xff;
+		}
+	else
+		{
+		iPayload[1] = EFragmentContinue;
+		iPayload[2] = (KFragmentDataLength >> 8) & 0xff;
+		iPayload[3] = (KFragmentDataLength) & 0xff;
+		}
+	
+	// Return the first 4 bytes, which contain the PDU id,
+	// fragmentation status and parameter length (2 bytes)
+	return iPayload.MidTPtr(0, KAVRCPMinVendorDependentResponseLen);
+	}
+
+TPtr8 CAVRCPFragmenter::GetNextFragment()
+	{
+	if (! InFragmentedState())
+		return TPtr8(0,0,0);
+	
+	// Sigh. MidTPtr() PANICs if the 2nd argument is too large.
+	// Other APIs (e.g. Java, STL) just return to end of string.
+	TInt fragmentSize = KFragmentDataLength;
+	if (LastFragment())
+		fragmentSize = iPayload.Length() - iStart;
+	
+	TPtr8 fragment = iPayload.MidTPtr(iStart, fragmentSize);
+	
+	if (LastFragment())
+		Reset();
+	else
+		iStart += fragmentSize;
+	return fragment;
+	}
+
+TBool CAVRCPFragmenter::LastFragment()
+	{
+	if (iStart + KFragmentDataLength > iPayload.Length())
+		return ETrue;
+	else
+		return EFalse;
+	}
+
+TInt CAVRCPFragmenter::GetPDU()
+	{
+	return iPayload[0];
+	}
+
+void CAVRCPFragmenter::Construct()
+	{
+	Reset();
+	}
+