usbengines/usbwatcher/src/cusbindicatorhandler.cpp
author hgs
Mon, 17 May 2010 11:03:15 +0300
changeset 52 831068540b07
permissions -rw-r--r--
201019_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
52
831068540b07 201019_1
hgs
parents:
diff changeset
     1
/*
831068540b07 201019_1
hgs
parents:
diff changeset
     2
* Copyright (c) 2009-2010 Nokia Corporation and/or its subsidiary(-ies).
831068540b07 201019_1
hgs
parents:
diff changeset
     3
* All rights reserved.
831068540b07 201019_1
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
831068540b07 201019_1
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
831068540b07 201019_1
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
831068540b07 201019_1
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
831068540b07 201019_1
hgs
parents:
diff changeset
     8
*
831068540b07 201019_1
hgs
parents:
diff changeset
     9
* Initial Contributors:
831068540b07 201019_1
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
831068540b07 201019_1
hgs
parents:
diff changeset
    11
*
831068540b07 201019_1
hgs
parents:
diff changeset
    12
* Contributors:
831068540b07 201019_1
hgs
parents:
diff changeset
    13
*
831068540b07 201019_1
hgs
parents:
diff changeset
    14
* Description:  This implements TUsbIndicatorHandler class.
831068540b07 201019_1
hgs
parents:
diff changeset
    15
*
831068540b07 201019_1
hgs
parents:
diff changeset
    16
*/
831068540b07 201019_1
hgs
parents:
diff changeset
    17
831068540b07 201019_1
hgs
parents:
diff changeset
    18
#include <e32std.h>
831068540b07 201019_1
hgs
parents:
diff changeset
    19
#include <hbindicatorsymbian.h>
831068540b07 201019_1
hgs
parents:
diff changeset
    20
#include <hbsymbianvariant.h>
831068540b07 201019_1
hgs
parents:
diff changeset
    21
#include <usbman.h>
831068540b07 201019_1
hgs
parents:
diff changeset
    22
#include "debug.h"
831068540b07 201019_1
hgs
parents:
diff changeset
    23
#include "cusbindicatorhandler.h"
831068540b07 201019_1
hgs
parents:
diff changeset
    24
831068540b07 201019_1
hgs
parents:
diff changeset
    25
831068540b07 201019_1
hgs
parents:
diff changeset
    26
// ---------------------------------------------------------------------------
831068540b07 201019_1
hgs
parents:
diff changeset
    27
// C++ Constructor 
831068540b07 201019_1
hgs
parents:
diff changeset
    28
// ---------------------------------------------------------------------------
831068540b07 201019_1
hgs
parents:
diff changeset
    29
//
831068540b07 201019_1
hgs
parents:
diff changeset
    30
831068540b07 201019_1
hgs
parents:
diff changeset
    31
CUsbIndicatorHandler::CUsbIndicatorHandler()
831068540b07 201019_1
hgs
parents:
diff changeset
    32
    {
831068540b07 201019_1
hgs
parents:
diff changeset
    33
    // No implementation required
831068540b07 201019_1
hgs
parents:
diff changeset
    34
    }
831068540b07 201019_1
hgs
parents:
diff changeset
    35
831068540b07 201019_1
hgs
parents:
diff changeset
    36
CUsbIndicatorHandler::~CUsbIndicatorHandler()
831068540b07 201019_1
hgs
parents:
diff changeset
    37
    {
831068540b07 201019_1
hgs
parents:
diff changeset
    38
    delete iSymbianIndicator;  
831068540b07 201019_1
hgs
parents:
diff changeset
    39
831068540b07 201019_1
hgs
parents:
diff changeset
    40
    }
831068540b07 201019_1
hgs
parents:
diff changeset
    41
831068540b07 201019_1
hgs
parents:
diff changeset
    42
CUsbIndicatorHandler* CUsbIndicatorHandler::NewLC()
831068540b07 201019_1
hgs
parents:
diff changeset
    43
    {
831068540b07 201019_1
hgs
parents:
diff changeset
    44
    CUsbIndicatorHandler* self = new (ELeave) CUsbIndicatorHandler();
831068540b07 201019_1
hgs
parents:
diff changeset
    45
    CleanupStack::PushL(self);
831068540b07 201019_1
hgs
parents:
diff changeset
    46
    self->ConstructL();
831068540b07 201019_1
hgs
parents:
diff changeset
    47
    return self;
831068540b07 201019_1
hgs
parents:
diff changeset
    48
    }
831068540b07 201019_1
hgs
parents:
diff changeset
    49
831068540b07 201019_1
hgs
parents:
diff changeset
    50
CUsbIndicatorHandler* CUsbIndicatorHandler::NewL()
831068540b07 201019_1
hgs
parents:
diff changeset
    51
    {
831068540b07 201019_1
hgs
parents:
diff changeset
    52
    CUsbIndicatorHandler* self = CUsbIndicatorHandler::NewLC();
831068540b07 201019_1
hgs
parents:
diff changeset
    53
    CleanupStack::Pop(); // self;
831068540b07 201019_1
hgs
parents:
diff changeset
    54
    return self;
831068540b07 201019_1
hgs
parents:
diff changeset
    55
    }
831068540b07 201019_1
hgs
parents:
diff changeset
    56
831068540b07 201019_1
hgs
parents:
diff changeset
    57
void CUsbIndicatorHandler::ConstructL()
831068540b07 201019_1
hgs
parents:
diff changeset
    58
    {
831068540b07 201019_1
hgs
parents:
diff changeset
    59
     LOG_FUNC    
831068540b07 201019_1
hgs
parents:
diff changeset
    60
        
831068540b07 201019_1
hgs
parents:
diff changeset
    61
    iDevStateB4Suspend = EUsbDeviceStateUndefined;
831068540b07 201019_1
hgs
parents:
diff changeset
    62
    iSymbianIndicator = CHbIndicatorSymbian::NewL();
831068540b07 201019_1
hgs
parents:
diff changeset
    63
    }
831068540b07 201019_1
hgs
parents:
diff changeset
    64
831068540b07 201019_1
hgs
parents:
diff changeset
    65
// ---------------------------------------------------------------------------
831068540b07 201019_1
hgs
parents:
diff changeset
    66
// Change USB Indicator 
831068540b07 201019_1
hgs
parents:
diff changeset
    67
// ---------------------------------------------------------------------------
831068540b07 201019_1
hgs
parents:
diff changeset
    68
//
831068540b07 201019_1
hgs
parents:
diff changeset
    69
void CUsbIndicatorHandler::HandleDeviceStateChangeL( TUsbDeviceState aStateOld, 
831068540b07 201019_1
hgs
parents:
diff changeset
    70
            TUsbDeviceState aStateNew, TInt aPersonality )
831068540b07 201019_1
hgs
parents:
diff changeset
    71
    {
831068540b07 201019_1
hgs
parents:
diff changeset
    72
    LOG_FUNC
831068540b07 201019_1
hgs
parents:
diff changeset
    73
831068540b07 201019_1
hgs
parents:
diff changeset
    74
    LOG2( "USB device state changed: %d ==> %d", aStateOld, aStateNew );
831068540b07 201019_1
hgs
parents:
diff changeset
    75
    
831068540b07 201019_1
hgs
parents:
diff changeset
    76
    if ( EUsbDeviceStateAddress == aStateNew ) // Entering addressed state
831068540b07 201019_1
hgs
parents:
diff changeset
    77
        {
831068540b07 201019_1
hgs
parents:
diff changeset
    78
       // going down configured -> addressed     
831068540b07 201019_1
hgs
parents:
diff changeset
    79
       if( ( EUsbDeviceStateConfigured == aStateOld ) ||
831068540b07 201019_1
hgs
parents:
diff changeset
    80
            ( ( EUsbDeviceStateSuspended == aStateOld ) &&
831068540b07 201019_1
hgs
parents:
diff changeset
    81
              ( EUsbDeviceStateConfigured == iDevStateB4Suspend ) ) ) 
831068540b07 201019_1
hgs
parents:
diff changeset
    82
            {
831068540b07 201019_1
hgs
parents:
diff changeset
    83
            ShowUsbConnectedIndicatorL( EFalse, aPersonality );
831068540b07 201019_1
hgs
parents:
diff changeset
    84
            }
831068540b07 201019_1
hgs
parents:
diff changeset
    85
        
831068540b07 201019_1
hgs
parents:
diff changeset
    86
        // connecting indicator will be shown when addressed state is entered going up or down
831068540b07 201019_1
hgs
parents:
diff changeset
    87
        // note that when disconnecting the cable (no need to show connecting indicator)
831068540b07 201019_1
hgs
parents:
diff changeset
    88
        // the state change is CONFIGURED => SUSPENDED => POWERED => UNDEFINED    
831068540b07 201019_1
hgs
parents:
diff changeset
    89
        // filter out case of addressed -> suspended -> addressed
831068540b07 201019_1
hgs
parents:
diff changeset
    90
        if ( ( EUsbDeviceStateSuspended != aStateOld ) || 
831068540b07 201019_1
hgs
parents:
diff changeset
    91
             ( EUsbDeviceStateAddress != iDevStateB4Suspend) )
831068540b07 201019_1
hgs
parents:
diff changeset
    92
            {
831068540b07 201019_1
hgs
parents:
diff changeset
    93
            ShowUsbAddressedIndicator( ETrue );
831068540b07 201019_1
hgs
parents:
diff changeset
    94
            }
831068540b07 201019_1
hgs
parents:
diff changeset
    95
        }
831068540b07 201019_1
hgs
parents:
diff changeset
    96
    
831068540b07 201019_1
hgs
parents:
diff changeset
    97
    else if ( EUsbDeviceStateConfigured == aStateNew ) // Entering configured state 
831068540b07 201019_1
hgs
parents:
diff changeset
    98
        {
831068540b07 201019_1
hgs
parents:
diff changeset
    99
        // filter out case of configed -> suspended -> configed
831068540b07 201019_1
hgs
parents:
diff changeset
   100
        if ( ( EUsbDeviceStateSuspended != aStateOld ) || 
831068540b07 201019_1
hgs
parents:
diff changeset
   101
             ( EUsbDeviceStateConfigured != iDevStateB4Suspend) )
831068540b07 201019_1
hgs
parents:
diff changeset
   102
            {
831068540b07 201019_1
hgs
parents:
diff changeset
   103
            ShowUsbAddressedIndicator( EFalse );    
831068540b07 201019_1
hgs
parents:
diff changeset
   104
            ShowUsbConnectedIndicatorL( ETrue, aPersonality );
831068540b07 201019_1
hgs
parents:
diff changeset
   105
            }
831068540b07 201019_1
hgs
parents:
diff changeset
   106
        }
831068540b07 201019_1
hgs
parents:
diff changeset
   107
     
831068540b07 201019_1
hgs
parents:
diff changeset
   108
    else if ( EUsbDeviceStateUndefined == aStateNew ) // Entering undefined
831068540b07 201019_1
hgs
parents:
diff changeset
   109
        {
831068540b07 201019_1
hgs
parents:
diff changeset
   110
        ShowUsbAddressedIndicator( EFalse );
831068540b07 201019_1
hgs
parents:
diff changeset
   111
        ShowUsbConnectedIndicatorL( EFalse, aPersonality );
831068540b07 201019_1
hgs
parents:
diff changeset
   112
        }   
831068540b07 201019_1
hgs
parents:
diff changeset
   113
        
831068540b07 201019_1
hgs
parents:
diff changeset
   114
        
831068540b07 201019_1
hgs
parents:
diff changeset
   115
    else if ( EUsbDeviceStateSuspended == aStateNew )
831068540b07 201019_1
hgs
parents:
diff changeset
   116
    // If current state is suspend, we do not change the indicator, but save
831068540b07 201019_1
hgs
parents:
diff changeset
   117
    // the previous state
831068540b07 201019_1
hgs
parents:
diff changeset
   118
        {
831068540b07 201019_1
hgs
parents:
diff changeset
   119
        iDevStateB4Suspend = aStateOld;
831068540b07 201019_1
hgs
parents:
diff changeset
   120
        }
831068540b07 201019_1
hgs
parents:
diff changeset
   121
    else // New device state is not configured, nor suspended, nor addressed
831068540b07 201019_1
hgs
parents:
diff changeset
   122
        {
831068540b07 201019_1
hgs
parents:
diff changeset
   123
        ShowUsbConnectedIndicatorL( EFalse, aPersonality );       
831068540b07 201019_1
hgs
parents:
diff changeset
   124
        } 
831068540b07 201019_1
hgs
parents:
diff changeset
   125
  
831068540b07 201019_1
hgs
parents:
diff changeset
   126
    }
831068540b07 201019_1
hgs
parents:
diff changeset
   127
    
831068540b07 201019_1
hgs
parents:
diff changeset
   128
// ---------------------------------------------------------------------------
831068540b07 201019_1
hgs
parents:
diff changeset
   129
// Show USB Indicator
831068540b07 201019_1
hgs
parents:
diff changeset
   130
// ---------------------------------------------------------------------------
831068540b07 201019_1
hgs
parents:
diff changeset
   131
//
831068540b07 201019_1
hgs
parents:
diff changeset
   132
void CUsbIndicatorHandler::ShowUsbConnectedIndicatorL( TBool aActivate, TInt aPersonality )
831068540b07 201019_1
hgs
parents:
diff changeset
   133
    {
831068540b07 201019_1
hgs
parents:
diff changeset
   134
     LOG_FUNC    
831068540b07 201019_1
hgs
parents:
diff changeset
   135
     TBool success = EFalse;
831068540b07 201019_1
hgs
parents:
diff changeset
   136
     _LIT(KUsbIndicator, "com.nokia.hb.indicator.usb.device.connected/1.0");  
831068540b07 201019_1
hgs
parents:
diff changeset
   137
     
831068540b07 201019_1
hgs
parents:
diff changeset
   138
     if (aActivate)
831068540b07 201019_1
hgs
parents:
diff changeset
   139
        {
831068540b07 201019_1
hgs
parents:
diff changeset
   140
        RUsb usbman;
831068540b07 201019_1
hgs
parents:
diff changeset
   141
        User::LeaveIfError(usbman.Connect());
831068540b07 201019_1
hgs
parents:
diff changeset
   142
        CleanupClosePushL(usbman);
831068540b07 201019_1
hgs
parents:
diff changeset
   143
        HBufC* description = NULL;
831068540b07 201019_1
hgs
parents:
diff changeset
   144
        User::LeaveIfError(usbman.GetDescription(aPersonality,
831068540b07 201019_1
hgs
parents:
diff changeset
   145
             description));
831068540b07 201019_1
hgs
parents:
diff changeset
   146
        CleanupStack::PopAndDestroy(&usbman);
831068540b07 201019_1
hgs
parents:
diff changeset
   147
        CleanupStack::PushL(description);
831068540b07 201019_1
hgs
parents:
diff changeset
   148
        CHbSymbianVariant* parameters = CHbSymbianVariant::NewL(description, CHbSymbianVariant::EDes);
831068540b07 201019_1
hgs
parents:
diff changeset
   149
        CleanupStack::PopAndDestroy(description);       
831068540b07 201019_1
hgs
parents:
diff changeset
   150
        success = iSymbianIndicator->Activate(KUsbIndicator, parameters);   
831068540b07 201019_1
hgs
parents:
diff changeset
   151
        LOG1( "calling CHbIndicatorSymbian::Activate(), returned %d", success);
831068540b07 201019_1
hgs
parents:
diff changeset
   152
        if (!success)
831068540b07 201019_1
hgs
parents:
diff changeset
   153
            {
831068540b07 201019_1
hgs
parents:
diff changeset
   154
            TInt indicatorerror = iSymbianIndicator->Error();
831068540b07 201019_1
hgs
parents:
diff changeset
   155
            LOG1( "activating the indicator failed with %d", indicatorerror);
831068540b07 201019_1
hgs
parents:
diff changeset
   156
            }
831068540b07 201019_1
hgs
parents:
diff changeset
   157
        else
831068540b07 201019_1
hgs
parents:
diff changeset
   158
            {
831068540b07 201019_1
hgs
parents:
diff changeset
   159
            iConnectedIndicatorActive = ETrue;    
831068540b07 201019_1
hgs
parents:
diff changeset
   160
            }    
831068540b07 201019_1
hgs
parents:
diff changeset
   161
        delete parameters;  
831068540b07 201019_1
hgs
parents:
diff changeset
   162
        }    
831068540b07 201019_1
hgs
parents:
diff changeset
   163
     else if (iConnectedIndicatorActive)
831068540b07 201019_1
hgs
parents:
diff changeset
   164
        {
831068540b07 201019_1
hgs
parents:
diff changeset
   165
        success = iSymbianIndicator->Deactivate(KUsbIndicator); 
831068540b07 201019_1
hgs
parents:
diff changeset
   166
        LOG1( "calling CHbIndicatorSymbian::Deactivate(), returned %d", success);
831068540b07 201019_1
hgs
parents:
diff changeset
   167
        if (success)
831068540b07 201019_1
hgs
parents:
diff changeset
   168
            {
831068540b07 201019_1
hgs
parents:
diff changeset
   169
            iConnectedIndicatorActive = EFalse;    
831068540b07 201019_1
hgs
parents:
diff changeset
   170
            }        
831068540b07 201019_1
hgs
parents:
diff changeset
   171
        LOG( "calling CHbIndicatorSymbian::Deactivate()");
831068540b07 201019_1
hgs
parents:
diff changeset
   172
        }
831068540b07 201019_1
hgs
parents:
diff changeset
   173
   
831068540b07 201019_1
hgs
parents:
diff changeset
   174
   }
831068540b07 201019_1
hgs
parents:
diff changeset
   175
831068540b07 201019_1
hgs
parents:
diff changeset
   176
void CUsbIndicatorHandler::ShowUsbAddressedIndicator( TBool aActivate  )
831068540b07 201019_1
hgs
parents:
diff changeset
   177
    {
831068540b07 201019_1
hgs
parents:
diff changeset
   178
     LOG_FUNC    
831068540b07 201019_1
hgs
parents:
diff changeset
   179
     TBool success = EFalse;
831068540b07 201019_1
hgs
parents:
diff changeset
   180
     _LIT(KUsbIndicator, "com.nokia.hb.indicator.usb.device.inprogress/1.0");  
831068540b07 201019_1
hgs
parents:
diff changeset
   181
     if (aActivate)
831068540b07 201019_1
hgs
parents:
diff changeset
   182
        {
831068540b07 201019_1
hgs
parents:
diff changeset
   183
        success = iSymbianIndicator->Activate(KUsbIndicator);   
831068540b07 201019_1
hgs
parents:
diff changeset
   184
        LOG1( "calling CHbIndicatorSymbian::Activate(), returned %d", success);
831068540b07 201019_1
hgs
parents:
diff changeset
   185
        if (!success)
831068540b07 201019_1
hgs
parents:
diff changeset
   186
            {
831068540b07 201019_1
hgs
parents:
diff changeset
   187
            TInt indicatorerror = iSymbianIndicator->Error();
831068540b07 201019_1
hgs
parents:
diff changeset
   188
            LOG1( "activating the indicator failed with %d", indicatorerror);
831068540b07 201019_1
hgs
parents:
diff changeset
   189
            }
831068540b07 201019_1
hgs
parents:
diff changeset
   190
        else
831068540b07 201019_1
hgs
parents:
diff changeset
   191
            {
831068540b07 201019_1
hgs
parents:
diff changeset
   192
            iAddressedIndicatorActive = ETrue;    
831068540b07 201019_1
hgs
parents:
diff changeset
   193
            }
831068540b07 201019_1
hgs
parents:
diff changeset
   194
        }    
831068540b07 201019_1
hgs
parents:
diff changeset
   195
     else if (iAddressedIndicatorActive)
831068540b07 201019_1
hgs
parents:
diff changeset
   196
        {
831068540b07 201019_1
hgs
parents:
diff changeset
   197
        success = iSymbianIndicator->Deactivate(KUsbIndicator); 
831068540b07 201019_1
hgs
parents:
diff changeset
   198
        LOG1( "calling CHbIndicatorSymbian::Deactivate(), returned %d", success);
831068540b07 201019_1
hgs
parents:
diff changeset
   199
        if (success)
831068540b07 201019_1
hgs
parents:
diff changeset
   200
            {
831068540b07 201019_1
hgs
parents:
diff changeset
   201
            iAddressedIndicatorActive = EFalse;    
831068540b07 201019_1
hgs
parents:
diff changeset
   202
            }
831068540b07 201019_1
hgs
parents:
diff changeset
   203
        LOG( "calling CHbIndicatorSymbian::Deactivate()");
831068540b07 201019_1
hgs
parents:
diff changeset
   204
        }
831068540b07 201019_1
hgs
parents:
diff changeset
   205
   }
831068540b07 201019_1
hgs
parents:
diff changeset
   206
   
831068540b07 201019_1
hgs
parents:
diff changeset
   207
831068540b07 201019_1
hgs
parents:
diff changeset
   208
831068540b07 201019_1
hgs
parents:
diff changeset
   209
// End of file