usbmgmt/usbmgrtest/t_ncm/src/ncmwatcher.cpp
author hgs
Wed, 03 Nov 2010 10:49:35 +0800
changeset 63 705964cc7132
parent 28 f1fd07aa74c9
permissions -rw-r--r--
201043_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
28
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     1
/*
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     3
* All rights reserved.
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     8
*
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     9
* Initial Contributors:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    11
*
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    12
* Contributors:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    13
*
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    14
* Description:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    15
*
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    16
*/
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    17
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    18
/** @file
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    19
 @internalComponent
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    20
 @test
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    21
 */
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    22
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    23
#include "ncmwatcher.h"
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    24
#include "ncmtestconsole.h"
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    25
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    26
using namespace UsbNcm;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    27
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    28
//
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    29
// CSharedStateWatcher
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    30
//
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    31
CSharedStateWatcher* CSharedStateWatcher::NewL(CUsbNcmConsole& aConsole)
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    32
    {
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    33
    CSharedStateWatcher* self = new (ELeave) CSharedStateWatcher(aConsole);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    34
    CleanupStack::PushL(self);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    35
    self->ConstructL();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    36
    CleanupStack::Pop(self);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    37
    return self;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    38
    }
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    39
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    40
CSharedStateWatcher::CSharedStateWatcher(CUsbNcmConsole& aConsole) :
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    41
    CActive(EPriorityStandard), iConsole(aConsole), iNcmStateDes(
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    42
            reinterpret_cast<TUint8*> (&iSharedState), sizeof(iSharedState),
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    43
            sizeof(iSharedState))
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    44
    {
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    45
    CActiveScheduler::Add(this);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    46
    }
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    47
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    48
CSharedStateWatcher::~CSharedStateWatcher()
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    49
    {
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    50
    Cancel();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    51
    iProperty.Close();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    52
    }
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    53
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    54
void CSharedStateWatcher::ConstructL()
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    55
    {
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    56
    User::LeaveIfError(iProperty.Attach(KC32ExeSid, KKeyNcmConnectionEvent));
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    57
    reportState();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    58
    iProperty.Subscribe(iStatus);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    59
    SetActive();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    60
    }
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    61
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    62
void CSharedStateWatcher::RunL()
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    63
    {
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    64
    TInt err = iStatus.Int();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    65
    iProperty.Subscribe(iStatus);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    66
    SetActive();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    67
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    68
    if (KErrNone == err)
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    69
        {
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    70
        reportState();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    71
        }
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    72
    }
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    73
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    74
void CSharedStateWatcher::reportState()
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    75
    {
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    76
    iProperty.Get(iNcmStateDes);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    77
    TBuf<DISPLAY_NCM_CONNECTION_STATE> stateBuf;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    78
    switch (iSharedState.iState)
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    79
        {
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    80
        case ENcmStateDisconnected:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    81
            stateBuf = _L("DisConnected");
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    82
            break;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    83
        case ENcmStateConnected:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    84
            stateBuf = _L("Connected");
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    85
            break;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    86
        default:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    87
            stateBuf = _L("Unknown");
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    88
            break;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    89
        }
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    90
    __FLOG_STATIC2(KSubSys, KLogComponent ,
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    91
            _L8("NCM state=%d, iapid=%d"), iSharedState.iState, iSharedState.iIapId);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    92
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    93
    iConsole.SetLocalIapId(iSharedState.iIapId);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    94
    iConsole.SetDisplayItem(ENcmConnectionStateItem, stateBuf);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    95
    }
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    96
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    97
/**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    98
 Stop checking the shared state 
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    99
 */
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   100
void CSharedStateWatcher::DoCancel()
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   101
    {
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   102
    iProperty.Cancel();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   103
    }