remoteconn_plat/generic_hid_api/inc/hidtranslate.h
author hgs
Thu, 04 Nov 2010 15:31:42 +0800
changeset 60 841f70763fbe
parent 29 3ae5cb0b4c02
permissions -rw-r--r--
201044_04
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     1
/*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     2
* Copyright (c) 2005-2007 Nokia Corporation and/or its subsidiary(-ies).
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     3
* All rights reserved.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     8
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     9
* Initial Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    11
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    12
* Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    13
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    14
* Description:  Report translator
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    15
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    16
*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    17
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    18
#ifndef T_TRANSLATE_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    19
#define T_TRANSLATE_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
#include <e32std.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
class CField;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
 * HID report base object
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
 * Base class for report translator and report generator.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
 * Contains only static functions.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
 * @lib  generichid.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
 * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
class TReportUtils
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
     *  Find the index within the usages for a field of a given usage ID.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
     *  @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
     *  @param aField Pointer to the field.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
     *  @param aUsageId Usage ID to find.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
     *  @param aUsageIndex Reference to variable to receive the index.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
     *  @return True if the usage ID is found.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
    static TBool GetIndexOfUsage(const CField* aField,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
        TInt aUsageId, TInt& aUsageIndex);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
     *  Find the usage ID at a given index within the usages for a field.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
     *  @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
     *  @param aField Pointer to the field.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
     *  @param aUsageIndex The index.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
     *  @return The usage ID at the given index.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
    static TInt UsageAtIndex(const CField* aField, TInt aUsageIndex);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
     *  Write a value to a field at a given index.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
     *  @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
     *  @param aData Buffer containing the HID report.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
     *  @param aField The field in which to write.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
     *  @param aIndex Position in the field to write.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
     *  @param aValue Value to write to the field.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
     *  @return Error code indicating success or reason for failure.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
    static TInt WriteData(HBufC8& aData, const CField* aField,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
        TInt aIndex, TInt aValue);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
     *  Read a value from a field at a given index.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
     *  @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
     *  @param aData Buffer containing the HID report.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
     *  @param aField The field from which to read.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
     *  @param aIndex Position in the field to read.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
     *  @param aValue Reference to variable to receive the value read
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
     *                from the field.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
     *  @return Error code indicating success or reason for failure.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
    static TInt ReadData(const TDesC8& aData, const CField* aField,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
        TInt aIndex, TInt& aValue);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
 * HID report translator
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
 * Allows a device driver to extract data items from a device report, based on
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
 * the results of the report descriptor parser stage (at device connection)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
 * @lib  generichid.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
 * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
class TReportTranslator
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
     * Constructor.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
     * @param aData Data to be extracted
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
     * @param aField  HID field
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
     * @return return TReportTranslator
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
    IMPORT_C TReportTranslator(const TDesC8& aData, const CField* aField);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
     * For variable fields, reads the logical value of the control with the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
     * given usage ID.  For arrays, searches for the usage ID and gives the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
     * value as ETrue if found and EFalse if not.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
     * @param aValue Reference to variable to receive the value read
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
     *  from the field.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
     * @param aUsageId Usage ID of the control to read.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
     * @param aControlOffset Which control to read when more than one
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
     *                       have the same usage ID.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
     * @return Error code indicating success or reason for failure.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
    IMPORT_C TInt GetValue(TInt& aValue, TInt aUsageId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
        TInt aControlOffset = 0) const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
     * Alternate version of the above method for convenience.  Returns the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
     * value read directly and leaves if an error occurs.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
     * @param aUsageId Usage ID of the control to read.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
     * @param aControlOffset Which control to read when more than one
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
     *                       have the same usage ID.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
     * @return The logical value of a variable, or true/false for an array.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
    IMPORT_C TInt ValueL(TInt aUsageId, TInt aControlOffset = 0) const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
     * Gets the usage ID at a given index in an array field.  For variable
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
     * fields, if the logical value of the control at the given index is non-
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
     * zero, returns the usage ID of the control, otherwise returns zero.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
     * @param aUsageId Reference to variable to receive the usage ID.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
     * @param aIndex Index in the array to read.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
     * @return Error code indicating success or reason for failure.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
    IMPORT_C TInt GetUsageId(TInt& aUsageId, TInt aIndex) const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
     * Alternate version of the above method for convenience.  Returns the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
     * usage ID directly and leaves if an error occurs.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
     * @param aIndex Index in the array to read.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
     * @return The usage ID.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
    IMPORT_C TInt UsageIdL(TInt aIndex) const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
     * Gets the logical value at a given index in a field.  Leaves if an
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
     * error occurs.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
     * @param aIndex Index in the field to read.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
     * @return The logical value.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
    IMPORT_C TInt RawValueL(TInt aIndex) const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
     * Gets the number of controls in the field.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
     * @return The number of controls.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
    IMPORT_C TInt Count() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
private:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
     * Data to be extracted
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
    const TDesC8& iData;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
     * HID field
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   186
     * Not own.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   187
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   188
    const CField* iField;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   191
#endif