multimediacommsengine/tsrc/mccstub/inc/mmcccodecred.h
author William Roberts <williamr@symbian.org>
Thu, 17 Jun 2010 22:31:54 +0100
branchGCC_SURGE
changeset 29 11893e44ad1b
parent 0 1bce908db942
permissions -rw-r--r--
Mark TMeta vtable and typeinfo exports as ABSENT - Bug 3024

/*
* Copyright (c) 2004 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:    Class is used for configuring red codec.
*
*/




#ifndef __MCC_CODEC_RED_H__
#define __MCC_CODEC_RED_H__

//  INCLUDES
#include <e32cmn.h>
#include <rtpdef.h>
#include "mmcccodecinformation.h"

// CONSTANTS
const TText8 KCharSpace( ' ' );
const TText8 KCharSlash( '/' );

const TInt KRedSampleRate = 8000;
const TInt KRedPTime = 20;
const TInt KRedMaxPTime = 200;

// Red Codec possible bitrates
const TUint KRedSamplingFreq = 8000;

// MACROS

// DATA TYPES

// FUNCTION PROTOTYPES

// FORWARD DECLARATIONS

// CLASS DECLARATION
/**
*  Container class for the codec information.
*
*  @lib mmccinterface.dll
*  
*/
NONSHARABLE_CLASS( CMccCodecRed ) : public CMccCodecInformation
    {
    public:  // Constructors and destructor

        /**
        * Two-phased constructor.
        */
        static CMccCodecRed* NewL();
        
        /**
        * Destructor.
        */
        virtual ~CMccCodecRed();
        
    public: // New functions
    
    public: // From CMccCodecInformation
    
        /**
        * From CMccCodecInformation
        */
        TBool RequireSignalling( const CMccCodecInformation& aCandidate ) const;     
        
        /**
        * From CMccCodecInformation
        */
        CMccCodecInformation* CloneDefaultsL();
        
        /**
        * From CMccCodecInformation
        */
        CMccCodecInformation* CloneDetailedL();
        
        /**
        * From CMccCodecInformation. Enable / Disable Voice Activity Detection.
        * @since    Series 60 3.0
        * @param    aEnableVAD    Boolean indicating whether to enable Voice Activity Detection
        * @return   KErrNotSupported if codec doesn't support VAD; otherwise KErrNone.
        */
        TInt EnableVAD( TBool aEnableVAD );
     
        /**
        * From CMccCodecInformation. Sets bitrate used with codec.
        * @since     Series 60 3.0
        * @param     aBitrate     New bitrate value
        * @return    KErrNotSupported if codec doesn't support bitrate value issued; otherwise KErrNone.
        */
        TInt SetBitrate( TUint aBitrate );
        
        /**
        * From CMccCodecInformation. Sets the sampling frequency.
        * @since    Series 60 3.0
        * @param    aSamplingFreq   Sampling frequency to be used
        * @return   KErrNotSupported if codec doesn't support sampling frequency issued; otherwise KErrNone.
        */
        TInt SetSamplingFreq( TUint32 aSamplingFreq );

        /**
        * From CMccCodecInformation. Sets the packet rate.
        * @since     Series 60 3.0
        * @param     aPacketrate        New packetrate
        * @return    KErrNotSupported if codec doesn't support packetrate value issued; otherwise KErrNone.
        */
        TInt SetPTime( TUint aPTime );
        
        /**
        * From CMccCodecInformation. Sets the packet rate.
        * @since     Series 60 3.0
        * @param     aPacketrate        New packetrate
        * @return    KErrNotSupported if codec doesn't support packetrate value issued; otherwise KErrNone.
        */
        TInt SetMaxPTime( TUint aMaxPTime );
        
        /**
        * From CMccCodecInformation. Sets the sdp name.
        * @since Series 60 3.0
        * @param aRtpId - [input] RTP session ID
        * @return One of the standard system-wide error codes.
        */
        TInt SetSdpName( const TDesC8& aSdpName );
        
        /**
        * From CMccCodecInformation. Sets the payload type.
        * @since Series 60 3.0
        * @param aRtpId - [input] RTP session ID
        * @return One of the standard system-wide error codes.
        */
        TInt SetPayloadType( TUint8 aPayloadType );

        /**
        * From CMccCodecInformation. Sets the codec mode.
        * @since         Series 60 3.0
        * @param aMode   Codec mode ( e.g. ULAW/ALAW, Bandwidth efficient / octet aligned )
        * @return        KErrNotSupported if codec doesnt' support codec mode value issued; otherwise KErrNone.
        */
        TInt SetCodecMode( TCodecMode aCodecMode );
        
        /**
        * Parses the fmtp attribute and sets the parsed codecs   
        * @since         Series60 3.0
        * @param aFmtp   Fmtp attribute
        * @return        One of the standard system-wide error codes.
        */
        TBool ParseFmtpAttrL( const TDesC8& aFmtp );    
        
        /**
        * Set Allowed BitRate
        * @since    Series 60 3.0
        * @param    aBitRateMask
        *                       
        * @return   Etrue, if Mask is valid
        */
        TInt SetAllowedBitrates( TUint aBitrateMask );
          
        /**
        * Sets the payload types used in redundancy 
        * @since        Series60 3.0
        * @param        Reference to the array containing the codecs
        * @return       None       
        */
        void SetRedPayloadsL( RArray<TUint>& aRedPayloads );
        
        /**
        * Fills array with red payload types.
        * @since        Series60 3.0
        * @param        aRedPayloads   
        */
        void RedPayloadsL( RArray<TUint>& aRedPayloads ) const;
   
   public: // New methods
       
        const RArray<TUint>& RedPayloads() const;
           
    private:
        /**
        * C++ default constructor.
        */
        CMccCodecRed();

        /**
        * By default Symbian 2nd phase constructor is private.
        */
        void ConstructL();
        
        /** 
        * Array contains the payloadtypes used in the Redundancy payload
        * Used only for redundancy payload format type 
        */ 
        RArray< TUint > iRedPayloads;        
    private:
        #ifdef TEST_EUNIT
            friend class UT_CMccCodecRed;
        #endif     
    };


#endif      // __MCC_CODEC_RED_H__

// End of File