Msrp/MsrpHeader/inc/CMsrpByteRangeHeader.h
author shivsood
Sat, 12 Jun 2010 14:30:11 +0530
branchMSRP_FrameWork
changeset 25 505ad3f0ce5c
permissions -rw-r--r--
MSRP Chat and File Sharing FrameWork - Initial Contribution from Nokia. MSRP Implementation as per RFC 4975 and RCS specifications that supports 1. Multiple one to one chat data sessions as per RCS/RFC 4975 specifications. 2. Multiple file Sharing sessions as per RCS. 3. Data Chunking requirements as per 4975. 3. MSRP Connection sharing requirements as per RFC 4975

/*
* Copyright (c) 2009-2010 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:
* MSRP Implementation
*
*/


#ifndef CMSRPBYTERANGEHEADER_H
#define CMSRPBYTERANGEHEADER_H

// INTERNAL INCLUDES
#include "CMsrpHeaderBase.h"

// CONSTANTS

const TInt KMaxLengthOfNumbers = 50;
_LIT8( KByteRangeSeparator, "-" );
_LIT8( KByteRangeTotalSeparator, "/" );

// CLASS DECLARATION
/**
* @publishedAll
*
* Class provides functions for setting and getting MSRP "Byte-Range" header field
*
* @lib msrpclient.lib
*/
class CMSRPByteRangeHeader : public CMSRPHeaderBase
	{
	public:	// Constructors and destructor

		/**
		* Creates a new instance of CMSRMessageIdHeader
		* @param aStart start position of the bytes in data
		* @param aEnd end position of bytes in the data
		* @param aTotal Total length of the data
		* @return a new instance of CMSRPByteRangeHeader
		*/
		IMPORT_C static CMSRPByteRangeHeader* NewL(
			TInt aStart, TInt aEnd, TInt aTotal );

		/**
		* Creates a new instance of CMSRPByteRangeHeader and puts it to CleanupStack
		* @param aStart start position of the bytes in data
		* @param aEnd end position of bytes in the data
		* @param aTotal Total length of the data
		* @return a new instance of CMSRPByteRangeHeader
		*/
		IMPORT_C static CMSRPByteRangeHeader* NewLC(
			TInt aStart, TInt aEnd, TInt aTotal );

		/**
		* Creates a new instance of CMSRMessageIdHeader
		* @return a new instance of CMSRPByteRangeHeader
		*/
		static CMSRPByteRangeHeader* NewL( );

		/**
		* Destructor, deletes the resources of CMSRPByteRangeHeader.
		*/
		IMPORT_C ~CMSRPByteRangeHeader();

	public: // New functions

		/**
		* Constructs an instance of a CMSRPByteRangeHeader from a RReadStream
		* @param aReadStream a stream containing the value of the
		*        externalized object (header name not included).
		* @return an instance of a CMSRPByteRangeHeader
		*/
		IMPORT_C static CMSRPByteRangeHeader*
			InternalizeValueL( RReadStream& aReadStream );

		/**
		* Sets the start position of the bytes in data
		* @param aStartPos start position of bytes
		*/
		IMPORT_C void SetStartPosition( TInt aStartPos );

		/**
		* Gets the start position of the bytes in data
		*/
		IMPORT_C TInt StartPosition( ) const;

		/**
		* Sets the end position of the bytes in data
		* @param aEndPos start position of bytes
		*/
		IMPORT_C void SetEndPosition( TInt aEndPos );

		/**
		* Gets the end position of the bytes in data
		*/
		IMPORT_C TInt EndPosition( ) const;

		/**
		* Sets the total length of bytes in data
		* @param aTotal total number of bytes
		*/
		IMPORT_C void SetTotalLength( TInt aTotal );

		/**
		* Gets the total number of the bytes in data
		*/
		IMPORT_C TInt TotalLength( ) const;

	public: // From CMSRPHeaderBase

		IMPORT_C void ExternalizeValueL( RWriteStream& aWriteStream ) const;

	protected: // From CMSRPHeaderBase

		RStringF Name() const;
		HBufC8* ToTextValueL() const;

	private: // Constructors

        /**
        * Contructor.
        */
		CMSRPByteRangeHeader( );
        /**
        * Contructor.
		* @param aStart start position of the bytes in data
		* @param aEnd end position of bytes in the data
		* @param aTotal Total length of the data
        */
		CMSRPByteRangeHeader(
			TInt aStart, TInt aEnd, TInt aTotal );
        /**
        * two-phased contructor.
        */
        void ConstructL( ) const;

	private: // new functions
	    /**
		* Internalize external object data
		* @param aReadStream a stream containing the value of the
		*        externalized object (header name not included).
		*/
		void DoInternalizeValueL( RReadStream& aReadStream );

  	private: // variables

		// byte range values
		TInt iStartPosition;
		TInt iEndPosition;
		TInt iTotalBytes;

	};

#endif // CMSRPBYTERANGEHEADER_H

// End of File