svgtopt/nvgdecoder/inc/NVGIconData.h
author hgs
Wed, 03 Nov 2010 18:56:10 +0200
changeset 46 88edb906c587
permissions -rw-r--r--
201044
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2003 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 "Eclipse Public 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.eclipse.org/legal/epl-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:  NVG Decoder 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
#ifndef CNVGICONDATA_H_
hgs
parents:
diff changeset
    20
#define CNVGICONDATA_H_
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include <e32base.h>
hgs
parents:
diff changeset
    23
#include <s32mem.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
/**
hgs
parents:
diff changeset
    27
 * @class CNVGIconData
hgs
parents:
diff changeset
    28
 *        This class is useful when you want to read nd write data from and to memory
hgs
parents:
diff changeset
    29
 *        This class check for buffer overflow
hgs
parents:
diff changeset
    30
 *        This is much faster than stream classes provided by symbian
hgs
parents:
diff changeset
    31
 *        During the ETM traces we found that those classes are 3 FPS less than these utility classes
hgs
parents:
diff changeset
    32
 *        This class will be checking for data alignment
hgs
parents:
diff changeset
    33
 */
hgs
parents:
diff changeset
    34
class CNVGIconData : public CBase
hgs
parents:
diff changeset
    35
    {
hgs
parents:
diff changeset
    36
private:
hgs
parents:
diff changeset
    37
    CNVGIconData();
hgs
parents:
diff changeset
    38
    void ConstructL(TUint aLength);
hgs
parents:
diff changeset
    39
    void ConstructL(const TDesC8& aBuf);
hgs
parents:
diff changeset
    40
    
hgs
parents:
diff changeset
    41
public:
hgs
parents:
diff changeset
    42
    
hgs
parents:
diff changeset
    43
    /**
hgs
parents:
diff changeset
    44
     * Here the user should only read. Will Behave undefinitly if try to write.
hgs
parents:
diff changeset
    45
     */
hgs
parents:
diff changeset
    46
    static CNVGIconData * NewL(const TDesC8& aBuf);
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
    static CNVGIconData * NewL(TInt aLength = 0);
hgs
parents:
diff changeset
    49
    
hgs
parents:
diff changeset
    50
    static CNVGIconData * NewLC(const TDesC8& aBuf);
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
    static CNVGIconData * NewLC(TInt aLength = 0);
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
    static CNVGIconData * NewL(TUint8 * aBuf, TInt aLength);
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
    static CNVGIconData * NewLC(TUint8 * aBuf, TInt aLength);
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
    virtual ~CNVGIconData();
hgs
parents:
diff changeset
    59
    
hgs
parents:
diff changeset
    60
    void Set(const TDesC8& aBuf);
hgs
parents:
diff changeset
    61
    
hgs
parents:
diff changeset
    62
    void Set(TUint8 * aBuf, TInt aLength);
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
    TInt EncodeInt8(TUint8 aVal);
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
    TInt EncodeInt16(TUint16 aVal);
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
    TInt EncodeInt32(TUint32 aVal);
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
    TInt EncodeReal32(TReal32 aVal);
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
    TInt EncodeReal64(TReal64 aVal);
hgs
parents:
diff changeset
    73
    
hgs
parents:
diff changeset
    74
    TInt EncodeData(const TAny *aData, TUint aLength);
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
    void EncodeInt8L(TUint8 aVal);
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
    void EncodeInt16L(TUint16 aVal);
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
    void EncodeInt32L(TUint32 aVal);
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
    void EncodeReal32L(TReal32 aVal);
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
    void EncodeReal64L(TReal64 aVal);
hgs
parents:
diff changeset
    85
    
hgs
parents:
diff changeset
    86
    void EncodeDataL(const TAny *aData, TUint aLength);
hgs
parents:
diff changeset
    87
    
hgs
parents:
diff changeset
    88
    TInt ExpandEncodedData(TUint aNewLength);
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
    const HBufC8 * GetNVGData() const;
hgs
parents:
diff changeset
    91
    
hgs
parents:
diff changeset
    92
    const HBufC8 * GetNVGData();
hgs
parents:
diff changeset
    93
    
hgs
parents:
diff changeset
    94
    void BeginRead();
hgs
parents:
diff changeset
    95
    void EndRead();
hgs
parents:
diff changeset
    96
    
hgs
parents:
diff changeset
    97
    TInt16 ReadInt16L();
hgs
parents:
diff changeset
    98
    
hgs
parents:
diff changeset
    99
    TInt32 ReadInt32L();
hgs
parents:
diff changeset
   100
    
hgs
parents:
diff changeset
   101
    TInt8 ReadInt8L();
hgs
parents:
diff changeset
   102
    
hgs
parents:
diff changeset
   103
    void ReadL(TDes8 &aDes, TInt aLength);
hgs
parents:
diff changeset
   104
    
hgs
parents:
diff changeset
   105
    void ReadL(TUint8 *aPtr, TInt aLength);
hgs
parents:
diff changeset
   106
    
hgs
parents:
diff changeset
   107
    TReal32 ReadReal32L();
hgs
parents:
diff changeset
   108
    
hgs
parents:
diff changeset
   109
    TReal64 ReadReal64L();
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
    void SkipL(TInt aLength);
hgs
parents:
diff changeset
   112
    
hgs
parents:
diff changeset
   113
    TInt ReadPos();
hgs
parents:
diff changeset
   114
    
hgs
parents:
diff changeset
   115
    TBool EOF();
hgs
parents:
diff changeset
   116
    
hgs
parents:
diff changeset
   117
    TInt DataLength();
hgs
parents:
diff changeset
   118
            
hgs
parents:
diff changeset
   119
private:
hgs
parents:
diff changeset
   120
    
hgs
parents:
diff changeset
   121
    void CheckOutOfBoundL(TInt aLength);
hgs
parents:
diff changeset
   122
    
hgs
parents:
diff changeset
   123
    HBufC8 *            iNVGData;
hgs
parents:
diff changeset
   124
    TPtr8               iNVGDataPtr;
hgs
parents:
diff changeset
   125
    TInt                iTotalRead;
hgs
parents:
diff changeset
   126
    TInt                iDataLength;
hgs
parents:
diff changeset
   127
    TUint8 *            iReadStream;
hgs
parents:
diff changeset
   128
    };
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
/**
hgs
parents:
diff changeset
   131
 * @class TDereferencer
hgs
parents:
diff changeset
   132
 *        This class is useful when you want to dereference character data
hgs
parents:
diff changeset
   133
 *        This class check for buffer overflow
hgs
parents:
diff changeset
   134
 *        This is much faster than stream classes provided by symbian
hgs
parents:
diff changeset
   135
 *        During the ETM traces we found that those classes are 3 FPS less than these utility classes
hgs
parents:
diff changeset
   136
 *        This class won't be checking for data alignment.
hgs
parents:
diff changeset
   137
 */
hgs
parents:
diff changeset
   138
class TDereferencer
hgs
parents:
diff changeset
   139
    {
hgs
parents:
diff changeset
   140
public:
hgs
parents:
diff changeset
   141
    
hgs
parents:
diff changeset
   142
    TDereferencer(TUint8 * aBuf, TInt aLength);
hgs
parents:
diff changeset
   143
    
hgs
parents:
diff changeset
   144
    TDereferencer(const TDesC8& aBuf);
hgs
parents:
diff changeset
   145
    
hgs
parents:
diff changeset
   146
    /**
hgs
parents:
diff changeset
   147
     *  @fn         SkipL
hgs
parents:
diff changeset
   148
     *              Advances the read pointer with the given length
hgs
parents:
diff changeset
   149
     */void SkipL(TInt aLength);
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
    /**
hgs
parents:
diff changeset
   152
     * @fn          DerefInt16L
hgs
parents:
diff changeset
   153
     *              Converts current position to TInt16 *. The caller should take care of alignment
hgs
parents:
diff changeset
   154
     *              The advantage of this method is that you don't have to copy the data
hgs
parents:
diff changeset
   155
     *              Bound check will happen
hgs
parents:
diff changeset
   156
     * @param       aAt dereference from this position
hgs
parents:
diff changeset
   157
     * @exception   Leaves if data size is not sufficient       
hgs
parents:
diff changeset
   158
     */
hgs
parents:
diff changeset
   159
    TInt16 DerefInt16L(TInt aAt = 0);
hgs
parents:
diff changeset
   160
    operator TInt16();
hgs
parents:
diff changeset
   161
    
hgs
parents:
diff changeset
   162
    /**
hgs
parents:
diff changeset
   163
     * @fn          DerefInt32L
hgs
parents:
diff changeset
   164
     *              Converts current position to TInt32 *. The caller should take care of alignment
hgs
parents:
diff changeset
   165
     *              The advantage of this method is that you don't have to copy the data
hgs
parents:
diff changeset
   166
     *              Bound check will happen
hgs
parents:
diff changeset
   167
     * @param       aAt dereference from this position
hgs
parents:
diff changeset
   168
     * @exception   Leaves if data size is not sufficient       
hgs
parents:
diff changeset
   169
     */
hgs
parents:
diff changeset
   170
    TInt32 DerefInt32L(TInt aAt = 0);
hgs
parents:
diff changeset
   171
    operator TInt32();
hgs
parents:
diff changeset
   172
    
hgs
parents:
diff changeset
   173
    /**
hgs
parents:
diff changeset
   174
     * @fn          DerefInt8L
hgs
parents:
diff changeset
   175
     *              Converts current position to TInt8 *. The caller should take care of alignment
hgs
parents:
diff changeset
   176
     *              The advantage of this method is that you don't have to copy the data
hgs
parents:
diff changeset
   177
     *              Bound check will happen
hgs
parents:
diff changeset
   178
     * @param       aAt dereference from this position
hgs
parents:
diff changeset
   179
     * @exception   Leaves if data size is not sufficient       
hgs
parents:
diff changeset
   180
     */
hgs
parents:
diff changeset
   181
    TInt8 DerefInt8L(TInt aAt = 0);
hgs
parents:
diff changeset
   182
    operator TInt8();
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
    /**
hgs
parents:
diff changeset
   185
     * @fn          DerefInt8ArrayL
hgs
parents:
diff changeset
   186
     *              Converts current position to TUint8 *. The caller should take care of alignment
hgs
parents:
diff changeset
   187
     *              The advantage of this method is that you don't have to copy the data
hgs
parents:
diff changeset
   188
     *              Bound check will happen
hgs
parents:
diff changeset
   189
     * @param       aLength making safe to dereference for this size
hgs
parents:
diff changeset
   190
     * @param       aAt dereference from this position
hgs
parents:
diff changeset
   191
     * @exception   Leaves if data size is not sufficient       
hgs
parents:
diff changeset
   192
     */
hgs
parents:
diff changeset
   193
    TUint8 * DerefInt8ArrayL(TInt aLength, TInt aAt = 0);
hgs
parents:
diff changeset
   194
       
hgs
parents:
diff changeset
   195
    /**
hgs
parents:
diff changeset
   196
     * @fn          ReadReal32L
hgs
parents:
diff changeset
   197
     *              Converts current position to TReal32 *. The caller should take care of alignment
hgs
parents:
diff changeset
   198
     *              The advantage of this method is that you don't have to copy the data
hgs
parents:
diff changeset
   199
     *              Bound check will happen
hgs
parents:
diff changeset
   200
     * @param       aAt dereference from this position
hgs
parents:
diff changeset
   201
     * @exception   Leaves if data size is not sufficient       
hgs
parents:
diff changeset
   202
     */
hgs
parents:
diff changeset
   203
    TReal32 DerefReal32L(TInt aAt = 0);
hgs
parents:
diff changeset
   204
    operator TReal32();
hgs
parents:
diff changeset
   205
    
hgs
parents:
diff changeset
   206
    /**
hgs
parents:
diff changeset
   207
     * @fn          ReadReal64L
hgs
parents:
diff changeset
   208
     *              Converts current position to TReal64 *. The caller should take care of alignment
hgs
parents:
diff changeset
   209
     *              The advantage of this method is that you don't have to copy the data
hgs
parents:
diff changeset
   210
     *              Bound check will happen
hgs
parents:
diff changeset
   211
     * @param       aAt dereference from this position
hgs
parents:
diff changeset
   212
     * @exception   Leaves if data size is not sufficient
hgs
parents:
diff changeset
   213
     */
hgs
parents:
diff changeset
   214
    TReal64 DerefReal64L(TInt aAt = 0);
hgs
parents:
diff changeset
   215
    operator TReal64();
hgs
parents:
diff changeset
   216
hgs
parents:
diff changeset
   217
    /**
hgs
parents:
diff changeset
   218
     * @fn          IsSafeL
hgs
parents:
diff changeset
   219
     *              Checks whether dereferencing is safe for the given length from the given offset
hgs
parents:
diff changeset
   220
     * @param       aLength length for dereferencing
hgs
parents:
diff changeset
   221
     * @param       aAt offset from where the dereferencing should start
hgs
parents:
diff changeset
   222
     */
hgs
parents:
diff changeset
   223
    void IsSafeL(TInt aLength, TInt aAt = 0);
hgs
parents:
diff changeset
   224
hgs
parents:
diff changeset
   225
    /**
hgs
parents:
diff changeset
   226
     * @fn          GetPtr
hgs
parents:
diff changeset
   227
     *              Retrieves the ptr to the data stream
hgs
parents:
diff changeset
   228
     */
hgs
parents:
diff changeset
   229
    TPtr8 GetPtr();
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231
    /**
hgs
parents:
diff changeset
   232
     * Retrieves the silze of the buffer
hgs
parents:
diff changeset
   233
     */
hgs
parents:
diff changeset
   234
    TInt GetLength();
hgs
parents:
diff changeset
   235
    
hgs
parents:
diff changeset
   236
    /**
hgs
parents:
diff changeset
   237
     * Returns current reading position
hgs
parents:
diff changeset
   238
     */
hgs
parents:
diff changeset
   239
    TInt GetReadingPos();
hgs
parents:
diff changeset
   240
hgs
parents:
diff changeset
   241
private:
hgs
parents:
diff changeset
   242
    void CheckOutOfBoundL(TInt aLength);
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
    TInt                iTotalRead;
hgs
parents:
diff changeset
   245
    TInt                iDataLength;
hgs
parents:
diff changeset
   246
    TUint8 *            iReadStream;
hgs
parents:
diff changeset
   247
    };
hgs
parents:
diff changeset
   248
hgs
parents:
diff changeset
   249
#include "NVGIconData.inl"
hgs
parents:
diff changeset
   250
hgs
parents:
diff changeset
   251
#endif