localconnectivityservice/generichid/inc/hiditem.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:  BTHid item
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
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    19
#ifndef T_ITEM_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#define T_ITEM_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include <e32std.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
 * HID item class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
 * A HID report descriptor is comprised of a sequence of "items"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
 * that provide information about the device.  Items consist of a
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
 * header and zero or more bytes of data.  The header contains the item
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
 * type (main/global/local), an item "tag" (subtype) and the item size.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
 * Items can be "short" (containing a maximum of 4 bytes of data) or
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
 * "long" (a maximum of 255 bytes of data).
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
 * A TItem represents a single HID report descriptor item. It is
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
 * constructed from an eight bit non-modifiable (Symbian-) descriptor,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
 * which is assumed to contain report (HID-) descriptor data.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
 * @lib generichid.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
 * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
class TItem
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
     * The possible item types: main, global or local.  Item type is
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
     * a two-bit field -- the 11b value is reserved for "long items", which
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
     * are only used for vendor-specific commands.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
    enum TItemType
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
        EMain = 0,    //!< Input, output, feature and begin or end collection
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
        EGlobal = 1,  //!< Global item items affect all subsequent fields
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
        ELocal = 2,   //!< Local items only persist until the next main item
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
        EReserved = 3 //!< No defined use in the current HID standard (v1.11)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
        };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
     * The constructor takes a an eight bit non-modifiable (Symbian-)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
     * descriptor containing report (HID-) descriptor data.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
     * The item tag, type, data size and offset are calculated here.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
     * @param aRawData The raw item data, represented as a Symbian
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
     * descriptor. The item data is assumed to be at the beginning of the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
     * descriptor. The size of the TDesC8 may be greater than the size
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
     * of the item, as the item size will be calculated from the raw HID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
     * descriptor data.  Of course, the TDesC8 should be at least as
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
     * long as the raw item data.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
    TItem(const TDesC8& aRawData);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
     * DataSize() returns the size of the item data in bytes. This
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
     * is the total item size minus the size of any header information.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
     * (A short item header is a single byte, a long item header is
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
     * three bytes long.)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
     * @return The size, in bytes, of the item data. Range 0-255.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
    TInt DataSize() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
     * Tag() returns the tag (subtype) value for this item.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
     * @return The item tag.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
    TInt Tag() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
     * Data() returns the data associated with the item, represented as a
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
     * 32-bit unsigned integer.  This is only meaningful if the data length
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
     * is less than 4 bytes.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
     * @return The item data as a 32-bit unsigned integer.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
    TUint32 Data() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
     * SignedData() returns the data associated with the item,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
     * represented as a 32-bit signed integer.  This is only
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
     * meaningful if the data length is less than 4 bytes.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
     * @return The item data as a 32-bit signed integer.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
    TInt32 SignedData() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
     * Returns the byte at the given offset within the item data block.     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
     * @param aIndex The index within the data block for the current tag.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
     * @return The data at the specified index.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
    TUint8 operator[](TInt aIndex) const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
     * Type() returns the item type (e.g. "global").
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
     * @since S60 v5.0     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
     * @return The item type.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
    TItemType Type() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
     * Check if item is main
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
     * @return ETrue if item type is "main"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
    TBool IsMain() 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
     * Check if item is local
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
     * @return ETrue if item type is "local"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
    TBool IsLocal() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
     * Check if item is global
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
     * @return ETrue if item type is "global"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
    TBool IsGlobal() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
     * Check if item is global
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
     * @return ETrue if this is a long item
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
    TBool IsLong() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
     * ItemSize() returns the total size of this item, including the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
     * header data.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
     * @return The total size of this item, in bytes.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
    TInt ItemSize() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
private:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
     * Pointer to the raw report descriptor data
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
    TPtrC8 iRawData;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
     * Item data size
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
    TInt iSize;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
     * Item tag value
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
    TInt iTag;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   186
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   187
     * Offset in bytes of the data block
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   188
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
    TInt iDataOffset;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   191
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   192
     * Item type
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   193
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   194
    TItemType iType;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   195
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   196
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   197
#endif
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   198