javaextensions/pim/agnadapter/src.s60/cpimmemoadaptermanager.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 27 Apr 2010 16:30:29 +0300
branchRCL_3
changeset 14 04becd199f91
permissions -rw-r--r--
Revision: v2.1.22 Kit: 201017

/*
* Copyright (c) 2008 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:  Provides static information about event lists and creates
 *                event list adapters.
 *
*/


// INCLUDE FILES
#include "cpimmemoadaptermanager.h"
#include "cpimeventlistadapter.h"
#include "cpimagnmemoadapter.h"
#include "logger.h"

// -----------------------------------------------------------------------------
// CPIMMemoAdapterManager::CPIMMemoAdapterManager
// C++ default constructor can NOT contain any code, that
// might leave.
// -----------------------------------------------------------------------------
//

CPIMMemoAdapterManager::CPIMMemoAdapterManager()
{
    JELOG2(EPim);
}

// -----------------------------------------------------------------------------
// CPIMMemoAdapterManager::ConstructL
// Symbian 2nd phase constructor can leave.
// -----------------------------------------------------------------------------
//

void CPIMMemoAdapterManager::ConstructL(const TDesC& aListName)
{
    JELOG2(EPim);
    CPIMEventAdapterManager::ConstructL(aListName);

    iSupportedFields
    = new(ELeave) CArrayFixFlat<TPIMField> (KPIMSupportedMemoFieldsCount);

    iSupportedFields->AppendL(KPIMSupportedMemoFields,
                              KPIMSupportedMemoFieldsCount);
}

// -----------------------------------------------------------------------------
// CPIMMemoAdapterManager::NewL
// Two-phased constructor.
// -----------------------------------------------------------------------------
//

CPIMMemoAdapterManager* CPIMMemoAdapterManager::NewL(const TDesC& aListName)
{
    JELOG2(EPim);
    CPIMMemoAdapterManager* self = new(ELeave) CPIMMemoAdapterManager();

    CleanupStack::PushL(self);
    self->ConstructL(aListName);
    CleanupStack::Pop(self);

    return self;
}

// Destructor
CPIMMemoAdapterManager::~CPIMMemoAdapterManager()
{
    JELOG2(EPim);
    delete iSupportedFields;
    delete iRepeatRuleFieldArrayMemoEmpty;
}

// -----------------------------------------------------------------------------
// CPIMMemoAdapterManager::GetAdapterManager
// Returns: A MPIMAdapterManager representation of this object.
// -----------------------------------------------------------------------------
//

MPIMAdapterManager* CPIMMemoAdapterManager::GetAdapterManager()
{
    JELOG2(EPim);
    return this;
}

// -----------------------------------------------------------------------------
// CPIMMemoAdapterManager::GetSupportedRepeatRuleFields
// Provides the supported repeat rule fields for a given frequency.
// Returns: Supported repeat rule fields for \a aFrequency. If no
// fields are supported for the frequency, an empty array is returned.
// -----------------------------------------------------------------------------
//

const CArrayFix<TPIMField>&
CPIMMemoAdapterManager::GetSupportedRepeatRuleFieldsL(
    const TPIMRepeatRuleFrequency& aFrequency)
{
    JELOG2(EPim);
    if (aFrequency != EPIMRepeatRuleDaily && aFrequency != EPIMRepeatRuleWeekly
            && aFrequency != EPIMRepeatRuleMonthly && aFrequency
            != EPIMRepeatRuleYearly)
    {
        User::Leave(KErrArgument); // invalid frequency
    }

    // Frequency is valid, return an empty array indicating no supported fields
    if (!iRepeatRuleFieldArrayMemoEmpty)
    {
        iRepeatRuleFieldArrayMemoEmpty = new(ELeave) CArrayFixFlat<TInt> (1);
    }
    return *iRepeatRuleFieldArrayMemoEmpty;
}

// -----------------------------------------------------------------------------
// CPIMMemoAdapterManager::GetSupportedIntervals
// Provides the supported interval values for given frequency.
// Returns: Supported interval values for given frequency. If the
// interval field is not supported for given frequency,
// an empty array is returned.
// -----------------------------------------------------------------------------
//

const CArrayFix<TInt>& CPIMMemoAdapterManager::GetSupportedIntervalsL(
    const TPIMRepeatRuleFrequency& aFrequency)
{
    JELOG2(EPim);
    // As there are no supported intervals, the GetSupportedRepeatRuleFieldsL
    // method can be used to check the frequency and to return an empty array
    return GetSupportedRepeatRuleFieldsL(aFrequency);
}

//  End of File