localconnectivityservice/generichid/src/hidreportgenerator.cpp
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) 2004-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:  HID retport generator
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
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#include "hidreportgenerator.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
#include "hidreportroot.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include "hidinterfaces.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
// ======== MEMBER FUNCTIONS ========
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
// NewLC()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
EXPORT_C CReportGenerator* CReportGenerator::NewLC(const CReportRoot*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
    aReportRoot, TInt aReportId, CField::TType aType)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
    CReportGenerator* self = new (ELeave) CReportGenerator(aReportId, aType);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
    CleanupStack::PushL(self);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
    self->ConstructL(aReportRoot);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
    return self;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
// NewL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
EXPORT_C CReportGenerator* CReportGenerator::NewL(const CReportRoot*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
    aReportRoot, TInt aReportId, CField::TType aType)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
    CReportGenerator* self =
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
        CReportGenerator::NewLC(aReportRoot, aReportId, aType);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
    CleanupStack::Pop(self);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
    return self;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
// Constructor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
CReportGenerator::CReportGenerator(TInt aReportId, CField::TType aType)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
    : iReportId(aReportId), iType(aType)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
    // Nothing else to do
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
// ConstructL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
void CReportGenerator::ConstructL(const CReportRoot* aReportRoot)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
    User::LeaveIfNull(const_cast<CReportRoot*>(aReportRoot));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
    iReportRoot = aReportRoot;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
    // Allocate the buffer, initialise to all zeros, and fill in the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
    // report ID if used.  Zero should be a null value for all array fields
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
    // according to the HID parser error checking spec.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
    iBuf = HBufC8::NewMaxL(aReportRoot->ReportSizeBytes(iReportId, iType));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
    TPtr8 bufptr = iBuf->Des(); 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
    bufptr.FillZ();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
    if ( 0 != iReportId )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
        bufptr[0] = static_cast<TUint8>(iReportId);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
// Destructor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
CReportGenerator::~CReportGenerator()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
    delete iBuf;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
// SetField()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
EXPORT_C TInt CReportGenerator::SetField(const CField* aField,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
    TInt aUsageId, TInt aValue, TInt aControlOffset /*= 0*/)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
    TInt usageIndex;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
    if ( aField && TReportUtils::GetIndexOfUsage(aField, aUsageId, usageIndex) )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
        if ( aField->IsArray() )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
            // Convert usage ID to logical value
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
            TInt logicalValue = usageIndex + aField->LogicalMin();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
            // Find unused position in the array and write the logical
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
            // value to it
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
            for ( TInt i = 0; i < aField->Count(); i++ )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
                {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
                TInt value;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
                TInt error = TReportUtils::ReadData(*iBuf, aField, i, value);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
                if ( KErrNone != error )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
                    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
                    return error;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
                    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
                if ( value == logicalValue )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
                    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
                    // The array already contains this usage
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
                    return KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
                    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
                else if ( 0 == value || value < aField->LogicalMin() ||
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
                    aField->LogicalMax() < value )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
                    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
                    // This is an unused position
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
                    //
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
                    // NOTE: The comparison with zero is because the buffer is
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
                    // initialised to all zeros, and some reports erroneously
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
                    // include zero in the logical range.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
                    //
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
                    return TReportUtils::WriteData(*iBuf, aField, i, logicalValue);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
                    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
                }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
            return KErrNoSpaceInArray;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
        else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
            // Check the value to set is valid
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
            if ( aValue < aField->LogicalMin() ||
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
                aField->LogicalMax() < aValue )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
                {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
                return KErrValueOutOfRange;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
                }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
            return TReportUtils::WriteData(*iBuf, aField,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
                usageIndex + aControlOffset, aValue);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
    return KErrUsageNotFound;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
// SetField()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
EXPORT_C TPtr8 CReportGenerator::Report()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
    return iBuf->Des();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
    }