javauis/amms_akn/module/src/cammsmodule.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 25 May 2010 12:34:19 +0300
branchRCL_3
changeset 18 9ac0a0a7da70
parent 14 04becd199f91
permissions -rw-r--r--
Revision: v2.1.26 Kit: 2010121

/*
* Copyright (c) 2005-2007 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:  This class is a container for MAMMSControlGroup objects.
*
*/


// INCLUDE FILES
#include "cammsmodule.h"
#include "cammscontrolgroup.h"
#include <jdebug.h>


// CONSTANTS
// Before further testing is done, 4 is sufficient average value to be used here.
const TInt KAMMSModuleDefaultGranularity = 4;

// ============================ MEMBER FUNCTIONS ===============================

// -----------------------------------------------------------------------------
// CAMMSModule::NewL
// Two-phased constructor.
// -----------------------------------------------------------------------------
CAMMSModule* CAMMSModule::NewL()
{
    CAMMSModule* self = NewLC();
    CleanupStack::Pop(self);

    return self;
}

// -----------------------------------------------------------------------------
// CAMMSModule::NewLC
// Two-phased constructor.
// -----------------------------------------------------------------------------
CAMMSModule* CAMMSModule::NewLC()
{
    CAMMSModule* self = new(ELeave) CAMMSModule;

    CleanupStack::PushL(self);
    self->ConstructL();
    return self;
}

// Destructor
CAMMSModule::~CAMMSModule()
{
    // Check that construction fully succeed.
    if (iControlGroups)
    {
        // control groups are owned and they must be deleted.
        iControlGroups->ResetAndDestroy();
        delete iControlGroups;
    }

    // Players are not owned.
    iPlayers.Close();
}

// -----------------------------------------------------------------------------
// CAMMSModule::AddControlGroupL
// Add control to iControlGroups array.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
void CAMMSModule::AddControlGroupAndPopL(CAMMSControlGroup* aGroup)
{
    // Check in debug build that group is not null.
    __ASSERT_DEBUG(aGroup, User::Invariant());

    iControlGroups->AppendL(aGroup);

    // aGroup must be the previous item in the cleanupstack
    CleanupStack::Pop(aGroup);
}

// -----------------------------------------------------------------------------
// CAMMSModule::AddPlayerL
// Adds new player to this module.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
void CAMMSModule::AddPlayerL(CMMAPlayer* aPlayer)
{
    // Check in debug build that player is not null.
    __ASSERT_DEBUG(aPlayer, User::Invariant());

    // Must leave if the player is already in the module
    if (HasPlayer(aPlayer))
    {
        User::Leave(KErrArgument);
    }

    // Must leave if player is in PREFETCHED or STARTED state
    User::LeaveIfError(CheckPlayerState(aPlayer));

    // Check that none of the players is not in PREFETCHED or STARTED state
    User::LeaveIfError(CheckAllPlayersState());

    AddPlayerNoStateCheckL(aPlayer);
}

// -----------------------------------------------------------------------------
// CAMMSModule::RemovePlayer
// Removes player from module..
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAMMSModule::RemovePlayer(CMMAPlayer* aPlayer)
{
    // call RemovePlayerNoStateCheck only if aPlayer and all players in the
    // module are in the right state.
    TInt error = CheckPlayerState(aPlayer);
    if (error == KErrNone)
    {
        error = CheckAllPlayersState();
        if (error == KErrNone)
        {
            error = RemovePlayerNoStateCheck(aPlayer);
        }
    }
    return error;
}

// -----------------------------------------------------------------------------
// CAMMSModule::AddPlayerNoStateCheckL
// Adds player without checking its state.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
void CAMMSModule::AddPlayerNoStateCheckL(CMMAPlayer* aPlayer)
{
    iPlayers.AppendL(aPlayer);

    // If adding players leaves CAMMSModule::CleanupAddPlayer method will be
    // called and player removed from module and from groups.
    CleanupStack::PushL(TCleanupItem(&CAMMSModule::CleanupAddPlayer, this));

    // Inform all control groups
    TInt count = iControlGroups->Count();
    for (TInt i = 0; i < count; i++)
    {
        iControlGroups->At(i)->PlayerAddedL(aPlayer);
    }

    CleanupStack::Pop(); // CSI: 12 Parameter TCleanupItem cannot be used as a parameter in Pop #
}

// -----------------------------------------------------------------------------
// CAMMSModule::RemovePlayerNoStateCheck
// Removes player without checking its state
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAMMSModule::RemovePlayerNoStateCheck(CMMAPlayer* aPlayer)
{
    TInt index = iPlayers.Find(aPlayer);
    if (index != KErrNotFound)
    {
        // player was in the array, remove it
        iPlayers.Remove(index);

        // inform all groups
        TInt count = iControlGroups->Count();
        for (TInt i = 0; i < count; i++)
        {
            iControlGroups->At(i)->PlayerRemoved(aPlayer);
        }
    }

    // Find returned KErrNotFound if player was not in the module
    return index;
}

// -----------------------------------------------------------------------------
// CAMMSModule::HasPlayer
// Checks whether the given player is in this module.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TBool CAMMSModule::HasPlayer(CMMAPlayer* aPlayer)
{
    DEBUG_INT("AMMS:CAMMSModule::HasPlayer %d +", (TInt)aPlayer);

    TInt index = iPlayers.Find(aPlayer);

    DEBUG_INT("AMMS:CAMMSModule::HasPlayer index=%d -", index);

    return (index != KErrNotFound);
}


#ifdef __WINS__

// -----------------------------------------------------------------------------
// CAMMSModule::PlayerCount
// Returns the count of players whose state is between the given limits.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAMMSModule::PlayerCount(TInt aMinState, TInt aMaxState)
{
    DEBUG_INT2("AMMS:CAMMSModule::PlayerCount %d %d +", aMinState, aMaxState);

    TInt result = 0;

    TInt playerCount = iPlayers.Count();

    DEBUG_INT("AMMS:CAMMSModule::HasPlayer, players=%d", playerCount);

    for (TInt i = 0; i < playerCount; i++)
    {
        TInt playerState = iPlayers[ i ]->State();

        DEBUG_INT2("AMMS:CAMMSModule::HasPlayer %d, state=%d", i,
                   playerState);

        if ((playerState >= aMinState) &&
                (playerState <= aMaxState))
        {
            result++;
        }
    }

    DEBUG_INT("AMMS:CAMMSModule::PlayerCount %d -", result);

    return result;
}

#endif  // __WINS__

// -----------------------------------------------------------------------------
// CAMMSModule::CheckPlayerState
// Checks all players state.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAMMSModule::CheckAllPlayersState()
{
    TInt error = KErrNone;

    TInt playerCount = iPlayers.Count();

    // Loop until all players are checked or one of the players is in
    // PREFETCHED or STARTED state
    for (TInt i = 0; (i < playerCount) &&
            (error == KErrNone); i++)
    {
        error = CheckPlayerState(iPlayers[ i ]);
    }
    return error;
}

// -----------------------------------------------------------------------------
// CAMMSModule::CheckPlayerState
// Checks player state.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAMMSModule::CheckPlayerState(CMMAPlayer* aPlayer)
{
    // Player may not be in PREFETCHED or STARTED state
    TInt retVal = KErrNone;
    TInt playerState = aPlayer->State();
    if (playerState == CMMAPlayer::EStarted ||
            playerState == CMMAPlayer::EPrefetched)
    {
        retVal = KErrNotReady;
    }
    return retVal;
}

// -----------------------------------------------------------------------------
// CAMMSModule::CleanupAddPlayer
// Static function to be used with TCleanupItem in AddPlayerNoStateCheckL
// method. This method removes last added player from module and control
// groups.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
void CAMMSModule::CleanupAddPlayer(TAny* aModule)
{
    CAMMSModule* module = static_cast< CAMMSModule* >(aModule);

    // This method is called from AddPlayerNoStateCheckL and there is always
    // at least one player.
    __ASSERT_DEBUG(module->iPlayers.Count() > 0, User::Invariant());

    // Remove last added player from module and from control groups
    module->RemovePlayerNoStateCheck(
        module->iPlayers[ module->iPlayers.Count() - 1 ]);
}

// -----------------------------------------------------------------------------
// CAMMSModule::Find
// Find control group with specified class name.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
MAMMSControlGroup* CAMMSModule::Find(const TDesC& aClassName)
{
    MAMMSControlGroup* group = NULL;
    TInt groupIndex = 0;
    TInt groupCount = iControlGroups->Count();

    // Loop until group is found or all group are checked
    while (!group && (groupIndex < groupCount))
    {
        MAMMSControlGroup* tmpGroup = iControlGroups->At(groupIndex);

        if (tmpGroup->ClassName() == aClassName)
        {
            // found the group, set return value which will stop while loop
            group = tmpGroup;
        }

        groupIndex++;
    }

    return group;
}

// -----------------------------------------------------------------------------
// CAMMSModule::At
// Index must be non-negative and less than the number of objects currently
// within the array otherwise the functions raise an E32USER-CBase 21 panic.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
MAMMSControlGroup* CAMMSModule::At(TInt aIndex)
{
    return iControlGroups->At(aIndex);    // CSI: 1 Array range panic allowed according to function description #
}

// -----------------------------------------------------------------------------
// CAMMSModule::Count
// return iControlGroup count.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAMMSModule::Count()
{
    return iControlGroups->Count();
}

// -----------------------------------------------------------------------------
// CAMMSModule::ConstructL
// Symbian 2nd phase constructor can leave.
// -----------------------------------------------------------------------------
void CAMMSModule::ConstructL()
{
    // Create array with default granularity, all derived classes must call
    // this method.
    iControlGroups = new(ELeave)CArrayPtrSeg< CAMMSControlGroup >(
        KAMMSModuleDefaultGranularity);

}

// -----------------------------------------------------------------------------
// CAMMSModule::CAMMSModule
// C++ default constructor can NOT contain any code, that
// might leave.
// -----------------------------------------------------------------------------
CAMMSModule::CAMMSModule()
{
}

//  End of File