hwrmhaptics/tsrc/hapticstestplugins/inc/plugintimer.h
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 test (adaptation) plugin timer header file
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
#ifndef __HWRMHAPTICSTESTPLUGINTIMER_H_
hgs
parents:
diff changeset
    21
#define __HWRMHAPTICSTESTPLUGINTIMER_H_
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
#include <hwrmhapticspluginservice.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
/**
hgs
parents:
diff changeset
    26
 *  An interface for handling timer expiration events.
hgs
parents:
diff changeset
    27
 *
hgs
parents:
diff changeset
    28
 * @since S60 5.1
hgs
parents:
diff changeset
    29
 */
hgs
parents:
diff changeset
    30
class MPluginTimerCallback
hgs
parents:
diff changeset
    31
    {
hgs
parents:
diff changeset
    32
public:
hgs
parents:
diff changeset
    33
    /** 
hgs
parents:
diff changeset
    34
     * Method that is called when the timer expires.
hgs
parents:
diff changeset
    35
     * Must be implemented by classes that support this interface.
hgs
parents:
diff changeset
    36
     *
hgs
parents:
diff changeset
    37
     * @param aService Pointer to an object that implements
hgs
parents:
diff changeset
    38
     *                 the MHWRMHapticsPluginCallback interface
hgs
parents:
diff changeset
    39
     *                 and thus handles the callbacks from this
hgs
parents:
diff changeset
    40
     *                 test plugin. In practice this is pointer 
hgs
parents:
diff changeset
    41
     *                 to the Haptics plugin manager object.
hgs
parents:
diff changeset
    42
     * @param aCommandId ID of the command that was being executed
hgs
parents:
diff changeset
    43
     *                   (or actually emulated as being executed) 
hgs
parents:
diff changeset
    44
     *                   at the time the timer expired.
hgs
parents:
diff changeset
    45
     * @param aTransId Transaction ID of the command that was being executed
hgs
parents:
diff changeset
    46
     *                 (or actually emulated as being executed) 
hgs
parents:
diff changeset
    47
     *                 at the time the timer expired.
hgs
parents:
diff changeset
    48
     * @param aRetVal  (Emulated) return value of the command that was
hgs
parents:
diff changeset
    49
     *                 being executed (or actually emulated as being executed)
hgs
parents:
diff changeset
    50
     *                 at the time the timer expired.
hgs
parents:
diff changeset
    51
     */
hgs
parents:
diff changeset
    52
    virtual void GenericTimerFired( MHWRMHapticsPluginCallback* aService,
hgs
parents:
diff changeset
    53
                                    TInt aCommandId,
hgs
parents:
diff changeset
    54
                                    TUint8 aTransId,
hgs
parents:
diff changeset
    55
                                    TInt aRetVal ) = 0;
hgs
parents:
diff changeset
    56
    };
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
/**
hgs
parents:
diff changeset
    60
 * Timer class that triggers command execution emulation. (This test
hgs
parents:
diff changeset
    61
 * stub emulates the real adaptation layer haptics command execution
hgs
parents:
diff changeset
    62
 * and the emulation "round" is triggered from this class).
hgs
parents:
diff changeset
    63
 *
hgs
parents:
diff changeset
    64
 * @since S60 5.1
hgs
parents:
diff changeset
    65
 */
hgs
parents:
diff changeset
    66
class CPluginTimer : public CTimer
hgs
parents:
diff changeset
    67
    {
hgs
parents:
diff changeset
    68
public:
hgs
parents:
diff changeset
    69
    /**
hgs
parents:
diff changeset
    70
     * Static method for instantiation.
hgs
parents:
diff changeset
    71
     * The instantiation also adds the instance to active scheduler and
hgs
parents:
diff changeset
    72
     * triggers start of the (embedded CTimer) timer.
hgs
parents:
diff changeset
    73
     *
hgs
parents:
diff changeset
    74
     * @param aInterval  Timeout value for command execution emulation.
hgs
parents:
diff changeset
    75
     * @param aService   Pointer to the object that handles the responses
hgs
parents:
diff changeset
    76
     *                   from command execution emulation. I.e., pointer
hgs
parents:
diff changeset
    77
     *                   to an object outside the test stub plugin that
hgs
parents:
diff changeset
    78
     *                   handles responses from all kinds of haptics plugins.
hgs
parents:
diff changeset
    79
     *                   In practice this is the Haptics plugin manager.
hgs
parents:
diff changeset
    80
     * @param aCommandId Id of the command whose execution is emulated.
hgs
parents:
diff changeset
    81
     * @param aTransId   Id of the transaction to which the emulated command
hgs
parents:
diff changeset
    82
     *                   belongs to. 
hgs
parents:
diff changeset
    83
     * @param aRetVal    Return value of the emulated command.
hgs
parents:
diff changeset
    84
     * @param aCallback  Pointer to the object that further handles the
hgs
parents:
diff changeset
    85
     *                   command emulation (i.e., pointer to the actual test
hgs
parents:
diff changeset
    86
     *                   stub plugin object). 
hgs
parents:
diff changeset
    87
     */
hgs
parents:
diff changeset
    88
    static CPluginTimer* NewL(
hgs
parents:
diff changeset
    89
            const TTimeIntervalMicroSeconds32& aInterval, 
hgs
parents:
diff changeset
    90
            MHWRMHapticsPluginCallback* aService,
hgs
parents:
diff changeset
    91
            TInt aCommandId,
hgs
parents:
diff changeset
    92
            TUint8 aTransId,
hgs
parents:
diff changeset
    93
            TInt aRetVal,
hgs
parents:
diff changeset
    94
            MPluginTimerCallback* aCallback);
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
    /**
hgs
parents:
diff changeset
    97
     * Destructor
hgs
parents:
diff changeset
    98
     */        
hgs
parents:
diff changeset
    99
    ~CPluginTimer();
hgs
parents:
diff changeset
   100
        
hgs
parents:
diff changeset
   101
    /**
hgs
parents:
diff changeset
   102
     * RunL handles (embedded CTimer) timer expirations.
hgs
parents:
diff changeset
   103
     *
hgs
parents:
diff changeset
   104
     * @see CActive
hgs
parents:
diff changeset
   105
     * @see CTimer
hgs
parents:
diff changeset
   106
     */
hgs
parents:
diff changeset
   107
    void RunL();
hgs
parents:
diff changeset
   108
        
hgs
parents:
diff changeset
   109
    /**
hgs
parents:
diff changeset
   110
     * Getter for transaction Id
hgs
parents:
diff changeset
   111
     */
hgs
parents:
diff changeset
   112
    TUint8 TransId() const;
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
private:
hgs
parents:
diff changeset
   115
    /**
hgs
parents:
diff changeset
   116
     * Constructor
hgs
parents:
diff changeset
   117
     * 
hgs
parents:
diff changeset
   118
     * @param aPriority
hgs
parents:
diff changeset
   119
     * @param aService   Pointer to an object that implements
hgs
parents:
diff changeset
   120
     *                   the MHWRMHapticsPluginCallback interface
hgs
parents:
diff changeset
   121
     *                   and thus handles the callbacks from this 
hgs
parents:
diff changeset
   122
     *                   whole test plugin.
hgs
parents:
diff changeset
   123
     * @param aCommandId Id of the command for which the timer-based
hgs
parents:
diff changeset
   124
     *                   command execution emulation is started.
hgs
parents:
diff changeset
   125
     * @param aTransId   Transaction Id 
hgs
parents:
diff changeset
   126
     * @param aRetVal
hgs
parents:
diff changeset
   127
     * @param aCallback  Pointer to an object that implements the above 
hgs
parents:
diff changeset
   128
     *                   declared MPluginTimerCallback interface. In 
hgs
parents:
diff changeset
   129
     *                   practice this is the CHWRMHapticsTestPlugin
hgs
parents:
diff changeset
   130
     *                   object.
hgs
parents:
diff changeset
   131
     */
hgs
parents:
diff changeset
   132
    CPluginTimer( TInt aPriority, 
hgs
parents:
diff changeset
   133
                  MHWRMHapticsPluginCallback* aService,
hgs
parents:
diff changeset
   134
                  TInt aCommandId,
hgs
parents:
diff changeset
   135
                  TUint8 aTransId,
hgs
parents:
diff changeset
   136
                  TInt aRetVal,
hgs
parents:
diff changeset
   137
                  MPluginTimerCallback* aCallback );
hgs
parents:
diff changeset
   138
                  
hgs
parents:
diff changeset
   139
    /**
hgs
parents:
diff changeset
   140
     * Two-phase construction. ConstructL is needed because parent
hgs
parents:
diff changeset
   141
     * class (CTimer) requires two-phase construction.
hgs
parents:
diff changeset
   142
     */
hgs
parents:
diff changeset
   143
    void ConstructL();
hgs
parents:
diff changeset
   144
          
hgs
parents:
diff changeset
   145
private: // data
hgs
parents:
diff changeset
   146
    
hgs
parents:
diff changeset
   147
    /**
hgs
parents:
diff changeset
   148
     * Pointer to an object that handles responses from this 
hgs
parents:
diff changeset
   149
     * test plugin (i.e., in practice the Haptics plugin manager).
hgs
parents:
diff changeset
   150
     */ 
hgs
parents:
diff changeset
   151
    MHWRMHapticsPluginCallback* iService;  // Not owned
hgs
parents:
diff changeset
   152
        
hgs
parents:
diff changeset
   153
    /**
hgs
parents:
diff changeset
   154
     * Id of the command whose execution is being emulated by
hgs
parents:
diff changeset
   155
     * the test plugin
hgs
parents:
diff changeset
   156
     */     
hgs
parents:
diff changeset
   157
    TInt iCommandId;
hgs
parents:
diff changeset
   158
 
hgs
parents:
diff changeset
   159
    /**
hgs
parents:
diff changeset
   160
     * Id of the transaction to which the command, whose execution
hgs
parents:
diff changeset
   161
     * is being emulated by the test plugin, belongs to
hgs
parents:
diff changeset
   162
     */
hgs
parents:
diff changeset
   163
    TUint8 iTransId;
hgs
parents:
diff changeset
   164
hgs
parents:
diff changeset
   165
    /**
hgs
parents:
diff changeset
   166
     * Return value that the emulated command execution is to return.
hgs
parents:
diff changeset
   167
     */
hgs
parents:
diff changeset
   168
    TInt iRetVal;
hgs
parents:
diff changeset
   169
       
hgs
parents:
diff changeset
   170
    /**
hgs
parents:
diff changeset
   171
     * Pointer to an object that further handles the timer expiries
hgs
parents:
diff changeset
   172
     * from this CPluginTimer object.
hgs
parents:
diff changeset
   173
     * I.e, pointer to the actual test plugin object
hgs
parents:
diff changeset
   174
     */   
hgs
parents:
diff changeset
   175
    MPluginTimerCallback* iCallback;  // Not owned
hgs
parents:
diff changeset
   176
    
hgs
parents:
diff changeset
   177
    };
hgs
parents:
diff changeset
   178
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
#endif // __HWRMHAPTICSTESTPLUGINTIMER_H_