hwrmhaptics/tsrc/hapticstestplugins/src/hwrmhapticstestplugin.cpp
author hgs
Fri, 08 Oct 2010 14:33:25 +0300
changeset 76 cb32bcc88bad
permissions -rw-r--r--
201039
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
76
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2008 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 the License "Symbian Foundation 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.symbianfoundation.org/legal/sfl-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:  Haptics adaptation test plugin implementation.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#include <s32mem.h>
hgs
parents:
diff changeset
    19
#include <hwrmhapticscommands.h>
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include "hwrmhapticstestplugin.h"
hgs
parents:
diff changeset
    22
#include "hwrmhapticstrace.h"
hgs
parents:
diff changeset
    23
#include "hwrmhapticsvibeconstants.h"
hgs
parents:
diff changeset
    24
#include "plugintimer.h"
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    27
// Enumeration for special test case in which it is tested that HapticsClient 
hgs
parents:
diff changeset
    28
// correctly converts VibeStatus codes to Symbian/S60 error codes.
hgs
parents:
diff changeset
    29
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    30
//
hgs
parents:
diff changeset
    31
enum vibestatustests
hgs
parents:
diff changeset
    32
    {
hgs
parents:
diff changeset
    33
    SUCCESS_TEST = 100,
hgs
parents:
diff changeset
    34
    ALREADY_INITIALIZED_TEST,
hgs
parents:
diff changeset
    35
    NOT_INITIALIZED_TEST,
hgs
parents:
diff changeset
    36
    INVALID_ARGUMENT_TEST,
hgs
parents:
diff changeset
    37
    FAIL_TEST,
hgs
parents:
diff changeset
    38
    INCOMPATIBLE_EFFECT_TYPE_TEST,
hgs
parents:
diff changeset
    39
    INCOMPATIBLE_CAPABILITY_TYPE_TEST,
hgs
parents:
diff changeset
    40
    INCOMPATIBLE_PROPERTY_TYPE_TEST,
hgs
parents:
diff changeset
    41
    DEVICE_NEEDS_LICENSE_TEST,
hgs
parents:
diff changeset
    42
    NOT_ENOUGH_MEMORY_TEST,
hgs
parents:
diff changeset
    43
    SERVICE_NOT_RUNNING_TEST,
hgs
parents:
diff changeset
    44
    INSUFFICIENT_PRIORITY_TEST,
hgs
parents:
diff changeset
    45
    SERVICE_BUSY_TEST,
hgs
parents:
diff changeset
    46
    WRN_NOT_PLAYING_TEST,
hgs
parents:
diff changeset
    47
    WRN_INSUFFICIENT_PRIORITY_TEST
hgs
parents:
diff changeset
    48
    };
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    51
// CHWRMHapticsTestPlugin::NewL
hgs
parents:
diff changeset
    52
// Static instantiation method. Allocates mem and constructs new test plugin object.
hgs
parents:
diff changeset
    53
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    54
//
hgs
parents:
diff changeset
    55
CHWRMHapticsTestPlugin* CHWRMHapticsTestPlugin::NewL( 
hgs
parents:
diff changeset
    56
                                    MHWRMHapticsPluginCallback* aCallback )
hgs
parents:
diff changeset
    57
    {
hgs
parents:
diff changeset
    58
    COMPONENT_TRACE( ( _L("CHWRMHapticsTestPlugin::NewL()") ) );
hgs
parents:
diff changeset
    59
    CHWRMHapticsTestPlugin* self = 
hgs
parents:
diff changeset
    60
        new ( ELeave ) CHWRMHapticsTestPlugin( aCallback );
hgs
parents:
diff changeset
    61
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
    62
    self->ConstructL();
hgs
parents:
diff changeset
    63
    CleanupStack::Pop( self );
hgs
parents:
diff changeset
    64
    return self;
hgs
parents:
diff changeset
    65
    }
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    68
// CHWRMHapticsTestPlugin::~CHWRMHapticsTestPlugin
hgs
parents:
diff changeset
    69
// Destructor
hgs
parents:
diff changeset
    70
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    71
//
hgs
parents:
diff changeset
    72
CHWRMHapticsTestPlugin::~CHWRMHapticsTestPlugin()
hgs
parents:
diff changeset
    73
    {
hgs
parents:
diff changeset
    74
    COMPONENT_TRACE( ( _L("CHWRMHapticsTestPlugin::~CFmtxPlugin()") ) );
hgs
parents:
diff changeset
    75
    
hgs
parents:
diff changeset
    76
    iStorage.Close();
hgs
parents:
diff changeset
    77
    
hgs
parents:
diff changeset
    78
    iTimers.ResetAndDestroy();
hgs
parents:
diff changeset
    79
    iVibeCmdPacket = NULL;
hgs
parents:
diff changeset
    80
 #ifdef PUBLISH_STATE_INFO
hgs
parents:
diff changeset
    81
    iCmdProperty.Close();
hgs
parents:
diff changeset
    82
    iDataProperty.Close();
hgs
parents:
diff changeset
    83
    iVibeCmdProperty.Close();
hgs
parents:
diff changeset
    84
#endif /* PUBLISH_STATE_INFO */
hgs
parents:
diff changeset
    85
    }
hgs
parents:
diff changeset
    86
hgs
parents:
diff changeset
    87
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    88
// CHWRMHapticsTestPlugin::CHWRMHapticsTestPlugin
hgs
parents:
diff changeset
    89
// Constructor
hgs
parents:
diff changeset
    90
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    91
//
hgs
parents:
diff changeset
    92
CHWRMHapticsTestPlugin::CHWRMHapticsTestPlugin( 
hgs
parents:
diff changeset
    93
    MHWRMHapticsPluginCallback* aCallback )
hgs
parents:
diff changeset
    94
    {
hgs
parents:
diff changeset
    95
    COMPONENT_TRACE( ( _L("CHWRMHapticsTestPlugin::CHWRMHapticsTestPlugin()") ) );
hgs
parents:
diff changeset
    96
    iResponseCallback = aCallback;
hgs
parents:
diff changeset
    97
    }
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   100
// CHWRMHapticsTestPlugin::ConstructL
hgs
parents:
diff changeset
   101
// Two-phase construction ConstructL that can leave.
hgs
parents:
diff changeset
   102
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   103
//
hgs
parents:
diff changeset
   104
void CHWRMHapticsTestPlugin::ConstructL()
hgs
parents:
diff changeset
   105
    {
hgs
parents:
diff changeset
   106
    COMPONENT_TRACE( ( _L("CHWRMHapticsTestPlugin::ConstructL") ) );
hgs
parents:
diff changeset
   107
    
hgs
parents:
diff changeset
   108
    // Create response data buffer
hgs
parents:
diff changeset
   109
    iStorage.Create( KHWRMHapticsRespMaxSize );
hgs
parents:
diff changeset
   110
    
hgs
parents:
diff changeset
   111
    // Read in response file contents
hgs
parents:
diff changeset
   112
    RFs fileServer;
hgs
parents:
diff changeset
   113
    User::LeaveIfError( fileServer.Connect() );
hgs
parents:
diff changeset
   114
    
hgs
parents:
diff changeset
   115
    RFile file;
hgs
parents:
diff changeset
   116
    TInt err = file.Open( fileServer, KStubResponseFile, EFileRead );
hgs
parents:
diff changeset
   117
    if( err !=KErrNone )
hgs
parents:
diff changeset
   118
        COMPONENT_TRACE( _L("HWRM HapticsPlugin: Couldn't open file successfully") );
hgs
parents:
diff changeset
   119
    
hgs
parents:
diff changeset
   120
    file.Read( iFileData );
hgs
parents:
diff changeset
   121
    
hgs
parents:
diff changeset
   122
    file.Close();
hgs
parents:
diff changeset
   123
    fileServer.Close();
hgs
parents:
diff changeset
   124
    
hgs
parents:
diff changeset
   125
#ifdef PUBLISH_STATE_INFO
hgs
parents:
diff changeset
   126
    RProperty::Define( KPSUidHWResourceNotification, KHWRMTestHapticsCommand, RProperty::EInt );
hgs
parents:
diff changeset
   127
    RProperty::Define( KPSUidHWResourceNotification, KHWRMTestHapticsDataPckg, RProperty::EByteArray, 512 );
hgs
parents:
diff changeset
   128
    RProperty::Define( KPSUidHWResourceNotification, KHWRMTestVibCmdData, RProperty::EInt );
hgs
parents:
diff changeset
   129
    iCmdProperty.Attach( KPSUidHWResourceNotification, KHWRMTestHapticsCommand );
hgs
parents:
diff changeset
   130
    iDataProperty.Attach( KPSUidHWResourceNotification, KHWRMTestHapticsDataPckg );
hgs
parents:
diff changeset
   131
    iVibeCmdProperty.Attach( KPSUidHWResourceNotification, KHWRMTestVibCmdData );
hgs
parents:
diff changeset
   132
#endif /* PUBLISH_STATE_INFO */
hgs
parents:
diff changeset
   133
    
hgs
parents:
diff changeset
   134
    // inform haptics of the plugin state
hgs
parents:
diff changeset
   135
    iResponseCallback->PluginEnabled( EHWRMLogicalActuatorAny, ETrue );
hgs
parents:
diff changeset
   136
    iResponseCallback->PluginEnabled( EHWRMLogicalActuatorDevice, ETrue );
hgs
parents:
diff changeset
   137
    }
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   141
// CHWRMHapticsTestPlugin::ProcessCommandL
hgs
parents:
diff changeset
   142
// Implementation of CHWRMHapticsPluginService::ProcessCommandL. 
hgs
parents:
diff changeset
   143
// This method processes the haptics command in adaptation layer. In this test
hgs
parents:
diff changeset
   144
// plugin simply a timer instance is created with the given data and later, after
hgs
parents:
diff changeset
   145
// the timer expiry, the semi-hard-coded response is created in GenericTimerFired
hgs
parents:
diff changeset
   146
// method below. 
hgs
parents:
diff changeset
   147
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   148
//     
hgs
parents:
diff changeset
   149
void CHWRMHapticsTestPlugin::ProcessCommandL( TInt aCommandId,
hgs
parents:
diff changeset
   150
                                              TUint8 aTransId,
hgs
parents:
diff changeset
   151
                                              TDesC8& aData )
hgs
parents:
diff changeset
   152
    {
hgs
parents:
diff changeset
   153
    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Processing command: 0x%x, TransId: 0x%x" ), aCommandId, aTransId ) );
hgs
parents:
diff changeset
   154
    
hgs
parents:
diff changeset
   155
    TInt retVal( KErrNone );
hgs
parents:
diff changeset
   156
    
hgs
parents:
diff changeset
   157
    switch ( aCommandId )
hgs
parents:
diff changeset
   158
        {
hgs
parents:
diff changeset
   159
        case HWRMHapticsCommand::EHapticsCmdId :
hgs
parents:
diff changeset
   160
            {
hgs
parents:
diff changeset
   161
            COMPONENT_TRACE( _L("HWRM HapticsPlugin: Processed EHapticsCmdId") );
hgs
parents:
diff changeset
   162
            }
hgs
parents:
diff changeset
   163
            break;
hgs
parents:
diff changeset
   164
        default :
hgs
parents:
diff changeset
   165
            {
hgs
parents:
diff changeset
   166
            COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Unknown Command: 0x%x" ), aCommandId ) );
hgs
parents:
diff changeset
   167
#ifdef _DEBUG
hgs
parents:
diff changeset
   168
            User::Invariant(); // panic here to notice the problem early
hgs
parents:
diff changeset
   169
#endif
hgs
parents:
diff changeset
   170
            }
hgs
parents:
diff changeset
   171
            break;
hgs
parents:
diff changeset
   172
        }
hgs
parents:
diff changeset
   173
    
hgs
parents:
diff changeset
   174
    
hgs
parents:
diff changeset
   175
    iVibeCmdPacket = reinterpret_cast<TVibePacket*>( const_cast<TUint8*>( aData.Ptr() ) ); 
hgs
parents:
diff changeset
   176
    // check for NULL pointer
hgs
parents:
diff changeset
   177
    if ( NULL == iVibeCmdPacket )
hgs
parents:
diff changeset
   178
        {
hgs
parents:
diff changeset
   179
        User::Leave( KErrBadDescriptor );
hgs
parents:
diff changeset
   180
        }
hgs
parents:
diff changeset
   181
    
hgs
parents:
diff changeset
   182
    TInt timeout( KTimeOut );
hgs
parents:
diff changeset
   183
    
hgs
parents:
diff changeset
   184
    _LIT8 ( KTestPluginMgrTransTimerExpires, "KTestPluginMgrTransTimerExpires" );
hgs
parents:
diff changeset
   185
    if ( aData.FindF ( KTestPluginMgrTransTimerExpires ) != KErrNotFound )
hgs
parents:
diff changeset
   186
        {
hgs
parents:
diff changeset
   187
		COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: set the timeout that is more than plug-in manager transaction generic timer time-out period") ) );
hgs
parents:
diff changeset
   188
        // set the timeout that is more than plug-in manager transaction generic timer time-out period i.e. > KDefaultPluginTimeout
hgs
parents:
diff changeset
   189
        timeout = 4000000;
hgs
parents:
diff changeset
   190
        }
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
#ifdef PUBLISH_STATE_INFO
hgs
parents:
diff changeset
   193
    // publish
hgs
parents:
diff changeset
   194
    iCmdProperty.Set( aCommandId );
hgs
parents:
diff changeset
   195
    iDataProperty.Set( aData );
hgs
parents:
diff changeset
   196
    iVibeCmdProperty.Set( iVibeCmdPacket->iSimpleRsp.iCmdCode );
hgs
parents:
diff changeset
   197
#endif /* PUBLISH_STATE_INFO */
hgs
parents:
diff changeset
   198
hgs
parents:
diff changeset
   199
    // create new timer and append it to the timer (pointer) array
hgs
parents:
diff changeset
   200
    CPluginTimer* timer = CPluginTimer::NewL( timeout, iResponseCallback, aCommandId, aTransId, retVal, this );
hgs
parents:
diff changeset
   201
    CleanupStack::PushL( timer );
hgs
parents:
diff changeset
   202
    iTimers.AppendL( timer );
hgs
parents:
diff changeset
   203
    CleanupStack::Pop( timer );
hgs
parents:
diff changeset
   204
    
hgs
parents:
diff changeset
   205
    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Processing command - return") ) );
hgs
parents:
diff changeset
   206
    }
hgs
parents:
diff changeset
   207
hgs
parents:
diff changeset
   208
hgs
parents:
diff changeset
   209
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   210
// CHWRMHapticsTestPlugin::CancelCommandL
hgs
parents:
diff changeset
   211
// Implementation of CHWRMHapticsPluginService::CancelCommandL.
hgs
parents:
diff changeset
   212
// Method for cancelling ongoing (emulated) command execution. In practice 
hgs
parents:
diff changeset
   213
// removes the timer that was started in order to emulate the given command.
hgs
parents:
diff changeset
   214
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   215
// 
hgs
parents:
diff changeset
   216
void CHWRMHapticsTestPlugin::CancelCommandL(
hgs
parents:
diff changeset
   217
    TUint8 aTransId, 
hgs
parents:
diff changeset
   218
    TInt /*aCommandId*/ )
hgs
parents:
diff changeset
   219
    {
hgs
parents:
diff changeset
   220
    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Cancelling command - iTimers.Count(): %d " ), iTimers.Count() ) );
hgs
parents:
diff changeset
   221
hgs
parents:
diff changeset
   222
    for( TInt i = 0; i < iTimers.Count(); i++ )
hgs
parents:
diff changeset
   223
        {
hgs
parents:
diff changeset
   224
        if ( iTimers[i]->TransId() == aTransId )
hgs
parents:
diff changeset
   225
            {
hgs
parents:
diff changeset
   226
            delete iTimers[i];
hgs
parents:
diff changeset
   227
            iTimers.Remove( i );
hgs
parents:
diff changeset
   228
            break;
hgs
parents:
diff changeset
   229
            }
hgs
parents:
diff changeset
   230
        }
hgs
parents:
diff changeset
   231
    }
hgs
parents:
diff changeset
   232
hgs
parents:
diff changeset
   233
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   234
// CHWRMHapticsTestPlugin::GenericTimerFired
hgs
parents:
diff changeset
   235
// Callback method that is called from the CPluginTimer after timer expiry. 
hgs
parents:
diff changeset
   236
// This method emulates reception of response from the ISA layer to a haptics
hgs
parents:
diff changeset
   237
// command. The actual response is read from a file, converted to binary and 
hgs
parents:
diff changeset
   238
// then the Haptics plugin manager's callback method (ProcessResponseL) is 
hgs
parents:
diff changeset
   239
// called with that binary data.
hgs
parents:
diff changeset
   240
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   241
// 
hgs
parents:
diff changeset
   242
void CHWRMHapticsTestPlugin::GenericTimerFired(
hgs
parents:
diff changeset
   243
    MHWRMHapticsPluginCallback* aService,
hgs
parents:
diff changeset
   244
    TInt aCommandId,
hgs
parents:
diff changeset
   245
    TUint8 aTransId,
hgs
parents:
diff changeset
   246
    TInt aRetVal )
hgs
parents:
diff changeset
   247
    {
hgs
parents:
diff changeset
   248
    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: GenericTimerFired (0x%x, 0x%x, %d)" ), aCommandId, aTransId, aRetVal ) );
hgs
parents:
diff changeset
   249
hgs
parents:
diff changeset
   250
    __ASSERT_ALWAYS( aService != NULL, User::Invariant() );
hgs
parents:
diff changeset
   251
    
hgs
parents:
diff changeset
   252
    TInt err = KErrNone;
hgs
parents:
diff changeset
   253
    TBuf8<KHWRMHapticsRespMaxSize> binRespData;
hgs
parents:
diff changeset
   254
    if ( NULL != iVibeCmdPacket )
hgs
parents:
diff changeset
   255
        {
hgs
parents:
diff changeset
   256
        TBool jumpCases = EFalse;
hgs
parents:
diff changeset
   257
        
hgs
parents:
diff changeset
   258
        // Special case for vibeStatus to S60 err code manipulations:
hgs
parents:
diff changeset
   259
        if ( iVibeCmdPacket->iSimpleRsp.iCmdCode == KVibeCmdPlayIVTEffectNoData )
hgs
parents:
diff changeset
   260
            {
hgs
parents:
diff changeset
   261
            TVibePacketPlayIVTEffectRequest* playReq = reinterpret_cast<TVibePacketPlayIVTEffectRequest*>( iVibeCmdPacket );
hgs
parents:
diff changeset
   262
            if ( playReq )
hgs
parents:
diff changeset
   263
                {
hgs
parents:
diff changeset
   264
                jumpCases = ETrue;
hgs
parents:
diff changeset
   265
                
hgs
parents:
diff changeset
   266
                // the repeat value is used to indicate which sub-case is ongoing.. 
hgs
parents:
diff changeset
   267
                // values between 100...114 are treated as special values.
hgs
parents:
diff changeset
   268
                switch ( playReq->iRepeat )
hgs
parents:
diff changeset
   269
                    {
hgs
parents:
diff changeset
   270
                    case SUCCESS_TEST:
hgs
parents:
diff changeset
   271
                        {
hgs
parents:
diff changeset
   272
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_S_SUCCESS") ) );
hgs
parents:
diff changeset
   273
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseSuccess ), binRespData );
hgs
parents:
diff changeset
   274
                        break;
hgs
parents:
diff changeset
   275
                        }
hgs
parents:
diff changeset
   276
                    case ALREADY_INITIALIZED_TEST:
hgs
parents:
diff changeset
   277
                        {
hgs
parents:
diff changeset
   278
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_ALREADY_INITIALIZED") ) );
hgs
parents:
diff changeset
   279
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseAlreadyInit ), binRespData );
hgs
parents:
diff changeset
   280
                        break;
hgs
parents:
diff changeset
   281
                        }                        
hgs
parents:
diff changeset
   282
                    case NOT_INITIALIZED_TEST:
hgs
parents:
diff changeset
   283
                        {
hgs
parents:
diff changeset
   284
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_NOT_INITIALIZED") ) );
hgs
parents:
diff changeset
   285
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseNotInit ), binRespData );
hgs
parents:
diff changeset
   286
                        break;
hgs
parents:
diff changeset
   287
                        }
hgs
parents:
diff changeset
   288
                    case INVALID_ARGUMENT_TEST:
hgs
parents:
diff changeset
   289
                        {
hgs
parents:
diff changeset
   290
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_INVALID_ARGUMENT") ) );
hgs
parents:
diff changeset
   291
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseInvalidArg ), binRespData );
hgs
parents:
diff changeset
   292
                        break;
hgs
parents:
diff changeset
   293
                        }        
hgs
parents:
diff changeset
   294
                    case FAIL_TEST:
hgs
parents:
diff changeset
   295
                        {
hgs
parents:
diff changeset
   296
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_FAIL") ) );
hgs
parents:
diff changeset
   297
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseFail ), binRespData );
hgs
parents:
diff changeset
   298
                        break;
hgs
parents:
diff changeset
   299
                        }
hgs
parents:
diff changeset
   300
                    case INCOMPATIBLE_EFFECT_TYPE_TEST:
hgs
parents:
diff changeset
   301
                        {
hgs
parents:
diff changeset
   302
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_INCOMPATIBLE_EFFECT_TYPE") ) );
hgs
parents:
diff changeset
   303
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseIncompEffType ), binRespData );
hgs
parents:
diff changeset
   304
                        break;
hgs
parents:
diff changeset
   305
                        }                        
hgs
parents:
diff changeset
   306
                    case INCOMPATIBLE_CAPABILITY_TYPE_TEST:
hgs
parents:
diff changeset
   307
                        {
hgs
parents:
diff changeset
   308
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_INCOMPATIBLE_CAPABILITY_TYPE") ) );
hgs
parents:
diff changeset
   309
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseIncompCapaType ), binRespData );
hgs
parents:
diff changeset
   310
                        break;
hgs
parents:
diff changeset
   311
                        }
hgs
parents:
diff changeset
   312
                    case INCOMPATIBLE_PROPERTY_TYPE_TEST:
hgs
parents:
diff changeset
   313
                        {
hgs
parents:
diff changeset
   314
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_INCOMPATIBLE_PROPERTY_TYPE") ) );
hgs
parents:
diff changeset
   315
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseIncompPropType ), binRespData );
hgs
parents:
diff changeset
   316
                        break;
hgs
parents:
diff changeset
   317
                        }                 
hgs
parents:
diff changeset
   318
                    case DEVICE_NEEDS_LICENSE_TEST:
hgs
parents:
diff changeset
   319
                        {
hgs
parents:
diff changeset
   320
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_DEVICE_NEEDS_LICENSE") ) );
hgs
parents:
diff changeset
   321
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseDevNeedsLicense ), binRespData );
hgs
parents:
diff changeset
   322
                        break;
hgs
parents:
diff changeset
   323
                        }
hgs
parents:
diff changeset
   324
                    case NOT_ENOUGH_MEMORY_TEST:
hgs
parents:
diff changeset
   325
                        {
hgs
parents:
diff changeset
   326
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_NOT_ENOUGH_MEMORY") ) );
hgs
parents:
diff changeset
   327
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseNotEnoughMem ), binRespData );
hgs
parents:
diff changeset
   328
                        break;
hgs
parents:
diff changeset
   329
                        }                        
hgs
parents:
diff changeset
   330
                    case SERVICE_NOT_RUNNING_TEST:
hgs
parents:
diff changeset
   331
                        {
hgs
parents:
diff changeset
   332
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_SERVICE_NOT_RUNNING") ) );
hgs
parents:
diff changeset
   333
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseSrvNotRunning ), binRespData );
hgs
parents:
diff changeset
   334
                        break;
hgs
parents:
diff changeset
   335
                        }
hgs
parents:
diff changeset
   336
                    case INSUFFICIENT_PRIORITY_TEST:
hgs
parents:
diff changeset
   337
                        {
hgs
parents:
diff changeset
   338
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_INSUFFICIENT_PRIORITY") ) );
hgs
parents:
diff changeset
   339
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseErrInsuffPriority ), binRespData );
hgs
parents:
diff changeset
   340
                        break;
hgs
parents:
diff changeset
   341
                        } 
hgs
parents:
diff changeset
   342
                    case SERVICE_BUSY_TEST:
hgs
parents:
diff changeset
   343
                        {
hgs
parents:
diff changeset
   344
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_E_SERVICE_BUSY") ) );
hgs
parents:
diff changeset
   345
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseSrvBusy ), binRespData );
hgs
parents:
diff changeset
   346
                        break;
hgs
parents:
diff changeset
   347
                        }
hgs
parents:
diff changeset
   348
                    case WRN_NOT_PLAYING_TEST:
hgs
parents:
diff changeset
   349
                        {
hgs
parents:
diff changeset
   350
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_W_NOT_PLAYING") ) );
hgs
parents:
diff changeset
   351
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseWrnNotPlaying ), binRespData );
hgs
parents:
diff changeset
   352
                        break;
hgs
parents:
diff changeset
   353
                        }                        
hgs
parents:
diff changeset
   354
                    case WRN_INSUFFICIENT_PRIORITY_TEST:
hgs
parents:
diff changeset
   355
                        {
hgs
parents:
diff changeset
   356
                        COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: Returning status VIBE_W_INSUFFICIENT_PRIORITY") ) );
hgs
parents:
diff changeset
   357
                        this->GetBinRespCode( iFileData.Find( KVibraCmdStatusCaseWrnInsuffPriority ), binRespData );
hgs
parents:
diff changeset
   358
                        break;
hgs
parents:
diff changeset
   359
                        }
hgs
parents:
diff changeset
   360
                    default:
hgs
parents:
diff changeset
   361
                        {
hgs
parents:
diff changeset
   362
                        jumpCases = EFalse;
hgs
parents:
diff changeset
   363
                        break;    
hgs
parents:
diff changeset
   364
                        }
hgs
parents:
diff changeset
   365
                    }
hgs
parents:
diff changeset
   366
                if ( jumpCases )
hgs
parents:
diff changeset
   367
                    {
hgs
parents:
diff changeset
   368
                    iEffectState = ENotPlaying; 
hgs
parents:
diff changeset
   369
                    }
hgs
parents:
diff changeset
   370
                }
hgs
parents:
diff changeset
   371
            }
hgs
parents:
diff changeset
   372
            
hgs
parents:
diff changeset
   373
        if ( !jumpCases )
hgs
parents:
diff changeset
   374
            {
hgs
parents:
diff changeset
   375
            // Other cases..
hgs
parents:
diff changeset
   376
            switch( iVibeCmdPacket->iSimpleRsp.iCmdCode )
hgs
parents:
diff changeset
   377
                {
hgs
parents:
diff changeset
   378
            
hgs
parents:
diff changeset
   379
                case KVibeCmdInitialize:
hgs
parents:
diff changeset
   380
                    {
hgs
parents:
diff changeset
   381
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_INITIALIZE command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );    
hgs
parents:
diff changeset
   382
                    TInt pos = iFileData.Find( KVibraCmdInitialize );
hgs
parents:
diff changeset
   383
                    iEffectState = ENotPlaying;
hgs
parents:
diff changeset
   384
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   385
                    break;
hgs
parents:
diff changeset
   386
                    }
hgs
parents:
diff changeset
   387
                case KVibeCmdOpenDevice:
hgs
parents:
diff changeset
   388
                    {
hgs
parents:
diff changeset
   389
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_OPENDEVICE command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   390
                    TInt pos = iFileData.Find( KVibraCmdOpenDevice );
hgs
parents:
diff changeset
   391
                    iEffectState = ENotPlaying; 
hgs
parents:
diff changeset
   392
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   393
                    break;
hgs
parents:
diff changeset
   394
                    }
hgs
parents:
diff changeset
   395
                case KVibeCmdSetDeviceProperty:
hgs
parents:
diff changeset
   396
                    {
hgs
parents:
diff changeset
   397
                     COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_SETDEVICEPROPERTY command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   398
                     TInt pos = iFileData.Find( KVibraCmdSetDeviceProperty );
hgs
parents:
diff changeset
   399
                     this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   400
                     break;
hgs
parents:
diff changeset
   401
                    }
hgs
parents:
diff changeset
   402
                case KVibeCmdPlayMagSweepEffect:
hgs
parents:
diff changeset
   403
                    {
hgs
parents:
diff changeset
   404
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_PLAYMAGSWEEPEFFECT command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) ); 
hgs
parents:
diff changeset
   405
                    TInt pos = iFileData.Find( KVibraCmdPlayMagSweepEffect );
hgs
parents:
diff changeset
   406
                    iEffectState = EPlaying;
hgs
parents:
diff changeset
   407
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   408
                    break;
hgs
parents:
diff changeset
   409
                    }
hgs
parents:
diff changeset
   410
                case KVibeCmdCloseDevice:
hgs
parents:
diff changeset
   411
                    {
hgs
parents:
diff changeset
   412
                     COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_CLOSEDEVICE command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   413
                     TInt pos = iFileData.Find( KVibraCmdCloseDevice );
hgs
parents:
diff changeset
   414
                     iEffectState = ENotPlaying;
hgs
parents:
diff changeset
   415
                     this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   416
                     break;
hgs
parents:
diff changeset
   417
                    }
hgs
parents:
diff changeset
   418
                case KVibeCmdDeviceCount:
hgs
parents:
diff changeset
   419
                    {
hgs
parents:
diff changeset
   420
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_DEVICE_COUNT command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) ); 
hgs
parents:
diff changeset
   421
                    TInt pos = iFileData.Find( KVibraCmdDeviceCount );
hgs
parents:
diff changeset
   422
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   423
                    break;
hgs
parents:
diff changeset
   424
                    }
hgs
parents:
diff changeset
   425
                case KVibeCmdGetDeviceProperty:
hgs
parents:
diff changeset
   426
                    {
hgs
parents:
diff changeset
   427
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_GETDEVICEPROPERTY command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   428
                    TInt pos = 0;
hgs
parents:
diff changeset
   429
                    switch (iVibeCmdPacket->iGetDevicePropertyReq.iPropertyValueType)
hgs
parents:
diff changeset
   430
                        {
hgs
parents:
diff changeset
   431
                        case KVibeValuetypeInt32:
hgs
parents:
diff changeset
   432
                            pos = iFileData.Find( KVibraCmdGetDevicePropertyInteger );
hgs
parents:
diff changeset
   433
                            break;
hgs
parents:
diff changeset
   434
                        case KVibeValuetypeString:
hgs
parents:
diff changeset
   435
                            pos = iFileData.Find( KVibraCmdGetDevicePropertyString );
hgs
parents:
diff changeset
   436
                            break;                        
hgs
parents:
diff changeset
   437
                        case KVibeValuetypeBool:
hgs
parents:
diff changeset
   438
                            pos = iFileData.Find( KVibraCmdGetDevicePropertyBool );
hgs
parents:
diff changeset
   439
                            break;                        
hgs
parents:
diff changeset
   440
                        default:
hgs
parents:
diff changeset
   441
#ifdef _DEBUG                        
hgs
parents:
diff changeset
   442
                            User::Invariant(); // wrong value type
hgs
parents:
diff changeset
   443
#endif                            
hgs
parents:
diff changeset
   444
                            ;
hgs
parents:
diff changeset
   445
                        }
hgs
parents:
diff changeset
   446
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   447
                    break;
hgs
parents:
diff changeset
   448
                    }
hgs
parents:
diff changeset
   449
                case KVibeCmdGetDeviceState:
hgs
parents:
diff changeset
   450
                    {
hgs
parents:
diff changeset
   451
                     COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_GETDEVICESTATE command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   452
                     TInt pos = iFileData.Find( KVibraCmdGetDeviceState );
hgs
parents:
diff changeset
   453
                     this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   454
                     break;
hgs
parents:
diff changeset
   455
                    }
hgs
parents:
diff changeset
   456
                case KVibeCmdGetDeviceCapabilities:
hgs
parents:
diff changeset
   457
                    {
hgs
parents:
diff changeset
   458
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_GETDEVICECAPABILITIES command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) ); 
hgs
parents:
diff changeset
   459
                    TInt pos = 0;
hgs
parents:
diff changeset
   460
                    switch (iVibeCmdPacket->iGetDeviceCapsReq.iCapabilityValueType)
hgs
parents:
diff changeset
   461
                        {
hgs
parents:
diff changeset
   462
                        case KVibeValuetypeInt32:
hgs
parents:
diff changeset
   463
                            pos = iFileData.Find( KVibraCmdGetDeviceCapabilitiesInteger );
hgs
parents:
diff changeset
   464
                            break;
hgs
parents:
diff changeset
   465
                        case KVibeValuetypeString:
hgs
parents:
diff changeset
   466
                            pos = iFileData.Find( KVibraCmdGetDeviceCapabilitiesString );
hgs
parents:
diff changeset
   467
                            break;
hgs
parents:
diff changeset
   468
                        default:
hgs
parents:
diff changeset
   469
#ifdef _DEBUG                        
hgs
parents:
diff changeset
   470
                            User::Invariant(); // wrong value type
hgs
parents:
diff changeset
   471
#endif                            
hgs
parents:
diff changeset
   472
                            ;
hgs
parents:
diff changeset
   473
                        }
hgs
parents:
diff changeset
   474
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   475
                    break;
hgs
parents:
diff changeset
   476
                    }
hgs
parents:
diff changeset
   477
                case KVibeCmdPlayPeriodicEffect:
hgs
parents:
diff changeset
   478
                    {
hgs
parents:
diff changeset
   479
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_PLAYPERIODICEFFECT command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   480
                    TInt pos = iFileData.Find( KVibraCmdPlayPeriodicEffect );
hgs
parents:
diff changeset
   481
                    iEffectState = EPlaying;
hgs
parents:
diff changeset
   482
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   483
                    break;
hgs
parents:
diff changeset
   484
                    }
hgs
parents:
diff changeset
   485
                case KVibeCmdPlayIVTEffectIncludeData:
hgs
parents:
diff changeset
   486
                    {
hgs
parents:
diff changeset
   487
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_PLAYIVTEFFECT_INCLUDEIVTDATA command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) ); 
hgs
parents:
diff changeset
   488
                    TInt pos = iFileData.Find( KVibraCmdPlayIVTEffectIncludeIVTData );
hgs
parents:
diff changeset
   489
                    iEffectState = EPlaying;
hgs
parents:
diff changeset
   490
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   491
                    break;
hgs
parents:
diff changeset
   492
                    }
hgs
parents:
diff changeset
   493
                case KVibeCmdPlayIVTEffectNoData:
hgs
parents:
diff changeset
   494
                    {
hgs
parents:
diff changeset
   495
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_PLAYIVTEFFECT_NOIVTDATA command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   496
                    TInt pos = iFileData.Find( KVibraCmdPlayIVTEffectNoIVTData );
hgs
parents:
diff changeset
   497
                    iEffectState = EPlaying;
hgs
parents:
diff changeset
   498
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   499
                    break;
hgs
parents:
diff changeset
   500
                    }
hgs
parents:
diff changeset
   501
                case KVibeCmdStopEffect:
hgs
parents:
diff changeset
   502
                    {
hgs
parents:
diff changeset
   503
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_STOPEFFECT command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   504
                    TInt pos = iFileData.Find( KVibraCmdStopEffect );
hgs
parents:
diff changeset
   505
                    iEffectState = ENotPlaying;
hgs
parents:
diff changeset
   506
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   507
                    break;
hgs
parents:
diff changeset
   508
                    }
hgs
parents:
diff changeset
   509
                case KVibeCmdStopAllEffects:
hgs
parents:
diff changeset
   510
                    {
hgs
parents:
diff changeset
   511
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_STOPALLEFFECTS command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) ); 
hgs
parents:
diff changeset
   512
                    TInt pos = iFileData.Find( KVibraCmdStopAllEffects );
hgs
parents:
diff changeset
   513
                    iEffectState = ENotPlaying;
hgs
parents:
diff changeset
   514
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   515
                    break;
hgs
parents:
diff changeset
   516
                    }
hgs
parents:
diff changeset
   517
                case KVibeCmdPlayStreamingSample:
hgs
parents:
diff changeset
   518
                    {
hgs
parents:
diff changeset
   519
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_PLAYSTREAMINGSAMPLE command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   520
                    TInt pos = iFileData.Find( KVibraCmdPlayStreamingSample );
hgs
parents:
diff changeset
   521
                    iEffectState = EPlaying;
hgs
parents:
diff changeset
   522
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   523
                    break;
hgs
parents:
diff changeset
   524
                    }
hgs
parents:
diff changeset
   525
            
hgs
parents:
diff changeset
   526
                case KVibeCmdCreateStreamingEffect:
hgs
parents:
diff changeset
   527
                    {
hgs
parents:
diff changeset
   528
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_CREATESTREAMINGEFFECT command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   529
                    TInt pos = iFileData.Find( KVibraCmdCreateStreamingEffect );
hgs
parents:
diff changeset
   530
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   531
                    break;
hgs
parents:
diff changeset
   532
                    }
hgs
parents:
diff changeset
   533
                case KVibeCmdDestroyStreamingEffect:
hgs
parents:
diff changeset
   534
                    {
hgs
parents:
diff changeset
   535
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_DESTROYSTREAMINGEFFECT command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) ); 
hgs
parents:
diff changeset
   536
                    TInt pos = iFileData.Find( KVibraCmdDestroyStreamingEffect );
hgs
parents:
diff changeset
   537
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   538
                    break;
hgs
parents:
diff changeset
   539
                    }
hgs
parents:
diff changeset
   540
                case KVibeCmdModifyPlayingMagSweepEffect:
hgs
parents:
diff changeset
   541
                    {
hgs
parents:
diff changeset
   542
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_MODIFYPLAYINGMAGSWEEPEFFECT command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   543
                    TInt pos = iFileData.Find( KVibraCmdModifyPlayingMagSweepEffect );
hgs
parents:
diff changeset
   544
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   545
                    break;
hgs
parents:
diff changeset
   546
                    }
hgs
parents:
diff changeset
   547
                case KVibeCmdModifyPlayingPeriodicEffect:
hgs
parents:
diff changeset
   548
                    {
hgs
parents:
diff changeset
   549
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_MODIFYPLAYINGPERIODICEFFECT: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   550
                    TInt pos = iFileData.Find( KVibraCmdModifyPlayingPeriodicEffect );
hgs
parents:
diff changeset
   551
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   552
                    break;
hgs
parents:
diff changeset
   553
                    }
hgs
parents:
diff changeset
   554
                case KVibeCmdPausePlayingEffect:
hgs
parents:
diff changeset
   555
                    {
hgs
parents:
diff changeset
   556
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_PAUSEPLAYINGEFFECT command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) ); 
hgs
parents:
diff changeset
   557
                    TInt pos = iFileData.Find( KVibraCmdPausePlayingEffect );
hgs
parents:
diff changeset
   558
                    iEffectState = EPaused;
hgs
parents:
diff changeset
   559
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   560
                    break;
hgs
parents:
diff changeset
   561
                    }
hgs
parents:
diff changeset
   562
                case KVibeCmdResumePausedEffect:
hgs
parents:
diff changeset
   563
                    {
hgs
parents:
diff changeset
   564
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_RESUMEPAUSEDEFFECT command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   565
                    TInt pos = iFileData.Find( KVibraCmdResumePausedEffect );
hgs
parents:
diff changeset
   566
                    iEffectState = EPlaying; 
hgs
parents:
diff changeset
   567
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   568
                    break;
hgs
parents:
diff changeset
   569
                    }
hgs
parents:
diff changeset
   570
            
hgs
parents:
diff changeset
   571
                case KVibeCmdGetEffectState:
hgs
parents:
diff changeset
   572
                    {
hgs
parents:
diff changeset
   573
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_GETEFFECTSTATE command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   574
                    TInt pos;
hgs
parents:
diff changeset
   575
                    if ( iEffectState == ENotPlaying ) 
hgs
parents:
diff changeset
   576
                        {
hgs
parents:
diff changeset
   577
                        pos = iFileData.Find( KVibraCmdGetEffectStateNotPlaying );
hgs
parents:
diff changeset
   578
                        }
hgs
parents:
diff changeset
   579
                    else if ( iEffectState == EPlaying ) 
hgs
parents:
diff changeset
   580
                        {   
hgs
parents:
diff changeset
   581
                        pos = iFileData.Find( KVibraCmdGetEffectStatePlaying );
hgs
parents:
diff changeset
   582
                        }
hgs
parents:
diff changeset
   583
                    else
hgs
parents:
diff changeset
   584
                        {
hgs
parents:
diff changeset
   585
                        pos = iFileData.Find( KVibraCmdGetEffectStatePaused );
hgs
parents:
diff changeset
   586
                        }
hgs
parents:
diff changeset
   587
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   588
                    break;
hgs
parents:
diff changeset
   589
                    }
hgs
parents:
diff changeset
   590
                case KVibeCmdSetKernelParameter:
hgs
parents:
diff changeset
   591
                    {
hgs
parents:
diff changeset
   592
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_SETKERNELPARAMETER command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) ); 
hgs
parents:
diff changeset
   593
                    TInt pos = iFileData.Find( KVibraCmdSetKernelParameter );
hgs
parents:
diff changeset
   594
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   595
                    break;
hgs
parents:
diff changeset
   596
                    }
hgs
parents:
diff changeset
   597
                case KVibeCmdGetKernelParameter:
hgs
parents:
diff changeset
   598
                    {
hgs
parents:
diff changeset
   599
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_GETKERNELPARAMETER command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   600
                    TInt pos = iFileData.Find( KVibraCmdGetKernelParameter );
hgs
parents:
diff changeset
   601
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   602
                    break;
hgs
parents:
diff changeset
   603
                    }
hgs
parents:
diff changeset
   604
                case KVibeCmdSetLicense:
hgs
parents:
diff changeset
   605
                    {
hgs
parents:
diff changeset
   606
                    COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: VIBEPKT_CMD_SETLICENSE command: 0x%x" ), iVibeCmdPacket->iSimpleRsp.iCmdCode ) );
hgs
parents:
diff changeset
   607
                    TInt pos = iFileData.Find( KVibraCmdSetLicense );
hgs
parents:
diff changeset
   608
                    this->GetBinRespCode( pos, binRespData );
hgs
parents:
diff changeset
   609
                    break;
hgs
parents:
diff changeset
   610
                    }
hgs
parents:
diff changeset
   611
                default:
hgs
parents:
diff changeset
   612
                    {
hgs
parents:
diff changeset
   613
                    // do panic --> packetized message not recognized
hgs
parents:
diff changeset
   614
                    break;
hgs
parents:
diff changeset
   615
                    }    
hgs
parents:
diff changeset
   616
                }//switch
hgs
parents:
diff changeset
   617
            }
hgs
parents:
diff changeset
   618
hgs
parents:
diff changeset
   619
            CHWRMHapticsRespData* respData;
hgs
parents:
diff changeset
   620
            TInt32 errorCode( KErrNone );
hgs
parents:
diff changeset
   621
            respData = CHWRMHapticsRespData::NewLC( errorCode, binRespData );
hgs
parents:
diff changeset
   622
            RDesWriteStream writer( iStorage );
hgs
parents:
diff changeset
   623
            CleanupClosePushL( writer );
hgs
parents:
diff changeset
   624
            // write to resp data
hgs
parents:
diff changeset
   625
            writer << *respData;
hgs
parents:
diff changeset
   626
            // remove from stack , it will commit the actual data to the stoarage.
hgs
parents:
diff changeset
   627
            CleanupStack::PopAndDestroy( &writer ); 
hgs
parents:
diff changeset
   628
            CleanupStack::PopAndDestroy( respData ); 
hgs
parents:
diff changeset
   629
            
hgs
parents:
diff changeset
   630
        } // if block end for pRsp check
hgs
parents:
diff changeset
   631
    
hgs
parents:
diff changeset
   632
    
hgs
parents:
diff changeset
   633
    TRAP( err, aService->ProcessResponseL( aCommandId, aTransId, iStorage ) );               
hgs
parents:
diff changeset
   634
    // delete obsolete timers
hgs
parents:
diff changeset
   635
    for( TInt i = ( iTimers.Count()-1 ); i > -1 ; i-- )
hgs
parents:
diff changeset
   636
        {
hgs
parents:
diff changeset
   637
        if ( !iTimers[i]->IsActive() )
hgs
parents:
diff changeset
   638
            {
hgs
parents:
diff changeset
   639
            delete iTimers[i];
hgs
parents:
diff changeset
   640
            iTimers.Remove( i );            
hgs
parents:
diff changeset
   641
            COMPONENT_TRACE( ( _L("HWRM HapticsPlugin: GenericTimerFired - Removed obsolete timer") ) );
hgs
parents:
diff changeset
   642
            }
hgs
parents:
diff changeset
   643
        }
hgs
parents:
diff changeset
   644
    }
hgs
parents:
diff changeset
   645
hgs
parents:
diff changeset
   646
hgs
parents:
diff changeset
   647
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   648
// CHWRMHapticsTestPlugin::Hex2Bin
hgs
parents:
diff changeset
   649
// Converts hexadecimal string given as first parameter to binary data that is 
hgs
parents:
diff changeset
   650
// stored to the object referenced by the second parameter.
hgs
parents:
diff changeset
   651
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   652
// 
hgs
parents:
diff changeset
   653
void CHWRMHapticsTestPlugin::Hex2Bin( const TDesC8& aSrcBuffer, TDes8& aDstBuffer )
hgs
parents:
diff changeset
   654
     {
hgs
parents:
diff changeset
   655
     TInt len = aSrcBuffer.Length();
hgs
parents:
diff changeset
   656
     aDstBuffer.SetLength( len >> 1 );
hgs
parents:
diff changeset
   657
     for ( TInt n=0; n<len; n+=2 )
hgs
parents:
diff changeset
   658
         {
hgs
parents:
diff changeset
   659
         TUint8 hiNibble = ( (aSrcBuffer[n] > '9' ) ? aSrcBuffer[n] - 'A' + 10: aSrcBuffer[n] - '0' );
hgs
parents:
diff changeset
   660
         TUint8 loNibble = ( (aSrcBuffer[n+1] > '9' ) ? aSrcBuffer[n+1] - 'A' + 10: aSrcBuffer[n+1] - '0' );
hgs
parents:
diff changeset
   661
 
hgs
parents:
diff changeset
   662
         aDstBuffer[n>>1] = static_cast<TUint8>( ( ( hiNibble << 4 ) + loNibble ) );
hgs
parents:
diff changeset
   663
         }
hgs
parents:
diff changeset
   664
     }
hgs
parents:
diff changeset
   665
hgs
parents:
diff changeset
   666
hgs
parents:
diff changeset
   667
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   668
// CHWRMHapticsTestPlugin::GetBinRespCode
hgs
parents:
diff changeset
   669
// Helper method that gets the response data string from given position (line)
hgs
parents:
diff changeset
   670
// of the (buffered in) response data file, and with the above Hex2Bin method
hgs
parents:
diff changeset
   671
// converts the string into binary data that is then stored to the TDes8 object
hgs
parents:
diff changeset
   672
// whose reference is given as second param (aBinRespData).
hgs
parents:
diff changeset
   673
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   674
// 
hgs
parents:
diff changeset
   675
void CHWRMHapticsTestPlugin::GetBinRespCode( TInt aCmdPosition, TDes8& aBinRespData )
hgs
parents:
diff changeset
   676
    {
hgs
parents:
diff changeset
   677
     TBuf8<KRespFileData> tempFileData;
hgs
parents:
diff changeset
   678
     TBuf8<KHexRespCode>  hexRespCode;
hgs
parents:
diff changeset
   679
     
hgs
parents:
diff changeset
   680
     tempFileData.Copy( iFileData.Mid( aCmdPosition ) );
hgs
parents:
diff changeset
   681
     TInt pos2 = tempFileData.Locate( '"' );
hgs
parents:
diff changeset
   682
     TInt pos3 = tempFileData.Locate( '\r' );
hgs
parents:
diff changeset
   683
     TInt respCodeLength = ( pos3-2 ) - pos2;
hgs
parents:
diff changeset
   684
     
hgs
parents:
diff changeset
   685
     hexRespCode.Copy( tempFileData.Mid( pos2+1, respCodeLength ) );
hgs
parents:
diff changeset
   686
     
hgs
parents:
diff changeset
   687
     CHWRMHapticsTestPlugin::Hex2Bin( hexRespCode, aBinRespData );     
hgs
parents:
diff changeset
   688
    }
hgs
parents:
diff changeset
   689
hgs
parents:
diff changeset
   690
hgs
parents:
diff changeset
   691