voipplugins/sipconnectionprovider/src/scppropertynotifier.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 18 Jan 2010 20:12:36 +0200
changeset 0 a4daefaec16c
permissions -rw-r--r--
Revision: 201001 Kit: 201003

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


#include "scppropertynotifier.h"
#include "scplogger.h"
#include "scppropertyobserver.h"

// -----------------------------------------------------------------------------
// CScpPropertyNotifier::CCScpPropertyNotifier
// -----------------------------------------------------------------------------
//
CScpPropertyNotifier::CScpPropertyNotifier( TUid aUid, 
                                            TInt aType, 
                                            MScpPropertyObserver& aObserver ) :
    CActive( CActive::EPriorityStandard ),
    iUid( aUid ),
    iType( aType ),
    iObserver( aObserver )
    {
    SCPLOGSTRING( "CScpPropertyNotifier::CScpPropertyNotifier" );

    CActiveScheduler::Add( this );
    }

// -----------------------------------------------------------------------------
// CScpPropertyNotifier::ConstructL
// -----------------------------------------------------------------------------
//
void CScpPropertyNotifier::ConstructL()
    {
    SCPLOGSTRING( "CScpPropertyNotifier::ConstructL" );
    
    User::LeaveIfError( iProperty.Attach( iUid, iType ) );

    Subscribe();
    }

// -----------------------------------------------------------------------------
// CScpPropertyNotifier::NewL
// -----------------------------------------------------------------------------
//
CScpPropertyNotifier* CScpPropertyNotifier::NewL( TUid aUid, 
                                                  TInt aType,
                                                  MScpPropertyObserver& aObserver )
    {
    SCPLOGSTRING( "CScpPropertyNotifier::NewL" );
    
    CScpPropertyNotifier* self = new(ELeave) CScpPropertyNotifier( aUid, 
                                                                   aType,
                                                                   aObserver );
    CleanupStack::PushL( self );    
    self->ConstructL();    
    CleanupStack::Pop( self );
    return self;
    }

// -----------------------------------------------------------------------------
// CScpPropertyNotifier::~CScpPropertyNotifier
// -----------------------------------------------------------------------------
//
CScpPropertyNotifier::~CScpPropertyNotifier()
    {
    SCPLOGSTRING( "CScpPropertyNotifier::~CScpPropertyNotifier" );
    
    Cancel();
    iProperty.Close();
    }

// -----------------------------------------------------------------------------
// CScpPropertyNotifier::GetValue
// -----------------------------------------------------------------------------
//
TInt CScpPropertyNotifier::GetValue( TInt& aValue ) const
    {
    SCPLOGSTRING( "CScpPropertyNotifier::GetValue" );
    
    return iProperty.Get( iUid, iType, aValue );
    }

// -----------------------------------------------------------------------------
// CScpPropertyNotifier::Subscribe
// -----------------------------------------------------------------------------
//
void CScpPropertyNotifier::Subscribe()
    {
    SCPLOGSTRING( "CScpPropertyNotifier::Subscribe" );      
    __ASSERT_DEBUG(!IsActive(), User::Panic( KNullDesC, KErrGeneral ) );

    if ( !IsActive() )
        {
        iProperty.Subscribe( iStatus );    
        SetActive();
        }
    }

// -----------------------------------------------------------------------------
// CScpPropertyNotifier::RunL
// -----------------------------------------------------------------------------
//
void CScpPropertyNotifier::RunL()
    {
    SCPLOGSTRING( "CScpPropertyNotifier::RunL" );

    if( iStatus.Int() == KErrNone )
        {        
        TInt value = 0;
        GetValue( value );

        iObserver.HandlePropertyChanged( value );
        }

    Subscribe();            
    }

// -----------------------------------------------------------------------------
// CScpPropertyNotifier::NewL
// -----------------------------------------------------------------------------
//
#ifdef _DEBUG
TInt CScpPropertyNotifier::RunError( TInt aError )
    {
    SCPLOGSTRING2( "CScpPropertyNotifier::RunError: %d", aError );
#else
TInt CScpPropertyNotifier::RunError( TInt /*aError*/ )
    {
#endif
    // Errors are disarded
    return KErrNone;
    }

// -----------------------------------------------------------------------------
// CScpPropertyNotifier::NewL
// -----------------------------------------------------------------------------
//
void CScpPropertyNotifier::DoCancel()
    {
    SCPLOGSTRING( "CScpPropertyNotifier::DoCancel" );
    
    iProperty.Cancel();
    }

//  End of File