contentmgmt/contentaccessfwfordrm/source/cafutils/cafmimeheader.cpp
author savpatil@2INL09984
Thu, 08 Oct 2009 14:59:39 +0530
changeset 11 9d767430696e
parent 8 35751d3474b7
permissions -rw-r--r--
Merged in changes from the tip of RCL_1 branch which includes fixes for Bug 284, Bug 383, Bug 287. These were wiped out from when the S^3 code drop came in.

/*
* Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "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: 
*
*/


#ifndef REMOVE_CAF1

#include <caf/caftypes.h>
#include <s32strm.h>
#include <caf/cafmimeheader.h>
#include "mimefieldanddata.h"

using namespace ContentAccess;

EXPORT_C CCafMimeHeader* CCafMimeHeader::NewL(const TDesC8 &aContentType)
	{
	CCafMimeHeader *self = new (ELeave) CCafMimeHeader();
	CleanupStack::PushL(self);
	self->ConstructL(aContentType);
	CleanupStack::Pop(self);
	return self;
	}

CCafMimeHeader::CCafMimeHeader() 
	{
	}

void CCafMimeHeader::ConstructL(const TDesC8 &aContentType) 
	{
	SetStandardMimeDataL(EContentType, aContentType);
	}

EXPORT_C CCafMimeHeader::~CCafMimeHeader()
	{
	TInt i=0;
	iNonStandardMimeHeaders.ResetAndDestroy();
	iNonStandardMimeHeaders.Close();
	
	for(i = 0; i < EMimeMax; i++)
		{
		delete iStandardMimeHeader[i];
		}
	}

EXPORT_C void CCafMimeHeader::SetStandardMimeDataL(const TMimeFields &aIndex, const TDesC8& aData)
	{
	HBufC8 *data = aData.AllocLC();

	// make sure mime types are lower case
	if(aIndex == EContentType)
		{
		data->Des().LowerCase();
		}
	
	// replace whatever value was there before
	delete iStandardMimeHeader[aIndex];
	iStandardMimeHeader[aIndex] = data;
		
	CleanupStack::Pop(data); 
	}

EXPORT_C TPtrC8 CCafMimeHeader::StandardMimeData(const TMimeFields &aIndex) const
	{
	// If the field value has not been set, return a null string
	if(iStandardMimeHeader[aIndex] == NULL)
		{
		return KNullDesC8();
		}
	return TPtrC8(iStandardMimeHeader[aIndex]->Des());
	}


EXPORT_C TInt CCafMimeHeader::NonStandardMimeCount() const
	{
	return iNonStandardMimeHeaders.Count();
	}

EXPORT_C void CCafMimeHeader::AddNonStandardMimeL(const TDesC8& aFieldName, const TDesC8& aData)
	{
	CMimeFieldAndData *mimeData = CMimeFieldAndData::NewL(aFieldName, aData);
	CleanupStack::PushL(mimeData);
	iNonStandardMimeHeaders.Append(mimeData);
	CleanupStack::Pop(mimeData);
	}

EXPORT_C TPtrC8 CCafMimeHeader::NonStandardMimeField(TInt aIndex) const
	{
	return iNonStandardMimeHeaders[aIndex]->FieldName();
	}

EXPORT_C TPtrC8 CCafMimeHeader::NonStandardMimeData(TInt aIndex) const
	{
	return iNonStandardMimeHeaders[aIndex]->Data();
	}

EXPORT_C void CCafMimeHeader::ExternalizeL(RWriteStream& aStream) const
	{
	TInt i=0;
	
	// Write the contents of this class out to a stream

	// Write the number of standard mime headers
	aStream.WriteInt32L(EMimeMax);
	
	// Write out the standard mime data, each one preceeded by it's length
	for(i = 0; i < EMimeMax; i++)
		{
		TInt length=0;
		
		// Length is zero if the mime field has not been set, 
		if(iStandardMimeHeader[i] == NULL)
			{
			length = 0;
			}
		else 
			{
			length = iStandardMimeHeader[i]->Length();
			}

		// write the field length
		aStream.WriteInt16L(length);
		if(length > 0)
			{
			// write the field value if length > 0
			aStream.WriteL(*iStandardMimeHeader[i]);
			}
		}

	aStream.WriteInt32L(iNonStandardMimeHeaders.Count());

	// Write out non standard mime headers and data, each Des preceeded by it's length
	for(i = 0; i < iNonStandardMimeHeaders.Count(); i++)
		{
		aStream.WriteInt16L(iNonStandardMimeHeaders[i]->FieldName().Length());
		if(iNonStandardMimeHeaders[i]->FieldName().Length() > 0)
			{
			aStream.WriteL(iNonStandardMimeHeaders[i]->FieldName());
			}
		aStream.WriteInt16L(iNonStandardMimeHeaders[i]->Data().Length());
		if(iNonStandardMimeHeaders[i]->Data().Length() > 0)
			{
			aStream.WriteL(iNonStandardMimeHeaders[i]->Data());
			}
		}
	}

EXPORT_C void CCafMimeHeader::InternalizeL(RReadStream& aStream)
	{
	TInt i=0;
	TInt fieldCount=0;
	TInt16 length=0;
	HBufC8 *field=NULL;
	HBufC8 *data=NULL;
	

	// clear any existing headers	
	iNonStandardMimeHeaders.ResetAndDestroy();
	for(i = 0; i < EMimeMax; i++)
		{
		// delete the existing data for the mime field
		delete iStandardMimeHeader[i];
		iStandardMimeHeader[i] = NULL;
		}


	fieldCount= aStream.ReadInt32L();
	if(fieldCount != EMimeMax)
		{
		// something is seriously wrong, should always be EMimeMax standard headers
		User::Leave(KErrGeneral);
		}
	
	for(i = 0; i < EMimeMax; i++)
		{
		// read the length from the stream
		length = aStream.ReadInt16L();
		if(length > 0)
			{
			// read in non zero fields, others will remain NULL
			data = HBufC8::NewLC(length);
			TPtr8 dataPtr = data->Des();
			aStream.ReadL(dataPtr,length);
			SetStandardMimeDataL(static_cast <TMimeFields>(i), dataPtr);
			CleanupStack::PopAndDestroy(data);
			}
		}

	fieldCount= aStream.ReadInt32L();

	for(i = 0; i < fieldCount; i++)
		{
		// Read mime field name
		length = aStream.ReadInt16L();
		if(length < 0)
			{
			User::Leave(KErrCorrupt);
			}

		field = HBufC8::NewLC(length);
		TPtr8 fieldPtr = field->Des();
		if(length > 0)
			{
			aStream.ReadL(fieldPtr,length);
			}
		
		// Read data
		length = aStream.ReadInt16L();
		if(length < 0)
			{
			User::Leave(KErrCorrupt);
			}

		data = HBufC8::NewLC(length);
		TPtr8 dataPtr = data->Des();
		if(length > 0)
			{
			aStream.ReadL(dataPtr,length);
			}

		// Add a new mime field and data to our array
		AddNonStandardMimeL(fieldPtr, dataPtr);

		// free memory allocated
		CleanupStack::PopAndDestroy(data);
		CleanupStack::PopAndDestroy(field); 
		}
	}


#endif // #ifndef REMOVE_CAF1