imservices/imfeatureplugin/srcimdatamodel/imapidataobjfactory.inl
author hgs
Wed, 03 Nov 2010 22:25:05 +0530
changeset 52 3d676fce9a4e
parent 51 61fad867f68e
permissions -rw-r--r--
201044_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
51
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2007 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:  Inline methods for codec to pack and unpack data objects.
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
#include <e32base.h>
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include "imtypehelpers.h"
hgs
parents:
diff changeset
    22
#include "imobjectfactory.h"
hgs
parents:
diff changeset
    23
#include "ximpapidataobjbase.h"
hgs
parents:
diff changeset
    24
#include "imconversationinfoimp.h"
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
//DATA TYPES
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
// ============================ MEMBER FUNCTIONS =============================
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
/**
hgs
parents:
diff changeset
    33
 * Type definition for exact API data object constructor signature.
hgs
parents:
diff changeset
    34
 */
hgs
parents:
diff changeset
    35
typedef CXIMPApiDataObjBase* (*TApiDataObjConstructor)( RReadStream& );
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
/**
hgs
parents:
diff changeset
    40
 * Structure for mapping data object interface IDs to
hgs
parents:
diff changeset
    41
 * to corect API data object constructors.
hgs
parents:
diff changeset
    42
 */
hgs
parents:
diff changeset
    43
struct SApiDataObjConstructorMap
hgs
parents:
diff changeset
    44
    {
hgs
parents:
diff changeset
    45
    //Interface id
hgs
parents:
diff changeset
    46
    TInt32    iInterfaceId;
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
    //Function pointer to data object interface implementation
hgs
parents:
diff changeset
    49
    TApiDataObjConstructor iConstructorPtr;
hgs
parents:
diff changeset
    50
    } ;
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
/**
hgs
parents:
diff changeset
    55
 * Helper macro to initialise KApiDataObjConstructorTable members.
hgs
parents:
diff changeset
    56
 *
hgs
parents:
diff changeset
    57
 * Macro forces that each data object implementation class to have static
hgs
parents:
diff changeset
    58
 * NewFromStreamLC() member function to instantiate the object.
hgs
parents:
diff changeset
    59
 *
hgs
parents:
diff changeset
    60
 * See TApiDataObjConstructor type definition for exact constructor
hgs
parents:
diff changeset
    61
 * signature.
hgs
parents:
diff changeset
    62
 */
hgs
parents:
diff changeset
    63
#define CONSTRUCTOR_ENTRY( TheImplementedIf, TheClass ) \
hgs
parents:
diff changeset
    64
    { TheImplementedIf::KInterfaceId, TheClass::NewFromStreamLC } \
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
/**
hgs
parents:
diff changeset
    67
 * Constructor function mapping for data object interface implementations.
hgs
parents:
diff changeset
    68
 *
hgs
parents:
diff changeset
    69
 * When new data object types are implemented, add them here.
hgs
parents:
diff changeset
    70
 */
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
const SApiDataObjConstructorMap KApiDataObjConstructorTable[] =
hgs
parents:
diff changeset
    73
    {
hgs
parents:
diff changeset
    74
    CONSTRUCTOR_ENTRY( MImConversationInfo, CImConversationInfoImp ),
hgs
parents:
diff changeset
    75
    };
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
/**
hgs
parents:
diff changeset
    79
 * Count of constructor mappings.
hgs
parents:
diff changeset
    80
 */
hgs
parents:
diff changeset
    81
const TInt KApiDataObjConstructorCount 	= sizeof( KApiDataObjConstructorTable )
hgs
parents:
diff changeset
    82
                                       / sizeof( SApiDataObjConstructorMap );
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
// ============================ HELPER FUNCTIONS =============================
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
hgs
parents:
diff changeset
    89
namespace {
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
    /**
hgs
parents:
diff changeset
    92
     * Helper function to locate constructor function for
hgs
parents:
diff changeset
    93
     * data object interface ID.
hgs
parents:
diff changeset
    94
     *
hgs
parents:
diff changeset
    95
     * @param aDataObjInterfaceId The data object interface ID.
hgs
parents:
diff changeset
    96
     * @return Data object constructor function.
hgs
parents:
diff changeset
    97
     */
hgs
parents:
diff changeset
    98
    TApiDataObjConstructor ConstructorForInterface( TInt32 aDataObjInterfaceId )
hgs
parents:
diff changeset
    99
    {
hgs
parents:
diff changeset
   100
        //Locate correct constructor
hgs
parents:
diff changeset
   101
        for( TInt ix = 0; ix < KApiDataObjConstructorCount; ix++ )
hgs
parents:
diff changeset
   102
        {
hgs
parents:
diff changeset
   103
           const SApiDataObjConstructorMap map = KApiDataObjConstructorTable[ ix ];
hgs
parents:
diff changeset
   104
            if( map.iInterfaceId == aDataObjInterfaceId )
hgs
parents:
diff changeset
   105
            {
hgs
parents:
diff changeset
   106
                return map.iConstructorPtr;
hgs
parents:
diff changeset
   107
            } 
hgs
parents:
diff changeset
   108
        }
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
        //If assertion below fails, check that data object implementation
hgs
parents:
diff changeset
   112
        //class implementing requested data object interface (aDataObjInterfaceId)
hgs
parents:
diff changeset
   113
        //is registered to KApiDataObjConstructorTable
hgs
parents:
diff changeset
   114
        __ASSERT_DEBUG( EFalse,
hgs
parents:
diff changeset
   115
                User::Panic( _L("ImObjectFactory"), KErrUnknown ) );
hgs
parents:
diff changeset
   116
hgs
parents:
diff changeset
   117
        return NULL;
hgs
parents:
diff changeset
   118
    }
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
    /**
hgs
parents:
diff changeset
   121
     * Helper function to instantiate new data object object
hgs
parents:
diff changeset
   122
     * of requested type and construct it from the stream.
hgs
parents:
diff changeset
   123
     *
hgs
parents:
diff changeset
   124
     * @param aDataObjInterfaceId
hgs
parents:
diff changeset
   125
     * @return Data object constructor function.
hgs
parents:
diff changeset
   126
     */
hgs
parents:
diff changeset
   127
    CXIMPApiDataObjBase* NewDataObjectFromStreamLC( TInt32 aDataObjInterfaceId,
hgs
parents:
diff changeset
   128
            RReadStream& aStream )
hgs
parents:
diff changeset
   129
    {
hgs
parents:
diff changeset
   130
        TApiDataObjConstructor newFromStreamLC = NULL;
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
        //Locate correct constructor for interface ID
hgs
parents:
diff changeset
   133
        newFromStreamLC = ConstructorForInterface( aDataObjInterfaceId );
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
        //Instantiate the object
hgs
parents:
diff changeset
   136
        CXIMPApiDataObjBase* dataObject = newFromStreamLC( aStream );
hgs
parents:
diff changeset
   137
hgs
parents:
diff changeset
   138
        return dataObject;
hgs
parents:
diff changeset
   139
    }
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
} // namespace
hgs
parents:
diff changeset
   142
hgs
parents:
diff changeset
   143
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   144
// ImApiDataObjFactory::InternalizeL
hgs
parents:
diff changeset
   145
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   146
//
hgs
parents:
diff changeset
   147
template< class INFOIMP >
hgs
parents:
diff changeset
   148
inline void CImApiDataObjFactory::InternalizeL( 
hgs
parents:
diff changeset
   149
        RReadStream& aStream,
hgs
parents:
diff changeset
   150
        RPointerArray<INFOIMP>& aArray )
hgs
parents:
diff changeset
   151
    {
hgs
parents:
diff changeset
   152
    TInt32 arrLen = aStream.ReadInt32L();
hgs
parents:
diff changeset
   153
hgs
parents:
diff changeset
   154
    for ( TInt i = 0; i < arrLen; i++ )
hgs
parents:
diff changeset
   155
        {
hgs
parents:
diff changeset
   156
        TInt paramType = aStream.ReadInt32L();
hgs
parents:
diff changeset
   157
        INFOIMP* infoObj = ( INFOIMP* ) NewDataObjectFromStreamLC( paramType, aStream );
hgs
parents:
diff changeset
   158
        aArray.AppendL( infoObj );
hgs
parents:
diff changeset
   159
        CleanupStack::Pop( infoObj );
hgs
parents:
diff changeset
   160
        }
hgs
parents:
diff changeset
   161
    }
hgs
parents:
diff changeset
   162
hgs
parents:
diff changeset
   163
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   164
// ImApiDataObjFactory::ExternalizeL
hgs
parents:
diff changeset
   165
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   166
//
hgs
parents:
diff changeset
   167
template <class INFOIMP>
hgs
parents:
diff changeset
   168
inline void CImApiDataObjFactory::ExternalizeL( 
hgs
parents:
diff changeset
   169
        RWriteStream& aWs,
hgs
parents:
diff changeset
   170
        const RPointerArray<INFOIMP>& aArray )
hgs
parents:
diff changeset
   171
    {
hgs
parents:
diff changeset
   172
    aWs.WriteInt32L( aArray.Count() ); // array length
hgs
parents:
diff changeset
   173
hgs
parents:
diff changeset
   174
    for ( TInt i = 0; i < aArray.Count(); i++ )
hgs
parents:
diff changeset
   175
        {
hgs
parents:
diff changeset
   176
        INFOIMP* infoField = aArray[ i ];
hgs
parents:
diff changeset
   177
hgs
parents:
diff changeset
   178
        // write the type
hgs
parents:
diff changeset
   179
        aWs.WriteInt32L( infoField->Base().GetInterfaceId() );
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
        // write the actual object
hgs
parents:
diff changeset
   182
        infoField->ExternalizeL( aWs );
hgs
parents:
diff changeset
   183
        }
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
    aWs.CommitL();
hgs
parents:
diff changeset
   186
    }
hgs
parents:
diff changeset
   187