multimediacommsengine/mmceshared/inc/mcecomstreambundle.h
author Stefan Karlsson <stefan.karlsson@nokia.com>
Sun, 28 Mar 2010 16:37:26 +0100
branchCompilerCompatibility
changeset 9 5d1d815214a5
parent 0 1bce908db942
permissions -rw-r--r--
Fixed "extra qualification" syntax errors.

/*
* Copyright (c) 2006 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:    
*
*/




#ifndef MCECOMSTREAMBUNDLE_H
#define MCECOMSTREAMBUNDLE_H

//  INCLUDES
#include <e32base.h>  	
#include <mcedefs.h>

// CONSTANTS

#ifdef MCE_COMMON_SERVER_SIDE

#include "mcesrv.h"

#endif//MCE_COMMON_SERVER_SIDE

#include "mcestreambundle.h"
#include "mcecomserializable.h"

class CMceComMediaStream;
class CMceComSession;
class CMceComEndpoint;
class TMceComFactory;
class MMceComEndPointProxy;

// FORWARD DECLARATIONS

/**
* Class for handling grouping of Mce streams (i.e. grouping of media lines).
*
* Can be used for example to synchronize audio and video streams.
*
* If streams are added to the bundle or removed from it after the bundle
* has been added to the session, the session has to be updated with
* CMceSEssion::UpdateL() function in order to complete the changes. 
*
*  @lib mceclient.lib
*/
class CMceComStreamBundle : public CBase, 
                            public MMceComSerializable
	{
	
public: // Constructors and destructor

    /**
    * Two-phased constructor.
    */
    static CMceComStreamBundle* NewL( CMceStreamBundle::TMceStreamBundleType aType );

    /**
    * Two-phased constructor.
    */
	static CMceComStreamBundle* NewLC( CMceStreamBundle::TMceStreamBundleType aType );
         
    /**
    * Destructor.
    */
	~CMceComStreamBundle();

public: //static API


    static TBool InBundle( CMceComEndpoint& aEndpoint, 
                           CMceComSession& aSession );

public:

    /**
    * Type of the bundle
    * @param aParent the parent
    */
    CMceStreamBundle::TMceStreamBundleType Type() const;

    /**
    * Adds stream to the bundle.
    * @param aStream, stream to be added
    */
    void AddStreamL( CMceComMediaStream& aStream );
    
    /**
    * Removes stream from the bundle.
    * @param aStream, stream to be removed
    */
    void RemoveStreamL( CMceComMediaStream& aStream );
    
     /**
    * Returns the streams belonging to the bundle.
    * @return streams of the bundle.
    */
	const RPointerArray< CMceComMediaStream >& Streams() const;
	
    /**
    * Called when bundle has beed added to session
    */
    void AddedL();
    
    
public: // from MMceComSerializable

    /**
    * Returns serialization id
    * @return serialization id
    */
    TUint64 SerializationId() const;

    /**
    * Internalizes flat data
    * @param aReadStream read stream
    */
    void InternalizeFlatL( RReadStream& aReadStream );

    /**
    * Externalizes flat data
    * @param aWriteStream write stream
    */
    void ExternalizeFlatL( RWriteStream& aWriteStream );

    /**
    * Internalizes
    * @param aSerCtx context for serialization
    */
    void InternalizeL( MMceComSerializationContext& aSerCtx );
    
    /**
    * Externalizes
    * @param aSerCtx context for serialization
    */
    void ExternalizeL( MMceComSerializationContext& aSerCtx );


public: // new functions

    /**
    * ID 
    * @return ID
    */
	TMceMediaId Id() const;

    /**
    * Factory
    * @return factory
    */
    TMceComFactory BaseFactory();

    /**
    * Initializes 
    * @param aParent the parent
    */
    void InitializeL( CMceComSession& aParent );

    /**
    * Updates this object
    * @param aUpdate object updates this
    */
    void UpdateL( CMceComStreamBundle& aUpdate );
    
    /**
    * Clones this object
    * @return the cloned object
    */
    CMceComStreamBundle* CloneL();

    /**
    * Clones this object
    * @param aStreams array containing streams
    * @return the cloned object
    */
    CMceComStreamBundle* CloneL( const RPointerArray<CMceComMediaStream>& aStreams );


private: //methods

    /**
     * C++ default constructor.
     */
	CMceComStreamBundle( CMceStreamBundle::TMceStreamBundleType aType );

    /**
     * second-phase constructor
     */
	void ConstructL();

    /**
    * Zeroes instance (used in cloning)
    */
    void Zero();


    void AddedSinkL( CMceComMediaStream& aStream,
                     CMceComEndpoint*& aCurrentSink,
                     MMceComEndPointProxy*& aProxy );

    void AddedSourceL( CMceComMediaStream& aStream,
                       CMceComEndpoint*& aCurrentSource,
                       MMceComEndPointProxy*& aProxy );

    
private: // Data


    /**
     * type
     */
    CMceStreamBundle::TMceStreamBundleType iBundleType;
    
    /**
     * ID
     */
    TMceMediaId iID;

    /**
     * streams
     */
    RPointerArray< CMceComMediaStream > iStreams;
    
    /**
     * session
     */
    CMceComSession* iSession;
    
    
#ifdef MCE_COMMON_SERVER_SIDE

	//definitions for unit testing
	MCEMM_UT_DEFINITIONS
    
#endif//MCE_COMMON_SERVER_SIDE
        
	MCE_UNIT_TEST_DEFS
	
	};

	

#endif //MCECOMSTREAMBUNDLE_H