resourcemgmt/hwresourcesmgr/vibra/src/HWRMVibraStatusObserver.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 00:53:00 +0200
changeset 0 4e1aa6a622a0
permissions -rw-r--r--
Revision: 201003

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




// INCLUDE FILES
#include "HWRMPrivatePSKeys.h"
#include "HWRMtrace.h"
#include "HWRMVibra.h"
#include "HWRMVibraStatusObserver.h"

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

// -----------------------------------------------------------------------------
// CHWRMVibraStatusObserver::CHWRMVibraStatusObserver
// C++ constructor can NOT contain any code, that
// might leave.
// -----------------------------------------------------------------------------
//
CHWRMVibraStatusObserver::CHWRMVibraStatusObserver(MHWRMVibraObserver* aCallback)
    : CActive(EPriorityStandard), iCallback(aCallback)
    {
    COMPONENT_TRACE2(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::CHWRMVibraStatusObserver(0x%x)" ), aCallback);

    CActiveScheduler::Add(this);

    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::CHWRMVibraStatusObserver - return" ) );
    }

// -----------------------------------------------------------------------------
// CHWRMVibraStatusObserver::NewL
// Two-phased constructor
// -----------------------------------------------------------------------------
//
CHWRMVibraStatusObserver* CHWRMVibraStatusObserver::NewL(MHWRMVibraObserver* aCallback)
    {

    COMPONENT_TRACE2(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::NewLC(0x%x)" ), aCallback);

	CHWRMVibraStatusObserver* newInstance = new (ELeave) CHWRMVibraStatusObserver(aCallback);

	CleanupStack::PushL( newInstance );
	
	newInstance->ConstructL();

	CleanupStack::Pop();

    COMPONENT_TRACE2(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::NewLC - return 0x%x" ), newInstance);

	return newInstance;
    }


// -----------------------------------------------------------------------------
// Destructor
// -----------------------------------------------------------------------------
//
CHWRMVibraStatusObserver::~CHWRMVibraStatusObserver()
    {
    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::~CHWRMVibraStatusObserver()" ));

    // Cancel property separately, as the following Cancel() call doesn't seem to 
    // cause DoCancel to fire.
    iProperty.Cancel();

    Cancel();
    
    iProperty.Close();
    
    iCallback = NULL; // PCLint demands

    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::~CHWRMVibraStatusObserver - return" ) );
    }

// -----------------------------------------------------------------------------
// CHWRMVibraStatusObserver::ConstructL
// Symbian 2nd phase constructor can leave.
// -----------------------------------------------------------------------------
//
void CHWRMVibraStatusObserver::ConstructL()
    {
    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::ConstructL()" ));

    User::LeaveIfError(iProperty.Attach(KPSUidHWResourceNotification, KHWRMVibraStatus));
    
    // Call RunL to order notification and do the initial notifying of the client
    RunL();

    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::ConstructL - return" ) );
    }

// -----------------------------------------------------------------------------
// CHWRMVibraStatusObserver::RunL
// Handle notification from pubsub session.
// -----------------------------------------------------------------------------
//
void CHWRMVibraStatusObserver::RunL()
    {
    // NOTE: RunL cannot currently leave, so it's not necessary to implement RunError. 
    // Remember to implement it if any change to RunL make it a leaving function.
    
    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::RunL()" ));

	User::LeaveIfError(KErrNone); // avoid leavescan error
	
    // Reorder notification
    OrderNotification();

    // get value from pubsub
    TInt value(CHWRMVibra::EVibraStatusUnknown);
    
    TInt err = iProperty.Get(value);
    
    // if no error or not found then no problem.
    // Otherwise leave as something went wrong
    if ( err == KErrNotFound || err == KErrNone )
        {
        CHWRMVibra::TVibraStatus status = static_cast<CHWRMVibra::TVibraStatus>(value);
        
        // Only notify if value actually changed
        if ( iCallback && iVibraStatus != status)
            {            
            iCallback->VibraStatusChanged(status);    
            }
        iVibraStatus = status;
        }
    else
        {
        COMPONENT_TRACE2(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::RunL. Error (%d) in iProperty.Get()" ), err);
	    if ( iCallback && iVibraStatus != CHWRMVibra::EVibraStatusUnknown)
	        {        
	        iCallback->VibraStatusChanged(CHWRMVibra::EVibraStatusUnknown);
	        }
	    
	    iVibraStatus = CHWRMVibra::EVibraStatusUnknown;
        }

    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::RunL - return" ) );
    }
    
// -----------------------------------------------------------------------------
// CHWRMVibraStatusObserver::DoCancel
// Handle cancel order on this active object.
// -----------------------------------------------------------------------------
//
void CHWRMVibraStatusObserver::DoCancel()
    {
    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::DoCancel()" ));

    iProperty.Cancel();

    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::DoCancel - return" ) );
    }

// -----------------------------------------------------------------------------
// CHWRMVibraStatusObserver::OrderNotification
// Order new notification from CenRep.
// -----------------------------------------------------------------------------
//
void CHWRMVibraStatusObserver::OrderNotification()
    {
    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::OrderNotification()" ));

    iProperty.Subscribe(iStatus);
    SetActive();

    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::OrderNotification - return" ) );
    }


// -----------------------------------------------------------------------------
// CHWRMVibraStatusObserver::CurrentStatus
// Return vibra status
// -----------------------------------------------------------------------------
//
CHWRMVibra::TVibraStatus CHWRMVibraStatusObserver::CurrentStatus() const
    {
    COMPONENT_TRACE1(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::CurrentStatus()" ));
    
    TInt value(CHWRMVibra::EVibraStatusUnknown);
    CHWRMVibra::TVibraStatus retval(CHWRMVibra::EVibraStatusUnknown);
    
    TInt err = RProperty::Get(KPSUidHWResourceNotification, KHWRMVibraStatus, value);
    
    if ( err != KErrNone )
        {
        // Perhaps a different status value other than the current one 
        // should be considered
        retval = iVibraStatus;
        }
    else
        {
        retval = static_cast<CHWRMVibra::TVibraStatus>(value);
        }
    
    COMPONENT_TRACE2(_L( "HWRM VibraClient - CHWRMVibraStatusObserver::CurrentStatus - return 0x%x" ), retval );
    
    return retval;
    }
    

// End of File