contentmgmt/referencedrmagent/RefTestAgent/localsdp/api/sdpattributefield.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          : SdpAttributeField.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 CSDPATTRIBUTEFIELD_H
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    25
#define CSDPATTRIBUTEFIELD_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 <stringpool.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    30
#include "sdpcodecstringconstants.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    31
#include "_sdpdefs.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    32
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    33
// FORWARD DECLARATIONS
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    34
class RReadStream;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    35
class RWriteStream;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    36
class CSdpFmtAttributeField;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    37
class CSdpAttributeFieldPtrs;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    38
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    39
// CLASS DECLARATION
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    40
/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    41
 *  @publishedAll
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    42
 *  @released
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    43
 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    44
 *	This class encapsulates the attribute field of Session Description Protocol
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    45
 *	for media and session level attributes. Media format/payload type level
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    46
 *  attributes are supported by the CSdpFmtAttributeField class. 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    47
 * 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    48
 *	The normative reference for correct formatting and values is
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    49
 *	draft-ietf-mmusic-sdp-new-14 unless specified otherwise in
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    50
 *  member documentation. The implementation supports this normative
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    51
 *  reference, but does not enforce it fully. 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    52
 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    53
 *  @lib localsdpcodec.lib
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    54
 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    55
class CSdpAttributeField : public CBase
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    56
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    57
    public:     // Constructors and destructor
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    58
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    59
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    60
         *	Constructs a new attribute field.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    61
		 *			 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    62
         *	@param aText A string containing a correctly 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    63
         *         formatted field value terminated by a CRLF.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    64
         *	@return a new instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    65
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    66
		IMPORT_C static CSdpAttributeField* DecodeL( const TDesC8& aText );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    67
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    68
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    69
         *	Constructs a new attribute field and adds the pointer to the 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    70
         *  cleanup stack.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    71
		 *		 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    72
         *	@param aTest A string containing a correctly 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    73
         *         formatted field value terminated by a CRLF.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    74
         *	@return a new instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    75
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    76
		IMPORT_C static CSdpAttributeField* DecodeLC( const TDesC8& aText );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    77
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    78
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    79
         *	Constructs a new attribute field. 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    80
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    81
         *	@param aAttribute The attribute name. It can be a pre-
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    82
         *         defined name in the SDP string pool or defined by the 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    83
         *         client.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    84
         *	@param aValue A valid attribute value or an empty 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    85
         *         descriptor to omit the value part.
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 CSdpAttributeField* NewL(
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    89
            RStringF aAttribute, const TDesC8& aValue );
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 attribute field and adds the pointer to the 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    93
         *  cleanup stack. 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    94
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    95
         *	@param aAttribute The attribute name. It can be a pre-defined 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    96
         *         name in the SDP string pool or defined by the client.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    97
         *	@param aValue A valid attribute value or an empty 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    98
         *         descriptor to omit the value part.
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 CSdpAttributeField* NewLC(
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   102
            RStringF aAttribute, const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   103
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   104
 		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   105
		 *	Deletes the resources held by the instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   106
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   107
		IMPORT_C ~CSdpAttributeField();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   108
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   109
    public:     // New functions
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   110
	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   111
    	/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   112
		 *	Outputs the field formatted according to SDP syntax and including
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   113
		 *  the terminating CRLF.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   114
		 * 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   115
		 *	@param aStream Stream used for output. On return the 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   116
         *         stream includes correctly formatted attribute field.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   117
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   118
		IMPORT_C void EncodeL( RWriteStream& aStream ) const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   119
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   120
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   121
		 *	Creates a new instance that is equal to the target.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   122
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   123
		 *	@return a new instance.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   124
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   125
		IMPORT_C CSdpAttributeField* CloneL() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   126
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   127
		/**	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   128
		 *	Compares this instance to another for equality.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   129
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   130
		 *	@param aObj: The instance to compare to.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   131
		 *	@return ETrue if equal, EFalse if not.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   132
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   133
		IMPORT_C TBool operator == ( const CSdpAttributeField& aObj ) const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   134
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   135
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   136
		 *	Gets the attribute name.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   137
		 *	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   138
		 *	@return	The attribute name. The name can be pre-defined 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   139
         *          name in the SDP string table or defined by the client.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   140
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   141
		IMPORT_C RStringF Attribute() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   142
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   143
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   144
		 *	Gets the attribute.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   145
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   146
 		 *	@return	The value or an empty descriptor if there is no value part.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   147
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   148
		IMPORT_C const TDesC8& Value() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   149
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   150
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   151
		 *	Sets the attribute and attribute value.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   152
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   153
         *	@param aAttribute A valid attribute name. It can be a 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   154
         *         pre-defined name in the SDP string pool or 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   155
         *         defined by the client.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   156
         *	@param aValue A valid attribute value or an empty 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   157
         *         descriptor to omit the value part.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   158
		 *  @leave KErrSdpCodecAttributeField if the attribute part is not 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   159
		 *         pre-defined EAttributeFmtp or EAttributeRtpmap.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   160
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   161
		IMPORT_C void SetL( RStringF aAttribute, const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   162
		
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   163
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   164
 		 *	Assigns attribute to the format level attribute.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   165
 		 *  In the final output the attribute will placed after format level
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   166
		 *  attribute.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   167
 		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   168
 		 *	@param aFmtAttribute A format level 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   169
 		 *         attribute this attribute is assigned to.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   170
 		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   171
 		IMPORT_C void AssignTo(const CSdpFmtAttributeField& aFmtAttribute);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   172
		
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   173
		/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   174
		 *	Test if the attribute belongs to the given format level attribute.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   175
		 *  Note, that the check can be true for the media level paremeter if
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   176
		 *  it appears after the last format level attribute.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   177
		 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   178
		 *	@param  aFmtAttribute: A format level 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   179
		 *          attribute this attribute belongs to.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   180
		 *	@return	ETrue if attribute belongs to the format level attribute, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   181
		 *          EFalse otherwise.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   182
		 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   183
		IMPORT_C TBool BelongsTo(const CSdpFmtAttributeField& aFmtAttribute) const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   184
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   185
    public:     // Internal to codec
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   186
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   187
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   188
         *  Externalizes the object to stream
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   189
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   190
         *  @param aStream Stream where the object's state will be stored
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   191
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   192
		void ExternalizeL( RWriteStream& aStream ) const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   193
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   194
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   195
         *  Creates object from the stream data
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   196
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   197
         *  @param aStream Stream where the object's state will be read
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   198
         *  @return Initialized object
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   199
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   200
        static CSdpAttributeField* InternalizeL( RReadStream& aStream );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   201
        
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   202
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   203
         *  Informs if the attribute belongs to any format level attribute.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   204
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   205
         *  @return ETrue if attribute belongs to any format level 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   206
		 *			attribute, EFalse otherwise.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   207
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   208
        TBool IsFmtAttribute();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   209
    
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   210
	private:    // Constructors
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   211
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   212
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   213
         *  Constructor
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   214
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   215
		CSdpAttributeField();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   216
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   217
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   218
         *  Second phase constructor
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   219
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   220
         *  @param aText Text string ending to LF character
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   221
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   222
        void ConstructL( const TDesC8& aText );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   223
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   224
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   225
         *  Second phase constructor
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   226
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   227
         *  @param aAttribute Attribute identifier
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   228
         *  @param aValue Value of the attribute of KNullDesC8
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   229
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   230
        void ConstructL( RStringF aAttribute, const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   231
    
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   232
    private:    // Internal
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   233
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   234
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   235
         *  Verifies that attribute is valid property attribute and initializes
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   236
         *  the member variables of class accordingly
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   237
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   238
         *  @param aAttribute Attribute in descriptor
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   239
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   240
        void FormatProperyAttributeL( const TDesC8& aAttribute );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   241
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   242
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   243
         *  Verifies that attribute is valid value attribute and initializes
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   244
         *  the member variables of class accordingly
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   245
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   246
         *  @param aArray Array of the attributes
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   247
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   248
        void FormatValueAttributeL( const TDesC8& aAttribute,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   249
                                    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
         *  Verifies that the value is valid for the attribute
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   253
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   254
         *  @param aAttribute The attribute
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   255
         *  @param aArray Array containing the values (and attribute)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   256
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   257
        void VerifyValueAttributeL( SdpCodecStringConstants::TStrings aString,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   258
                                    const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   259
                                    
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   260
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   261
         *  Forms attribute and value strings out of the token array
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   262
         *  and pushes both (aAttribute & aValue) into cleanup stack
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   263
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   264
         *  @param aArray Token array
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   265
         *  @param aAttribute Attribute string (in cleanup stack)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   266
         *  @param aValue Value string (in cleanup stack)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   267
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   268
        void CreateAttributeAndValueStringsLC( RArray<TPtrC8>& aArray,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   269
                                               HBufC8*& aAttribute,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   270
                                               HBufC8*& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   271
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   272
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   273
         *  Checks if the value is among the valid orient attributes
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   274
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   275
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   276
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   277
        void CheckValidOrientL( const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   278
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   279
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   280
         *  Checks if the value is valid language attribute as
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   281
         *  specified in RFC 3066
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   282
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   283
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   284
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   285
        void CheckValidLangStrL( const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   286
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   287
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   288
         *  Checks if the value is valid framerate attribute
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   289
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   290
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   291
         */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   292
        void CheckValidFrameRateL( const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   293
        
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   294
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   295
         *  Checks if the value is among valid uri value for control attribute
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   296
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   297
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   298
         */       
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   299
        void CheckValidControlL( const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   300
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   301
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   302
         *  Checks if the value is valid value for group attribute as
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   303
         *  specified in RFC 3388
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   304
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   305
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   306
         */       
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   307
        void CheckValidGroupL( const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   308
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   309
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   310
         *  Checks if the value is valid value for des attribute as
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   311
         *  specified in RFC 3312
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   312
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   313
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   314
         */       
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   315
        void CheckValidDesL( const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   316
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   317
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   318
         *  Checks if the value is valid value for curr and conf attribute as
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   319
         *  specified in RFC 3312
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   320
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   321
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   322
         */       
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   323
        void CheckValidCurrAndConfL( const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   324
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   325
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   326
         *  Checks if value is included in the list of predefined values
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   327
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   328
         *  @param aItemsCount Predefined values count
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   329
         *  @param aValuesList List of predefined values
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   330
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   331
         */       
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   332
        void ValidValueInListL( TInt aItemsCount, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   333
                                const TText8* const aValuesList[], 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   334
                                const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   335
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   336
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   337
         *  Checks if the value is valid value for range attribute as
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   338
         *  specified in RFC 2326
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   339
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   340
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   341
         */       
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   342
        void CheckValidRangeL( const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   343
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   344
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   345
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   346
         *  Checks if the value is valid rtpmap string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   347
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   348
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   349
         */   
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   350
        void CheckValidRtpmapL( const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   351
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   352
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   353
         *  Checks if the value is valid fmtp string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   354
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   355
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   356
         */   
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   357
        void CheckValidFmtpL( const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   358
        
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   359
        /**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   360
         *  Set attribute and values. Attribute is not one of predefined ones.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   361
         *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   362
         *  @param aAttribute Attribute string (in cleanup stack)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   363
         *  @param aValue Value string
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   364
         */   
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   365
        void SetNotPredefinedAttributeL( const TDesC8& aAttribute, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   366
                                         const TDesC8& aValue );
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   367
        
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   368
        void CreateAttributeFieldPtrsL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   369
        
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   370
        inline CSdpAttributeFieldPtrs& AttributeFieldPtrs();      
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   371
        
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   372
        inline const CSdpAttributeFieldPtrs& AttributeFieldPtrs() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   373
	   
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   374
		void __DbgTestInvariant() const;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   375
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   376
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   377
    private:    // Data
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   378
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   379
        // String pool
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   380
        RStringPool iPool;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   381
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   382
        // Attribute name
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   383
        RStringF iAttribute;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   384
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   385
        // Flag indicating if the attribute is a property attribute
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   386
        TBool iPropertyAttribute;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   387
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   388
        // Value field
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   389
        HBufC8* iValue;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   390
	};
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   391
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   392
#endif // CSDPATTRIBUTEFIELD_H