contentmgmt/referencedrmagent/RefTestAgent/localsdp/api/sdpmediafield.h
author hgs
Thu, 24 Jun 2010 15:39:07 +0530
changeset 72 de46a57f75fb
permissions -rw-r--r--
201023_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
72
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     1
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     3
* All rights reserved.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     8
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     9
* Initial Contributors:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    11
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    12
* Contributors:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    13
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    14
* Description:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    15
* Name          : SdpMediaField.h
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    16
* Part of       : Local SDP Codec
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    17
* Interface     : SDK API, Local SDP Codec API
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    18
* Version       : 1.0
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    19
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    20
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    21
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    22
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    23
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    24
#ifndef CSDPMEDIAFIELD_H
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    25
#define CSDPMEDIAFIELD_H
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    26
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    27
//  INCLUDES
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    28
#include <e32base.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    29
#include "_sdpdefs.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    30
#include <stringpool.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    31
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    32
// FORWARD DECLARATIONS
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    33
class RReadStream;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    34
class RWriteStream;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    35
class CSdpConnectionField;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    36
class CSdpBandwidthField;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    37
class CSdpAttributeField;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    38
class CSdpKeyField;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    39
class CSdpFmtAttributeField;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    40
class CSdpCodecParseUtil;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    41
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    42
// CLASS DECLARATION
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    43
/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    44
 *  @publishedAll
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    45
 *  @released
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    46
 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    47
 *	This class encapsulates the media description field and related media
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    48
 *  specific subfields of the Session Description Protocol.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    49
 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    50
 *	The normative reference for correct formatting and values is
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    51
 *	draft-ietf-mmusic-sdp-new-14 unless specified otherwise in
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    52
 *  member documentation. The implementation supports this normative
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    53
 *  reference, but does not enforce it fully. 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    54
 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    55
 *  @lib localsdpcodec.lib
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    56
 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    57
class CSdpMediaField : public CBase
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    58
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    59
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    60
	public:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    61
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    62
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    63
    public: // Constructors and destructor
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    64
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    65
         *	Constructs a new media description field.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    66
		 *	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    67
         *	@param aText A correctly formatted media field 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    68
         *         terminated by a CRLF followed by zero or more media 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    69
         *         attribute fields separated by a CRLF.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    70
         *	@param aRecurse If ETrue, attempts to construct also media 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    71
         *         attributes following the CRLF terminating the media field.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    72
         *	@return a new instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    73
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    74
		IMPORT_C static	CSdpMediaField* DecodeL(const TDesC8& aText,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    75
												TBool aRecurse = ETrue);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    76
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    77
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    78
         *	Constructs a new media description field and adds the pointer to 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    79
         *  the cleanup stack.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    80
		 *	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    81
         *	@param aText A correctly formatted media field 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    82
         *         terminated by a CRLF followed by zero or more media 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    83
         *         attribute fields separated by a CRLF.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    84
         *	@param aRecurse If ETrue, attempts to construct also media 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    85
         *         attributes following the CRLF terminating the media field.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    86
		 *  @return a new instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    87
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    88
		IMPORT_C static	CSdpMediaField* DecodeLC(const TDesC8& aText,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    89
												 TBool aRecurse = ETrue);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    90
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    91
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    92
         *	Constructs a new media description field.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    93
		 *  The optional portcount component of the field is initialized to 1.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    94
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    95
		 *	@param aMedia A valid media type name.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    96
         *	@param aPort Port number.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    97
         *	@param aProtocol A valid media protocol name.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    98
         *	@param aFormatList A valid format list.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    99
         *	@return a new instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   100
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   101
		IMPORT_C static CSdpMediaField* NewL(RStringF aMedia,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   102
											 TUint aPort,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   103
											 RStringF aProtocol,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   104
											 const TDesC8& aFormatList);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   105
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   106
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   107
         *	Constructs a new media description field and adds the pointer to 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   108
         *  the cleanup stack.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   109
		 *  The optional portcount component of the field is initialized to 1.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   110
		 *	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   111
		 *	@param aMedia A valid media type name.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   112
         *	@param aPort Port number.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   113
         *	@param aProtocol A valid media protocol name.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   114
         *	@param aFormatList A valid format list.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   115
         *	@return a new instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   116
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   117
		IMPORT_C static CSdpMediaField* NewLC(RStringF aMedia,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   118
											  TUint aPort,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   119
										      RStringF aProtocol,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   120
										      const TDesC8& aFormatList);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   121
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   122
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   123
		 *	Deletes the resources held by the instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   124
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   125
		IMPORT_C ~CSdpMediaField();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   126
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   127
    public: // New functions
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   128
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   129
		 *	Outputs the field formatted according to SDP syntax and including
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   130
		 *  the terminating CRLF. Optionally output also the related media 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   131
		 *  level fields. 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   132
		 * 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   133
		 *	@param aStream Stream used for output. On return the
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   134
         *         stream includes correctly formatted media field with 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   135
         *         media part fields if aRecurse is defined to ETrue.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   136
		 *	@param aRecurse Flag to specify whether to output media 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   137
		 *         attributes also (ETrue) or only the media field (EFalse).
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   138
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   139
		IMPORT_C void 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   140
			EncodeL(RWriteStream& aStream, TBool aRecurse = ETrue) const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   141
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   142
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   143
		 *	Creates a new instance that is equal to the target.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   144
		 *  Optionally also related subfields are cloned.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   145
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   146
		 *	@param aRecurse Flag to specify whether to clone subfields
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   147
		 *         also (ETrue) or only the media field (EFalse).
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   148
		 *	@return a new instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   149
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   150
		IMPORT_C CSdpMediaField * CloneL(TBool aRecurse = ETrue) const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   151
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   152
		/**	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   153
		 *	Compares this instance to another for equality. Subfields are
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   154
		 *  included in the comparison if present.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   155
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   156
		 *	@param aObj The instance to compare to.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   157
		 *	@return ETrue if equal, EFalse if not.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   158
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   159
		IMPORT_C TBool operator == (const CSdpMediaField& aObj) const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   160
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   161
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   162
		 *	Checks the consistency between the media field and it's subfields.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   163
		 *  In particular, this function checks that each format specific 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   164
		 *  attribute is related to a format in the format list of the
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   165
		 *  media field.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   166
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   167
		 *	@return	ETrue if media description is consistent and EFalse if not.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   168
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   169
		IMPORT_C TBool IsValid() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   170
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   171
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   172
		 *	Gets the media type.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   173
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   174
		 *	@return The media type.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   175
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   176
		IMPORT_C RStringF Media() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   177
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   178
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   179
		 *	Sets the media type.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   180
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   181
		 *	@param aMedia The media type.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   182
		 *  @leave KErrSdpCodecMediaField if aMedia is not valid character
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   183
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   184
		IMPORT_C void SetMediaL(RStringF aMedia);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   185
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   186
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   187
		 *	Gets the media protocol.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   188
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   189
		 *	@return The media protocol.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   190
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   191
		IMPORT_C RStringF Protocol() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   192
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   193
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   194
		 *	Sets the media protocol.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   195
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   196
		 *	@param aProtocol The media protocol.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   197
		 *  @leave KErrSdpCodecMediaField if 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   198
		 *		   aProtocol containing two elements divided by slash are not 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   199
         *         valid tokens.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   200
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   201
		IMPORT_C void SetProtocolL(RStringF aProtocol);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   202
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   203
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   204
		 *	Gets the port number.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   205
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   206
		 *	@return The port number.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   207
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   208
		IMPORT_C TUint Port() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   209
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   210
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   211
		 *	Sets the port number.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   212
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   213
		 *	@param aPort The port number.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   214
		 *  @leave KErrSdpCodecMediaField if port is not valid number as 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   215
         *         defined in draft-ietf-mmusic-sdp-new-14
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   216
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   217
		IMPORT_C void SetPortL(TUint aPort);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   218
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   219
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   220
		 *	Gets the port count.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   221
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   222
		 *	@return The port count.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   223
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   224
		IMPORT_C TUint PortCount() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   225
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   226
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   227
		 *	Sets the port count.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   228
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   229
		 *	@param aCount The port count that must be greater than zero.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   230
		 *  @leave KErrSdpCodecMediaField if aCount equals to zero.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   231
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   232
		IMPORT_C void SetPortCountL(TUint aCount);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   233
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   234
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   235
		 *	Gets the format list.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   236
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   237
		 *	@return The format list.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   238
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   239
		IMPORT_C const TDesC8& FormatList() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   240
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   241
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   242
		 *	Sets the format list.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   243
		 *  The format list should contain one or more format tokens separated
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   244
		 *  by a single whitespace character.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   245
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   246
		 *	@param aValue A valid format list.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   247
		 *  @leave KErrSdpCodecMediaField if aValue contains invalid tokens
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   248
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   249
		IMPORT_C void SetFormatListL(const TDesC8& aValue);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   250
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   251
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   252
		 *	Return the media level info field value.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   253
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   254
		 *	@return The value or an empty descriptor if not present.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   255
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   256
		IMPORT_C const TDesC8& Info() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   257
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   258
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   259
		 *	Sets the media level info field value.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   260
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   261
		 *	@param aValue A valid info field value.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   262
		 *	@leave KErrSdpCodecMediaInfoField if aValue is not KNullDesC8 or 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   263
         *         aValue includes invalid byte strings (´\0´, ´\n´, ´\r´).
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   264
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   265
		IMPORT_C void SetInfoL(const TDesC8& aValue);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   266
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   267
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   268
		 *	Gets the media level encryption key field.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   269
		 *	Note, that the ownership is not transferred and
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   270
		 *	the instance must not be deleted by the caller.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   271
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   272
		 *	@return Encryption key field or null if not present.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   273
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   274
		IMPORT_C CSdpKeyField* Key();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   275
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   276
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   277
		 *	Gets the media level encryption key field.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   278
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   279
		 *	@return Encryption key field or null if not present.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   280
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   281
		IMPORT_C const CSdpKeyField* Key() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   282
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   283
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   284
		 *	Sets or removes the media level encryption key field.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   285
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   286
		 *	@param aObj The new key field or null if field is 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   287
         *         to be removed. Ownership of the referenced object
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   288
		 *         is transferred to the media field instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   289
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   290
		IMPORT_C void SetKey(CSdpKeyField* aObj);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   291
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   292
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   293
		 *	Gets the set of media format level attributes.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   294
		 *  This array is used directly for element insertion and removal.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   295
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   296
		 *	The objects referenced from the array are owned by the media
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   297
		 *  field instance and must not be deleted. An object can be
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   298
		 *  removed from the media description by setting the corresponding
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   299
		 *  element to zero. By doing so, the calling party receives ownership
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   300
		 *  of the removed object.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   301
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   302
		 *	@return The set of media format level attributes.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   303
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   304
		IMPORT_C RPointerArray<CSdpFmtAttributeField>& FormatAttributeFields();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   305
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   306
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   307
		 *	Gets the set of media level, format independent attributes.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   308
		 *  This array is used directly for element insertion and removal.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   309
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   310
		 *	The objects referenced from the array are owned by the media
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   311
		 *  field instance and must not be deleted. An object can be
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   312
		 *  removed from the media description by setting the corresponding
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   313
		 *  element to zero. By doing so, the calling party receives ownership
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   314
		 *  of the removed object.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   315
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   316
		 *	@return The set of media level attributes.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   317
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   318
		IMPORT_C RPointerArray<CSdpAttributeField>& AttributeFields();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   319
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   320
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   321
		 *	Gets the set of media level bandwidth fields.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   322
		 *  This array is used directly for element insertion and removal.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   323
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   324
		 *	The objects referenced from the array are owned by the media
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   325
		 *  field instance and must not be deleted. An object can be
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   326
		 *  removed from the media description by setting the corresponding
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   327
		 *  element to zero. By doing so, the calling party receives ownership
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   328
		 *  of the removed object.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   329
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   330
		 *	@return The set of media level bandwidth fields.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   331
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   332
		IMPORT_C RPointerArray<CSdpBandwidthField>& BandwidthFields();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   333
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   334
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   335
		 *	Gets the set of media level connection fields.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   336
		 *  This array is used directly for element insertion and removal.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   337
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   338
		 *	The objects referenced from the array are owned by the media
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   339
		 *  field instance and must not be deleted. An object can be
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   340
		 *  removed from the media description by setting the corresponding
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   341
		 *  element to zero. By doing so, the calling party receives ownership
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   342
		 *  of the removed object.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   343
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   344
		 *	@return The set of media level connection fields.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   345
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   346
		IMPORT_C RPointerArray<CSdpConnectionField>& ConnectionFields();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   347
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   348
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   349
		 *	Removes a specific format from the media description.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   350
		 *  The function will remove the named format from the format list if
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   351
		 *  found and then delete all format level attributes of type 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   352
		 *  CSdpFmtAttributeField related to the removed format. 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   353
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   354
		 *	@param aFormat The name of the format to remove.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   355
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   356
		IMPORT_C void RemoveFormatL(const TDesC8& aFormat);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   357
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   358
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   359
		 *	Removes all formats except one from the media description.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   360
		 *  The function will set the format list to only contain the one
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   361
		 *  format to keep and then delete all format level attributes that
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   362
		 *  are related to the removed formats. If the format is not found
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   363
		 *  from the format list, it is added there. If there are no format
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   364
		 *  level attributes for the specified format, the format level
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   365
		 *  attribute set will be empty.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   366
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   367
		 *	@param aFormat The name of the format to keep after 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   368
		 *         removing all others.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   369
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   370
		IMPORT_C void KeepFormatL(const TDesC8& aFormat);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   371
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   372
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   373
		 *	Sets this media description into rejected state.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   374
		 *  The rejected state is defined by the offer/answer model in
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   375
		 *  RFC3264. The function sets the port number to 0 and removes
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   376
		 *  all formats except one. The remaining format is determined
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   377
		 *  by the implementation.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   378
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   379
		IMPORT_C void RejectMedia();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   380
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   381
    public:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   382
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   383
		 *	Shows if contact is present
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   384
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   385
		 *	@return ETrue if contact present, otherwise EFalse
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   386
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   387
		TBool IsContactPresent() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   388
		
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   389
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   390
         *  Externalizes the object to stream
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   391
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   392
         *  @param aStream Stream where the object's state will be stored
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   393
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   394
		void ExternalizeL(RWriteStream& aStream) const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   395
		
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   396
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   397
         *  Creates object from the stream data
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   398
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   399
         *  @param aStream Stream where the object's state will be read	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   400
         *  @return Initialized object
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   401
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   402
		static CSdpMediaField* InternalizeL(RReadStream& aStream);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   403
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   404
	private:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   405
		CSdpMediaField();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   406
		void ConstructL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   407
		void ConstructL(TBool aRecurse);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   408
		void ConstructL(RStringF aMedia, TUint aPort, RStringF aProtocol, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   409
						const TDesC8& aFormatList);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   410
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   411
		void ConstructL(const CSdpMediaField& aSdpMediaField);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   412
		void DoInternalizeL(RReadStream& aStream);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   413
		void ParseL (const TDesC8& aText);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   414
		void ParseMediaL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   415
		void ParseInformationL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   416
		void ParseConnectionL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   417
		void ParseBandwithL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   418
		void ParseEncryptionKeyL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   419
		void ParseAttributeFieldsL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   420
		TDesC8& GetTokenFromStreamL(RReadStream& aStream);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   421
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   422
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   423
		CSdpMediaField(const CSdpMediaField&); // Hidden.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   424
		CSdpMediaField& operator = (const CSdpMediaField&); // Hidden
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   425
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   426
    private: // Data
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   427
		HBufC8* iInfo;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   428
		CSdpKeyField* iSdpKeyField;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   429
		RArray<TPtrC8> iElementArray;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   430
		RStringPool iPool;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   431
		TBool iRecurse;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   432
		RStringF iMedia;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   433
		RStringF iProtocol;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   434
		TUint iPort;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   435
		TUint iPortCount;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   436
		HBufC8* iFormatList;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   437
		RPointerArray<CSdpBandwidthField>* iBandwidthFields;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   438
		RPointerArray<CSdpAttributeField>* iAttributeFields;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   439
		RPointerArray<CSdpConnectionField>* iConnectionFields;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   440
		RPointerArray<CSdpFmtAttributeField>* iFmtAttrFields;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   441
		HBufC8* iToken;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   442
		CSdpCodecParseUtil* iSdpCodecParseUtil;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   443
	};
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   444
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   445
#endif // CSDPMEDIAFIELD_H