accessoryservices/pluggeddisplay/pluggeddisplayengine/src/centralrepositorywatch.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 31 Mar 2010 23:31:40 +0300
branchRCL_3
changeset 7 1fc153c72b60
parent 0 4e1aa6a622a0
permissions -rw-r--r--
Revision: 201011 Kit: 201013

/*
* Copyright (c) 2009 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:  A class to watch changes of key values in Central Repository.
*
*/



#include    <e32base.h>
#include    <e32def.h>
#include    <centralrepository.h>


#include "centralrepositorywatch.h"
#include "trace.h"


// ======== LOCAL FUNCTIONS ========


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

// ---------------------------------------------------------
// Symbian two-phased constructor
// ---------------------------------------------------------
//
CCentralRepositoryWatch* CCentralRepositoryWatch::NewL(
        MCentralRepositoryObserver&   aObserver,
        TUid aRepositoryUid,
        TUint32 aKeyId )
    {
    FUNC_LOG;
    CCentralRepositoryWatch* self = new ( ELeave ) CCentralRepositoryWatch(
            aObserver,
            aRepositoryUid,
            aKeyId );
    CleanupStack::PushL( self );
    self->ConstructL();
    CleanupStack::Pop( self );
    return self;
    }


// ---------------------------------------------------------------------------
// Symbian two-phased constructor
// ---------------------------------------------------------------------------
//
CCentralRepositoryWatch* CCentralRepositoryWatch::NewLC(
        MCentralRepositoryObserver&   aObserver,
        TUid aRepositoryUid,
        TUint32 aKeyId )
    {
    FUNC_LOG;
    CCentralRepositoryWatch* self = new( ELeave ) CCentralRepositoryWatch(
            aObserver,
            aRepositoryUid,
            aKeyId );
    CleanupStack::PushL( self );
    self->ConstructL();
    return self;
    }


// ---------------------------------------------------------
// Destructor
// ---------------------------------------------------------
//
CCentralRepositoryWatch::~CCentralRepositoryWatch()
    {
    FUNC_LOG;
    Cancel();
    delete iRepository;
    }

// ---------------------------------------------------------
// SubscribeNotification
// ---------------------------------------------------------
//
void CCentralRepositoryWatch::Watch()
    {
    FUNC_LOG;
    // Subscribe
    if ( !IsActive() )
        {
        iRepository->NotifyRequest( iKey, iStatus );
        SetActive();        
        }
    return;
    }


// ---------------------------------------------------------
// Get current value.
// ---------------------------------------------------------
//
TInt CCentralRepositoryWatch::GetCurrentValue( TInt& aValue)
    {
    FUNC_LOG;
    TInt value(0);
    TInt aError = iRepository->Get(iKey, value); //try to get the value
    if(KErrNone == aError)
        {
        aValue = value;
        }
    else 
        {
        iObserver.CentRepGetKeyValueFailed( iRepositoryUid, iKey, aError );
        }
    INFO_1( "Return aValue 0x%x", aValue );
    return aError;
    }


// ---------------------------------------------------------
// From class CActive.
// DoCancel
// ---------------------------------------------------------
//
void CCentralRepositoryWatch::DoCancel()
    {
    FUNC_LOG;
    iRepository->NotifyCancel( iKey );
    }


// ---------------------------------------------------------
// C++ constructor
// ---------------------------------------------------------
//
CCentralRepositoryWatch::CCentralRepositoryWatch(
        MCentralRepositoryObserver& aObserver,
        TUid aRepositoryUid,
        TUint32 aKeyId )
    : CActive ( EPriorityStandard),
    iObserver ( aObserver )
    {
    FUNC_LOG;
    iRepositoryUid = aRepositoryUid;
    iKey = aKeyId;
    }


// ---------------------------------------------------------
// ConstructL
// ---------------------------------------------------------
//
void CCentralRepositoryWatch::ConstructL( )
    {
    FUNC_LOG;
    // Connect CenRep
    iRepository = CRepository::NewL( iRepositoryUid );
    // Check that key is valid
    TInt aCurrentValue;
    TInt errorCode = GetCurrentValue( aCurrentValue );
    if ( KErrNone != errorCode )
        {
        User::Leave( errorCode );
        }
    CActiveScheduler::Add( this );
    return;
   }

// ---------------------------------------------------------
// From class CActive.
// RunL
// ---------------------------------------------------------
//
void CCentralRepositoryWatch::RunL()
    {
    FUNC_LOG;

    // Get the value
    TInt aCurrentValue = 0;
    
    // Re-subscribe before notifying The Master
    iRepository->NotifyRequest( iKey, iStatus );
    SetActive();
    
    TInt errorCode = GetCurrentValue( aCurrentValue );
    if ( KErrNone == errorCode )
        {
        // Notify requester
        iObserver.CentRepKeyChanged(
                iRepositoryUid,
                iKey );
        }
    else
        {
        INFO_1( "RRepsitory::Get()failed aError %d", errorCode );
        iObserver.CentRepGetKeyValueFailed( iRepositoryUid, iKey, errorCode );
        }
    }


// ---------------------------------------------------------
// From class CActive.
// RunL
// ---------------------------------------------------------
//
TInt CCentralRepositoryWatch::RunError( TInt aError )
    {
    FUNC_LOG;
    // Avoid Panic in CActiveScheduler
    INFO_1( "aError %d", aError );
    INFO("Issuing a new request for key value changes");
    Watch();
    aError = KErrNone;
    return aError;
    }


// ======== GLOBAL FUNCTIONS ========