callcontinuity/vcc/src/vccengpspropertylistener.cpp
changeset 0 a4daefaec16c
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/callcontinuity/vcc/src/vccengpspropertylistener.cpp	Mon Jan 18 20:12:36 2010 +0200
@@ -0,0 +1,197 @@
+/*
+* Copyright (c) 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:   Observes the state of P&S property
+*
+*/
+
+
+
+#include <e32cmn.h>
+#include <vccsubscribekeys.h>
+
+#include "vccengpspropertylistener.h"
+#include "rubydebug.h"
+
+//#include "vccuipropertyhandler.pan"
+
+// ======== MEMBER FUNCTIONS ========
+// -----------------------------------------------------------------------------
+// C++ constructor
+// -----------------------------------------------------------------------------
+//
+CVccEngPsPropertyListener::CVccEngPsPropertyListener( 
+const TUid aCategoryUid,
+		const TUint aKeyId ):
+CActive( EPriorityStandard ),
+iCategoryId( aCategoryUid ),
+iKeyId( aKeyId )
+	{
+	RUBY_DEBUG_BLOCK( "VccEngPsPropertyListener::CVccEngPsPropertyListener" );
+	}
+
+// -----------------------------------------------------------------------------
+// 2nd phase constructor
+// -----------------------------------------------------------------------------
+//
+void CVccEngPsPropertyListener::ConstructL()
+    {
+    RUBY_DEBUG_BLOCKL( "CVccEngPsPropertyListener::ConstructL" );
+    // Attach to categroy and key.
+    User::LeaveIfError( iProperty.Attach( iCategoryId, iKeyId ));
+    // Add to active scheduler
+    CActiveScheduler::Add( this );
+    }
+
+// -----------------------------------------------------------------------------
+// Constructor
+// -----------------------------------------------------------------------------
+//
+CVccEngPsPropertyListener* CVccEngPsPropertyListener::NewL(
+		                                                 const TUid aCategoryId, 
+		                                                 const TUint aKeyId)   
+    {
+	RUBY_DEBUG_BLOCKL("CVccEngPsPropertyListener::NewL");
+   
+	CVccEngPsPropertyListener* self = new (ELeave) CVccEngPsPropertyListener( 
+			                                              aCategoryId, aKeyId );
+    CleanupStack::PushL( self );
+    self->ConstructL();
+    CleanupStack::Pop( self );
+   
+    return self;
+    }
+
+// -----------------------------------------------------------------------------
+// Destructor
+// -----------------------------------------------------------------------------
+//
+CVccEngPsPropertyListener::~CVccEngPsPropertyListener()
+    {
+    RUBY_DEBUG0( "CVccEngPsPropertyListener::~CVccEngPsPropertyListener() - ENTER" );
+    Cancel();
+    iProperty.Close();
+    iObservers.Close();
+    RUBY_DEBUG0( "CVccEngPsPropertyListener::~CVccEngPsPropertyListener() - EXIT" );
+    }
+
+// -----------------------------------------------------------------------------
+// Add Vcc property observer
+// -----------------------------------------------------------------------------
+//
+void CVccEngPsPropertyListener::AddObserverL( 
+        MVccEngPsPropertyListenerObserver& aObserver )
+    {
+    RUBY_DEBUG_BLOCKL( "CVccEngPsPropertyListener::AddObserverL" );
+    
+    if ( iObservers.Find( &aObserver ) == KErrNotFound )
+        {
+        User::LeaveIfError( iObservers.Append( &aObserver ) );
+        }
+    }
+
+// -----------------------------------------------------------------------------
+// Removes observer
+// -----------------------------------------------------------------------------
+//
+void CVccEngPsPropertyListener::RemoveObserver( 
+        MVccEngPsPropertyListenerObserver& aObserver )
+    {
+    RUBY_DEBUG_BLOCK( "CVccEngPsPropertyListener::RemoveObserver" );
+   
+    TInt index = iObservers.Find( &aObserver );
+    
+    if ( index != KErrNotFound )
+        {
+        iObservers.Remove( index );
+        }
+    }
+
+// -----------------------------------------------------------------------------
+// Fetches the current value of the key
+// -----------------------------------------------------------------------------
+//
+TInt CVccEngPsPropertyListener::CurrentValue()
+    {
+    RUBY_DEBUG_BLOCK( "CVccEngPsPropertyListener::CurrentValue" );
+   
+    TInt value( KErrNotFound );
+    iProperty.Get( iCategoryId, iKeyId, value );
+    return value;
+    }
+
+
+// -----------------------------------------------------------------------------
+// Cancels the outstanding subsription request
+// -----------------------------------------------------------------------------
+//
+void CVccEngPsPropertyListener::DoCancel()
+    {
+    RUBY_DEBUG0( "CVccEngPsPropertyListener::DoCancel - ENTER" );
+    iProperty.Cancel();
+    RUBY_DEBUG0( "CVccEngPsPropertyListener::DoCancel - EXIT" );
+    }
+
+// -----------------------------------------------------------------------------
+// Subsribes to property
+// -----------------------------------------------------------------------------
+//
+void CVccEngPsPropertyListener::Start()
+    {
+    RUBY_DEBUG_BLOCK( "CVccEngPsPropertyListener::Start" );
+   
+    // Subscribe to get updates.
+    iProperty.Subscribe( iStatus );
+    SetActive();
+    }
+
+// -----------------------------------------------------------------------------
+// RunL
+// -----------------------------------------------------------------------------
+//
+void CVccEngPsPropertyListener::RunL()
+    {
+    TInt err = iStatus.Int();
+Start();
+    RUBY_DEBUG_BLOCK( "CVccEngPsPropertyListener::RunL" );
+    RUBY_DEBUG1( " - Status: %d", iStatus.Int() );
+    if ( KErrNone == err )
+        {
+        RUBY_DEBUG0( " - CVccEngPsPropertyListener::RunL - \
+                     if ( KErrNone == err )" );
+        // Notify property changes to observers.
+        NotifyObserversL();
+        }
+    }
+
+// -----------------------------------------------------------------------------
+// Notify all observers about the changed value
+// -----------------------------------------------------------------------------
+//
+void CVccEngPsPropertyListener::NotifyObserversL()
+    {
+    RUBY_DEBUG_BLOCKL( "CVccEngPsPropertyListener::NotifyObserversL" );
+   
+    TInt value = CurrentValue();
+    RUBY_DEBUG1( " - value [%d]", value );
+   
+    for ( TInt i(0) ; i < iObservers.Count() ; i++ )
+        {
+        MVccEngPsPropertyListenerObserver* observer = iObservers[i];
+
+        if ( observer )
+            {
+            observer->PropertyChangedL( iCategoryId, iKeyId, value );
+            }
+        }
+    }