satengine/satserver/SystemState/src/CSatPSChangeNotifier.cpp
author hgs
Fri, 15 Oct 2010 13:21:28 +0300
changeset 53 25b8d29b7c59
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2007 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Notifies the changes in publish and suscripe properties.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
// INCLUDE FILES
hgs
parents:
diff changeset
    21
#include    "CSatPSChangeNotifier.h"
hgs
parents:
diff changeset
    22
#include    "MSatSystemStateObserver.h"
hgs
parents:
diff changeset
    23
#include    "Panic.h"
hgs
parents:
diff changeset
    24
#include    "SatLog.h"
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// ============================ MEMBER FUNCTIONS ===============================
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    29
// CSatPSChangeNotifier::CSatPSChangeNotifier
hgs
parents:
diff changeset
    30
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
    31
// might leave.
hgs
parents:
diff changeset
    32
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    33
//
hgs
parents:
diff changeset
    34
CSatPSChangeNotifier::CSatPSChangeNotifier(
hgs
parents:
diff changeset
    35
    const TUid& aPropertyKey,
hgs
parents:
diff changeset
    36
    TUint aPropertyValue,
hgs
parents:
diff changeset
    37
    MSatSystemStateObserver& aObserver,
hgs
parents:
diff changeset
    38
    TInt aNotifyValue ) :
hgs
parents:
diff changeset
    39
    CActive( EPriorityStandard ),
hgs
parents:
diff changeset
    40
    iObserver( aObserver ),
hgs
parents:
diff changeset
    41
    iPSKey( aPropertyKey ),
hgs
parents:
diff changeset
    42
    iPSValue( aPropertyValue ),
hgs
parents:
diff changeset
    43
    iNotifyValue( aNotifyValue )
hgs
parents:
diff changeset
    44
    {
hgs
parents:
diff changeset
    45
    LOG( SIMPLE,
hgs
parents:
diff changeset
    46
        "SATSYSTEMSTATE: CSatPSChangeNotifier::CSatPSChangeNotifier calling" )
hgs
parents:
diff changeset
    47
    // Log parameters
hgs
parents:
diff changeset
    48
    LOG2( NORMAL,
hgs
parents:
diff changeset
    49
        "SATSYSTEMSTATE: CSatPSChangeNotifier::CSatPSChangeNotifier PS Uid: %d",
hgs
parents:
diff changeset
    50
        aPropertyKey )
hgs
parents:
diff changeset
    51
    LOG2( NORMAL,
hgs
parents:
diff changeset
    52
        "SATSYSTEMSTATE: CSatPSChangeNotifier::CSatPSChangeNotifier PS Key: %d",
hgs
parents:
diff changeset
    53
        aPropertyValue )
hgs
parents:
diff changeset
    54
    LOG2( NORMAL,
hgs
parents:
diff changeset
    55
        "SATSYSTEMSTATE: CSatPSChangeNotifier::CSatPSChangeNotifier Needed \
hgs
parents:
diff changeset
    56
        value: %d ", aNotifyValue )
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
    CActiveScheduler::Add( this );
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
    LOG( SIMPLE,
hgs
parents:
diff changeset
    61
        "SATSYSTEMSTATE: CSatPSChangeNotifier::CSatPSChangeNotifier exiting" )
hgs
parents:
diff changeset
    62
    }
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    65
// CSatPSChangeNotifier::NewL
hgs
parents:
diff changeset
    66
// Two-phased constructor.
hgs
parents:
diff changeset
    67
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    68
//
hgs
parents:
diff changeset
    69
CSatPSChangeNotifier* CSatPSChangeNotifier::NewL(
hgs
parents:
diff changeset
    70
    const TUid& aPropertyKey,
hgs
parents:
diff changeset
    71
    TUint aPropertyValue,
hgs
parents:
diff changeset
    72
    MSatSystemStateObserver& aObserver,
hgs
parents:
diff changeset
    73
    TInt aNotifyValue )
hgs
parents:
diff changeset
    74
    {
hgs
parents:
diff changeset
    75
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::NewL calling" )
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
    CSatPSChangeNotifier* self =
hgs
parents:
diff changeset
    78
        new( ELeave ) CSatPSChangeNotifier(
hgs
parents:
diff changeset
    79
            aPropertyKey, aPropertyValue, aObserver, aNotifyValue );
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::NewL exiting" )
hgs
parents:
diff changeset
    82
    return self;
hgs
parents:
diff changeset
    83
    }
hgs
parents:
diff changeset
    84
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
// Destructor
hgs
parents:
diff changeset
    87
CSatPSChangeNotifier::~CSatPSChangeNotifier()
hgs
parents:
diff changeset
    88
    {
hgs
parents:
diff changeset
    89
    LOG( SIMPLE,
hgs
parents:
diff changeset
    90
        "SATSYSTEMSTATE: CSatPSChangeNotifier::~CSatPSChangeNotifier calling" )
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
    Cancel();
hgs
parents:
diff changeset
    93
    iPSClient.Close();
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
    LOG( SIMPLE,
hgs
parents:
diff changeset
    96
        "SATSYSTEMSTATE: CSatPSChangeNotifier::~CSatPSChangeNotifier exiting" )
hgs
parents:
diff changeset
    97
    }
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   100
// CSatPSChangeNotifier::NotifyChangeL
hgs
parents:
diff changeset
   101
// Issues notification request.
hgs
parents:
diff changeset
   102
// (other items were commented in a header).
hgs
parents:
diff changeset
   103
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   104
//
hgs
parents:
diff changeset
   105
void CSatPSChangeNotifier::NotifyChangeL()
hgs
parents:
diff changeset
   106
    {
hgs
parents:
diff changeset
   107
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::NotifyChangeL calling" )
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
    __ASSERT_ALWAYS( !IsActive(), Panic( ESatSystemStateAllReadyActive ) );
hgs
parents:
diff changeset
   110
    User::LeaveIfError( iPSClient.Attach( iPSKey, iPSValue ) );
hgs
parents:
diff changeset
   111
    Activate();
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::NotifyChangeL exiting" )
hgs
parents:
diff changeset
   114
    }
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   117
// CSatPSChangeNotifier::CancelNotify
hgs
parents:
diff changeset
   118
// Cancels outstanding request.
hgs
parents:
diff changeset
   119
// (other items were commented in a header).
hgs
parents:
diff changeset
   120
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   121
//
hgs
parents:
diff changeset
   122
void CSatPSChangeNotifier::CancelNotify()
hgs
parents:
diff changeset
   123
    {
hgs
parents:
diff changeset
   124
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::CancelNotify calling" )
hgs
parents:
diff changeset
   125
hgs
parents:
diff changeset
   126
    Cancel();
hgs
parents:
diff changeset
   127
hgs
parents:
diff changeset
   128
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::CancelNotify exiting" )
hgs
parents:
diff changeset
   129
    }
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   132
// CSatPSChangeNotifier::DoCancel
hgs
parents:
diff changeset
   133
// (other items were commented in a header).
hgs
parents:
diff changeset
   134
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   135
//
hgs
parents:
diff changeset
   136
void CSatPSChangeNotifier::DoCancel()
hgs
parents:
diff changeset
   137
    {
hgs
parents:
diff changeset
   138
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::DoCancel calling" )
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
    iPSClient.Cancel();
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::DoCancel exiting" )
hgs
parents:
diff changeset
   143
    }
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   146
// CSatPSChangeNotifier::RunL
hgs
parents:
diff changeset
   147
// Activates the request again and calls the observer.
hgs
parents:
diff changeset
   148
// (other items were commented in a header).
hgs
parents:
diff changeset
   149
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   150
//
hgs
parents:
diff changeset
   151
void CSatPSChangeNotifier::RunL()
hgs
parents:
diff changeset
   152
    {
hgs
parents:
diff changeset
   153
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::RunL calling" )
hgs
parents:
diff changeset
   154
    // Makes sure that all the changes are notified.
hgs
parents:
diff changeset
   155
    LOG2( SIMPLE, "SATSYSTEMSTATE:   Failed: %i", iStatus.Int() )
hgs
parents:
diff changeset
   156
    if ( KErrNone == iStatus.Int() )
hgs
parents:
diff changeset
   157
        {
hgs
parents:
diff changeset
   158
        NotifyChangeL();
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
        // Check the value
hgs
parents:
diff changeset
   161
        TInt value = KNotifyValueNotSet;
hgs
parents:
diff changeset
   162
hgs
parents:
diff changeset
   163
        // Get the value from P&S
hgs
parents:
diff changeset
   164
        RProperty::Get( iPSKey, iPSValue, value );
hgs
parents:
diff changeset
   165
hgs
parents:
diff changeset
   166
        // If notify value is set, check the value before notifying observer
hgs
parents:
diff changeset
   167
        if ( KNotifyValueNotSet != iNotifyValue )
hgs
parents:
diff changeset
   168
            {
hgs
parents:
diff changeset
   169
            LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::RunL \
hgs
parents:
diff changeset
   170
            KNotifyValueNotSet != iNotifyValue" )
hgs
parents:
diff changeset
   171
            // If changed P&S value is same as notify value, notify observer
hgs
parents:
diff changeset
   172
            if ( value == iNotifyValue )
hgs
parents:
diff changeset
   173
                {
hgs
parents:
diff changeset
   174
                LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::RunL \
hgs
parents:
diff changeset
   175
                value == iNotifyValue" )
hgs
parents:
diff changeset
   176
                iObserver.StateChanged();
hgs
parents:
diff changeset
   177
                }
hgs
parents:
diff changeset
   178
            }
hgs
parents:
diff changeset
   179
        else
hgs
parents:
diff changeset
   180
            {
hgs
parents:
diff changeset
   181
            LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::RunL \
hgs
parents:
diff changeset
   182
            KNotifyValueNotSet == iNotifyValue" )
hgs
parents:
diff changeset
   183
            // Notify value not specified -> Send the changed value
hgs
parents:
diff changeset
   184
            iObserver.StateChanged( value );
hgs
parents:
diff changeset
   185
            }
hgs
parents:
diff changeset
   186
        }
hgs
parents:
diff changeset
   187
    else if ( KErrCancel == iStatus.Int() )
hgs
parents:
diff changeset
   188
        {
hgs
parents:
diff changeset
   189
        Activate();
hgs
parents:
diff changeset
   190
        }
hgs
parents:
diff changeset
   191
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::RunL exiting" )
hgs
parents:
diff changeset
   192
    }
hgs
parents:
diff changeset
   193
hgs
parents:
diff changeset
   194
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   195
// CSatPSChangeNotifier::Activate
hgs
parents:
diff changeset
   196
// (other items were commented in a header).
hgs
parents:
diff changeset
   197
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   198
//
hgs
parents:
diff changeset
   199
void CSatPSChangeNotifier::Activate()
hgs
parents:
diff changeset
   200
    {
hgs
parents:
diff changeset
   201
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::Activate calling" )
hgs
parents:
diff changeset
   202
hgs
parents:
diff changeset
   203
    iPSClient.Subscribe( iStatus );
hgs
parents:
diff changeset
   204
    SetActive();
hgs
parents:
diff changeset
   205
hgs
parents:
diff changeset
   206
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::Activate exiting" )
hgs
parents:
diff changeset
   207
    }
hgs
parents:
diff changeset
   208
hgs
parents:
diff changeset
   209
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   210
// CSatPSChangeNotifier::GetValueInt
hgs
parents:
diff changeset
   211
// (other items were commented in a header).
hgs
parents:
diff changeset
   212
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   213
//
hgs
parents:
diff changeset
   214
TInt CSatPSChangeNotifier::GetValueInt()
hgs
parents:
diff changeset
   215
    {
hgs
parents:
diff changeset
   216
    LOG( SIMPLE, "SATSYSTEMSTATE: CSatPSChangeNotifier::GetValueInt calling" )
hgs
parents:
diff changeset
   217
hgs
parents:
diff changeset
   218
    // Gets the value from P&S.
hgs
parents:
diff changeset
   219
    TInt value( KNotifyValueNotSet );
hgs
parents:
diff changeset
   220
    RProperty::Get( iPSKey, iPSValue, value );
hgs
parents:
diff changeset
   221
hgs
parents:
diff changeset
   222
    LOG2( SIMPLE, 
hgs
parents:
diff changeset
   223
        "SATSYSTEMSTATE: CSatPSChangeNotifier::GetValueInt exiting %i",
hgs
parents:
diff changeset
   224
        value )
hgs
parents:
diff changeset
   225
    return value;
hgs
parents:
diff changeset
   226
    }
hgs
parents:
diff changeset
   227
    
hgs
parents:
diff changeset
   228
//  End of File