javauis/m2g_qt/inc/M2GGeneral.h
author hgs
Fri, 23 Jul 2010 12:27:20 +0300
changeset 56 abc41079b313
permissions -rw-r--r--
v2.2.7_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     1
/*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     2
* Copyright (c) 2005-2006 Nokia Corporation and/or its subsidiary(-ies).
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     3
* All rights reserved.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     8
*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     9
* Initial Contributors:
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    11
*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    12
* Contributors:
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    13
*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    14
* Description:  General definitions
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    15
*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    16
*/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    17
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    18
#ifndef M2GGENERAL_H
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    19
#define M2GGENERAL_H
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    20
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    21
#include <e32base.h>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    22
#include <jutils.h>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    23
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    24
#if defined ( _DEBUG )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    25
#if defined ( __WINSCW__ )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    26
// #define M2G_DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    27
#endif // __WINSCW__
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    28
#endif  // _DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    29
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    30
#ifdef M2G_DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    31
// #define M2G_INFO_POPUP
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    32
#define M2G_STATISTIC_DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    33
#include <flogger.h>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    34
#include <jdebug.h>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    35
#ifdef M2G_STATISTIC_DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    36
#include <HAL.h>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    37
#include <hal_data.h>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    38
#endif // M2G_STATISTIC_DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    39
#endif // M2G_DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    40
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    41
#include "JcfAutoPtr.h"// cfcommon::auto_ptr<>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    42
#include "M2GNamespace.h"
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    43
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    44
//#if defined( __cplusplus )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    45
//extern "C" {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    46
//#endif
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    47
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    48
M2G_NS_START
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    49
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    50
// CONSTANTS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    51
// == ALPHA BLEND CONSTANTS ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    52
const TUint8 KFullOpaque = 0xFF;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    53
const TUint8 KFullTransparent = 0x00;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    54
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    55
// == ERROR TEXT CONSTANTS ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    56
_LIT8(KM2GEmptyString8, "");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    57
_LIT(KM2GEmptyString, "");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    58
_LIT(KGraphicsContextErrText, "Invalid M2G graphics context");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    59
_LIT(KOffscreenErrText, "Invalid M2G offscreen bitmap");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    60
_LIT(KSvgProxyPointerErrText, "Invalid SVG proxy pointer");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    61
_LIT(KSvgEnginePointerErrText, "Invalid SVG engine pointer");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    62
_LIT(KSvgTargetGraphicsPointerErrText, "Invalid target graphics pointer");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    63
_LIT(KNotSupportedErrText, "Not supported");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    64
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    65
// == ERROR CODE CONSTANTS ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    66
const TInt KM2GOk = KErrNone;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    67
const TInt KM2GNotOk = KErrGeneral;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    68
const TInt KM2GHandleNotOk = KErrBadHandle;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    69
const TInt KM2GArgNotOk = KErrArgument;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    70
const TInt KM2GSupportedNotOk = KErrNotSupported;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    71
const TInt KM2GMemoryNotOk = KErrNoMemory;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    72
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    73
// Own error codes
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    74
const TInt KM2GIOException = -10;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    75
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    76
// Java exception class names
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    77
_LIT8(KJavaExceptionClass, "java/lang/Exception");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    78
_LIT8(KJavaIOExceptionClass, "java/io/IOException");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    79
_LIT8(KJavaOutOfMemoryErrorClass, "java/lang/OutOfMemoryError");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    80
_LIT8(KJavaNullPointerException, "java/lang/NullPointerException");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    81
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    82
// == SVG CONSTANTS ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    83
const TInt KM2GRestartAttribute = 114; // M2GSVGConstants.AT_RESTART
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    84
const TInt KM2GRestartNever = 471; // M2GSVGConstants.RESTART_NEVER
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    85
const TInt KM2GRestartWhenNotActive = 472; // M2GSVGConstants.RESTART_WHENNOTACTIVE
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    86
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    87
// == HANDLE MACROS ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    88
#define M2G_INVALID_HANDLE /**/ 0
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    89
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    90
// FORWARD DECLARATIONS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    91
class RWriteStream;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    92
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    93
// FUNCTION PROTOTYPES
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    94
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    95
// CLASS DECLARATION
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    96
/**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    97
 * General static methods
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    98
 * @lib -
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    99
 * @series Series S60 3.0
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   100
 */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   101
class M2GGeneral
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   102
{
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   103
public: // STATIC METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   104
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   105
     * Check if a handle is valid
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   106
     * @since Series S60 3.0
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   107
     * @param aHandle
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   108
     * @return ETrue if a handle is valid.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   109
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   110
    template<typename T>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   111
    inline static TBool IsHandleValid(const T& aHandle)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   112
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   113
        return ((aHandle == M2G_INVALID_HANDLE) ? EFalse : ETrue);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   114
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   115
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   116
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   117
     * Returns min
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   118
     * @since Series S60 3.0
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   119
     * @param a Left parameter
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   120
     * @param b Right parameter
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   121
     * @return Returns min
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   122
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   123
    template<typename T>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   124
    inline static T Min(const T& a, const T& b)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   125
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   126
        return ((a) <= (b) ? (a) : (b));
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   127
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   128
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   129
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   130
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   131
     * Returns max
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   132
     * @since Series S60 3.0
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   133
     * @param a Left parameter
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   134
     * @param b Right parameter
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   135
     * @return Returns max
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   136
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   137
    template<typename T>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   138
    inline static T Max(const T& a, const T& b)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   139
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   140
        return ((a) >= (b) ? (a) : (b));
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   141
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   142
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   143
     * Instantiates an Java exception object with the message specified by
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   144
     * message, and causes that exception to be thrown in Java side. A thrown
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   145
     * exception will be pending in the current thread, but does not
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   146
     * immediately disrupt native code execution.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   147
     * @param aEnv pointer to JNI environment
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   148
     * @param aName The name of a java.lang.Throwable class.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   149
     * @param aMsg The message used to construct the java.lang.Throwable object.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   150
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   151
    static void RaiseException(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   152
        JNIEnv* aEnv,
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   153
        const TDesC8& aName,
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   154
        const TUint8* aMsg = (STATIC_CAST(const TDesC8&, KM2GEmptyString8)).Ptr());
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   155
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   156
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   157
     * Instantiates an Java exception object specified by error code,
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   158
     * and causes that exception to be thrown in Java side.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   159
     * @param aEnv pointer to JNI environment
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   160
     * @param aErrorCode Error code.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   161
     * @return Value passed in is returned if not an error.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   162
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   163
    static TInt CheckErrorCode(JNIEnv* aEnv, TInt aErrorCode);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   164
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   165
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   166
     * If handle is invalid instantiates an Java exception object,
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   167
     * and causes that exception to be thrown in Java side.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   168
     * @param aEnv pointer to JNI environment
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   169
     * @param aHandle Handle.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   170
     * @return Handle passed in is returned if it is not invalid.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   171
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   172
    static TInt CheckHandle(JNIEnv* aEnv, TInt aHandle);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   173
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   174
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   175
     * If handle is invalid or error code matches instantiates an
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   176
     * Java exception object, and causes that exception to be thrown in Java side.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   177
     * @param aEnv pointer to JNI environment
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   178
     * @param aErrorCode
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   179
     * @param aHandle Handle.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   180
     * @param aErrorResult Result that is returned if error.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   181
     * @return Handle passed in is returned if no error otherwise the
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   182
     * .aErrorResult is returned.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   183
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   184
    static TInt CheckErrorCodeAndHandle(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   185
        JNIEnv* aEnv, TInt aErrorCode, TInt aHandle, TInt aErrorResult);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   186
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   187
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   188
     * Shows pop up dialog on the emulator
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   189
     * @since Series S60 3.1
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   190
     * @param aLine1
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   191
     * @param aLine2
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   192
    */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   193
#ifdef M2G_INFO_POPUP
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   194
    static void PopupInfo(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   195
        const TDesC& aLine1,
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   196
        const TDesC& aLine2);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   197
#endif // M2G_INFO_POPUP
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   198
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   199
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   200
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   201
    * Data array wrapper.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   202
    * @series Series S60 3.1
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   203
    */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   204
    template <typename T>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   205
    class TDataArrayPtr
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   206
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   207
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   208
    public: // METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   209
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   210
         * Ctor
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   211
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   212
        TDataArrayPtr(T* aData = 0, TInt aSize = 0) : iData(aData), iSize(aSize) {}
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   213
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   214
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   215
         * Return pointer to a data
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   216
         * @return Pointer
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   217
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   218
        inline T* Begin()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   219
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   220
            return iData;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   221
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   222
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   223
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   224
         * Check if data is valid
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   225
         * @return ETrue if ok
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   226
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   227
        inline TBool IsValid()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   228
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   229
            return (((iData != NULL) && (iSize > 0)) ? ETrue : EFalse);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   230
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   231
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   232
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   233
         * Return data size
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   234
         * @return Length
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   235
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   236
        inline TInt Length()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   237
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   238
            return iSize;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   239
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   240
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   241
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   242
         * Operator [] const
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   243
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   244
        inline const T& operator[](TInt aIndex) const
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   245
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   246
            return iData[ aIndex ];
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   247
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   248
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   249
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   250
         * Operator []
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   251
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   252
        inline T& operator[](TInt aIndex)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   253
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   254
            return iData[ aIndex ];
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   255
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   256
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   257
    private: // METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   258
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   259
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   260
         * Copy ctor
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   261
         * @param aRhs Right side array
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   262
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   263
        TDataArrayPtr(const TDataArrayPtr& aRhs);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   264
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   265
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   266
         * Assignment operator
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   267
         * @param aRhs Right side array
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   268
         * @return Array object
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   269
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   270
        TDataArrayPtr& operator=(const TDataArrayPtr& aRhs);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   271
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   272
    public: // VARIABLES
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   273
        T* iData;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   274
        TInt iSize;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   275
    };
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   276
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   277
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   278
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   279
     * Statistic info
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   280
     * @series Series S60 3.1
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   281
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   282
#ifdef M2G_STATISTIC_DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   283
    class TM2GStatistic
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   284
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   285
    public: // METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   286
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   287
         * Ctor
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   288
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   289
        TM2GStatistic();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   290
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   291
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   292
         * Reset
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   293
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   294
        void Reset();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   295
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   296
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   297
         * Print
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   298
         * @param aPrintElapsedTime Print also en elapsed time
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   299
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   300
        void Print(TBool aPrintElapsedTime = EFalse);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   301
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   302
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   303
         * Print
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   304
         * @param aStream
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   305
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   306
        void Print(RWriteStream& aStream);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   307
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   308
    public: // STATIC METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   309
        static void Log();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   310
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   311
    private: // METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   312
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   313
         * Copy ctor
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   314
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   315
        TM2GStatistic(const TM2GStatistic&);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   316
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   317
        /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   318
         * Assignment operator
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   319
         */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   320
        TM2GStatistic& operator=(const TM2GStatistic&);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   321
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   322
    private: // VARIABLES
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   323
        TTime iStartTime;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   324
        TTime iEndTime;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   325
        TThreadId iId;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   326
        TName iThreadName;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   327
    };
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   328
#endif // M2G_STATISTIC_DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   329
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   330
private: // METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   331
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   332
     * Default constructor
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   333
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   334
    M2GGeneral() {};
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   335
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   336
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   337
     * Copy constructor
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   338
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   339
    M2GGeneral(const M2GGeneral&);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   340
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   341
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   342
     * Assignment operator
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   343
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   344
    M2GGeneral& operator=(const M2GGeneral&);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   345
};
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   346
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   347
// MACROS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   348
// == TOOL MACROS ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   349
#define M2G_MIN( a, b ) ( ( a ) <= ( b ) ? ( a ) : ( b ) )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   350
#define M2G_MAX( a, b ) ( ( a ) >= ( b ) ? ( a ) : ( b ) )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   351
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   352
// == SWITCHES ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   353
#define M2G_NO_EXCEPTION_SWITCH
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   354
// #define M2G_NO_NULL_POINTER_EXCEPTION_SWITCH
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   355
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   356
#if defined( M2G_DEBUG )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   357
#define M2G_TRACE
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   358
#endif
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   359
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   360
// == EXCEPTION MACROS ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   361
// Common exception handling
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   362
#ifndef M2G_NO_EXCEPTION_SWITCH
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   363
#define M2G_THROW( ERR_CODE ) /**/ User::Leave( ( ERR_CODE ) )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   364
#define M2G_THROW2( ERR_TEXT, ERR_CODE ) /**/ M2G_DEBUG_0( ERR_TEXT ); User::Leave( ( ERR_CODE ) )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   365
#else
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   366
#define M2G_THROW( ERR_CODE ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   367
#define M2G_THROW2( ERR_TEXT, ERR_CODE ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   368
#endif // !M2G_NO_EXCEPTION_SWITCH
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   369
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   370
// Null pointer exception handling
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   371
#ifndef M2G_NO_NULL_POINTER_EXCEPTION_SWITCH
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   372
#define M2G_CHECK_NULL_POINTER( JNI, POINTER ) /**/ M2GGeneral::CheckHandle( ( JNI, POINTER ) )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   373
#else
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   374
#define M2G_CHECK_NULL_POINTER( JNI, POINTER ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   375
#endif // !M2G_NO_NULL_POINTER_EXCEPTION_SWITCH
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   376
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   377
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   378
// == STATIC LOG MACROS ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   379
#if defined( M2G_STATISTIC_DEBUG )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   380
#define M2G_STATISTIC_LOG /**/ M2GGeneral::TM2GStatistic::Log()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   381
#else // M2G_STATISTIC_DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   382
#define M2G_STATISTIC_LOG /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   383
#endif // !M2G_STATISTIC_DEBUG
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   384
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   385
// == POPUP MACROS ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   386
#if defined( M2G_INFO_POPUP )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   387
#define M2G_POPUP( LINE1, LINE2 ) /**/ M2GGeneral::PopupInfo( LINE1, LINE2 );
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   388
#else // !M2G_INFO_POPUP
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   389
#define M2G_POPUP( LINE1, LINE2 ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   390
#endif // M2G_INFO_POPUP
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   391
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   392
// == TRACE MACROS ==
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   393
#if defined( M2G_TRACE )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   394
#define M2G_DEBUG_0( TEXT ) /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   395
        RFileLogger::Write( KLogDirectory, KLogFileName, EFileLoggingModeAppend, _L( TEXT ) )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   396
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   397
#define M2G_DEBUG_1( TEXT, VAL1 ) /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   398
        RFileLogger::WriteFormat( KLogDirectory, KLogFileName, EFileLoggingModeAppend, /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   399
        _L( TEXT ), VAL1 )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   400
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   401
#define M2G_DEBUG_2( TEXT, VAL1, VAL2 ) /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   402
        RFileLogger::WriteFormat( KLogDirectory, KLogFileName, EFileLoggingModeAppend, /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   403
        _L( TEXT ), VAL1, VAL2 )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   404
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   405
#define M2G_DEBUG_3( TEXT, VAL1, VAL2, VAL3 ) /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   406
        RFileLogger::WriteFormat( KLogDirectory, KLogFileName, EFileLoggingModeAppend, /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   407
        _L( TEXT ), VAL1, VAL2, VAL3 )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   408
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   409
#define M2G_DEBUG_4( TEXT, VAL1, VAL2, VAL3, VAL4 ) /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   410
        RFileLogger::WriteFormat( KLogDirectory, KLogFileName, EFileLoggingModeAppend, /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   411
        _L( TEXT ), VAL1, VAL2, VAL3, VAL4 )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   412
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   413
#define M2G_DEBUG_5( TEXT, VAL1, VAL2, VAL3, VAL4, VAL5 ) /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   414
        RFileLogger::WriteFormat( KLogDirectory, KLogFileName, EFileLoggingModeAppend, /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   415
        _L( TEXT ), VAL1, VAL2, VAL3, VAL4, VAL5 )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   416
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   417
#define M2G_DEBUG_6( TEXT, VAL1, VAL2, VAL3, VAL4, VAL5, VAL6 ) /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   418
        RFileLogger::WriteFormat( KLogDirectory, KLogFileName, EFileLoggingModeAppend, /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   419
        _L( TEXT ), VAL1, VAL2, VAL3, VAL4, VAL5, VAL6 )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   420
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   421
#define M2G_DEBUG_7( TEXT, VAL1, VAL2, VAL3, VAL4, VAL5, VAL6, VAL7 ) /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   422
        RFileLogger::WriteFormat( KLogDirectory, KLogFileName, EFileLoggingModeAppend, /**/ \
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   423
        _L( TEXT ), VAL1, VAL2, VAL3, VAL4, VAL5, VAL6, VAL7 )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   424
#else // !M2G_TRACE
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   425
#define M2G_POPUP( LINE1, LINE2 ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   426
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   427
#define M2G_DEBUG_0( TEXT ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   428
#define M2G_DEBUG_1( TEXT, VAL1 ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   429
#define M2G_DEBUG_2( TEXT, VAL1, VAL2 ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   430
#define M2G_DEBUG_3( TEXT, VAL1, VAL2, VAL3 ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   431
#define M2G_DEBUG_4( TEXT, VAL1, VAL2, VAL3, VAL4 ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   432
#define M2G_DEBUG_5( TEXT, VAL1, VAL2, VAL3, VAL4, VAL5 ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   433
#define M2G_DEBUG_6( TEXT, VAL1, VAL2, VAL3, VAL4, VAL5, VAL6 ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   434
#define M2G_DEBUG_7( TEXT, VAL1, VAL2, VAL3, VAL4, VAL5, VAL6, VAL7 ) /**/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   435
#endif // M2G_TRACE
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   436
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   437
// DATA TYPES
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   438
typedef TInt TM2GSvgEngineHandle;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   439
typedef TInt TM2GSvgDocumentHandle;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   440
typedef TInt TM2GSvgElementHandle;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   441
typedef TInt TM2GBitmapHandle;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   442
typedef TInt TM2GSvgPathHandle;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   443
typedef TInt16 TM2GSvgAttrType;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   444
typedef TUint8 TM2GPixelComponent;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   445
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   446
//For Qimage related changes
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   447
typedef TUint TM2GSvgBitmapHandle;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   448
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   449
typedef TFixedArray<TInt, 3> TM2GColorData;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   450
typedef TFixedArray<TReal32, 6> TM2GMatrixData;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   451
typedef M2GGeneral::TDataArrayPtr<TReal32> TM2GMatrixData2;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   452
typedef TFixedArray<TReal32, 4> TM2GRectData;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   453
typedef TFixedArray<TReal32, 4> TM2GScreenBBoxData;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   454
typedef TFixedArray<TReal32, 6> TM2GPathCurveData;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   455
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   456
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   457
M2G_NS_END
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   458
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   459
//#if defined( __cplusplus )
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   460
//} // extern "C"
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   461
//#endif
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   462
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   463
#endif // M2GGENERAL_H