gssettingsuis/Gs/GSFramework/src/GSBaseDocument.cpp
author hgs
Thu, 04 Nov 2010 13:38:47 +0800
changeset 68 13e71d907dc3
permissions -rw-r--r--
201044
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
68
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2005 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:  Base Document for the General Settings Application
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#include "GSBaseDocument.h"
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
// User includes
hgs
parents:
diff changeset
    21
#include "GSPluginWrapper.h"
hgs
parents:
diff changeset
    22
#include "GSPluginAndViewIdCache.h"
hgs
parents:
diff changeset
    23
#include "GSWatchDog.h"
hgs
parents:
diff changeset
    24
#include "gsplugininterface.h"
hgs
parents:
diff changeset
    25
#include "GsLogger.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
// Constants
hgs
parents:
diff changeset
    28
const TInt KGSPluginWrapperObjectGranularity = 10;
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
// ================= MEMBER FUNCTIONS =======================
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
// ----------------------------------------------------
hgs
parents:
diff changeset
    34
// CGSBaseDocument::CGSBaseDocument()
hgs
parents:
diff changeset
    35
// constructor
hgs
parents:
diff changeset
    36
//
hgs
parents:
diff changeset
    37
// ----------------------------------------------------
hgs
parents:
diff changeset
    38
//
hgs
parents:
diff changeset
    39
EXPORT_C CGSBaseDocument::CGSBaseDocument( CEikApplication& aApp )
hgs
parents:
diff changeset
    40
:   CAknDocument( aApp ),
hgs
parents:
diff changeset
    41
    iUnloadWrapperObjects( KGSPluginWrapperObjectGranularity ),
hgs
parents:
diff changeset
    42
    iWatchDog ( NULL )
hgs
parents:
diff changeset
    43
    {
hgs
parents:
diff changeset
    44
    }
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
// ----------------------------------------------------
hgs
parents:
diff changeset
    48
// CGSBaseDocument::~CGSBaseDocument()
hgs
parents:
diff changeset
    49
// destructor
hgs
parents:
diff changeset
    50
//
hgs
parents:
diff changeset
    51
// ----------------------------------------------------
hgs
parents:
diff changeset
    52
//
hgs
parents:
diff changeset
    53
EXPORT_C CGSBaseDocument::~CGSBaseDocument()
hgs
parents:
diff changeset
    54
    {
hgs
parents:
diff changeset
    55
    // This physically unloads the plugin dlls if their ECOM
hgs
parents:
diff changeset
    56
    // reference count is zero. This must be the last thing to
hgs
parents:
diff changeset
    57
    // occur to any plugin object (i.e. all of its code must have
hgs
parents:
diff changeset
    58
    // finished running by the time this next line takes place).
hgs
parents:
diff changeset
    59
    const TInt count = iUnloadWrapperObjects.Count();
hgs
parents:
diff changeset
    60
    for( TInt i=count-1; i>=0; i-- )
hgs
parents:
diff changeset
    61
        {
hgs
parents:
diff changeset
    62
        CGSPluginWrapper* object = iUnloadWrapperObjects[ i ];
hgs
parents:
diff changeset
    63
        (void) object;
hgs
parents:
diff changeset
    64
        delete object;
hgs
parents:
diff changeset
    65
        }
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
    iUnloadWrapperObjects.Close();
hgs
parents:
diff changeset
    68
    delete iPluginViewIdCache;
hgs
parents:
diff changeset
    69
#ifdef GS_ENABLE_WATCH_DOG
hgs
parents:
diff changeset
    70
    delete iWatchDog;
hgs
parents:
diff changeset
    71
#endif
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
    iImplInfoArray.ResetAndDestroy();// This is needed
hgs
parents:
diff changeset
    74
    iImplInfoArray.Close();
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
// CGSBaseDocument::ConstructL()
hgs
parents:
diff changeset
    80
// Symbian OS second phase constructor
hgs
parents:
diff changeset
    81
//
hgs
parents:
diff changeset
    82
// ----------------------------------------------------
hgs
parents:
diff changeset
    83
//
hgs
parents:
diff changeset
    84
EXPORT_C void CGSBaseDocument::ConstructL()
hgs
parents:
diff changeset
    85
    {
hgs
parents:
diff changeset
    86
#ifdef GS_ENABLE_WATCH_DOG
hgs
parents:
diff changeset
    87
    iWatchDog = CGSWatchDog::NewL();
hgs
parents:
diff changeset
    88
#endif
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
    REComSession::ListImplementationsL(
hgs
parents:
diff changeset
    91
        KGSPluginInterfaceUid,
hgs
parents:
diff changeset
    92
        iImplInfoArray );
hgs
parents:
diff changeset
    93
#ifdef _DEBUG
hgs
parents:
diff changeset
    94
    PrintImplInfoArray( iImplInfoArray );
hgs
parents:
diff changeset
    95
#endif //_DEBUG
hgs
parents:
diff changeset
    96
        
hgs
parents:
diff changeset
    97
    __GSLOGSTRING1(
hgs
parents:
diff changeset
    98
        "[CGSBaseDocument::ConstructL] iImplInfoArray count:%d",
hgs
parents:
diff changeset
    99
        iImplInfoArray.Count() );
hgs
parents:
diff changeset
   100
    }
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
// ----------------------------------------------------
hgs
parents:
diff changeset
   104
// CGSBaseDocument::NewPluginUnloadWrapperLC()
hgs
parents:
diff changeset
   105
//
hgs
parents:
diff changeset
   106
//
hgs
parents:
diff changeset
   107
// ----------------------------------------------------
hgs
parents:
diff changeset
   108
//
hgs
parents:
diff changeset
   109
EXPORT_C CGSPluginWrapper* CGSBaseDocument::NewPluginUnloadWrapperLC()
hgs
parents:
diff changeset
   110
    {
hgs
parents:
diff changeset
   111
    CGSPluginWrapper* wrapper = new(ELeave) CGSPluginWrapper( *this );
hgs
parents:
diff changeset
   112
    TCleanupItem wrapperCleanupItem( CleanupPluginWrapperObject, wrapper );
hgs
parents:
diff changeset
   113
    CleanupStack::PushL( wrapperCleanupItem );
hgs
parents:
diff changeset
   114
    iUnloadWrapperObjects.AppendL( wrapper );
hgs
parents:
diff changeset
   115
    //
hgs
parents:
diff changeset
   116
    return wrapper;
hgs
parents:
diff changeset
   117
    }
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
// ----------------------------------------------------
hgs
parents:
diff changeset
   121
// CGSBaseDocument::PreparePluginCacheL()
hgs
parents:
diff changeset
   122
//
hgs
parents:
diff changeset
   123
//
hgs
parents:
diff changeset
   124
// ----------------------------------------------------
hgs
parents:
diff changeset
   125
//
hgs
parents:
diff changeset
   126
EXPORT_C void CGSBaseDocument::PreparePluginCacheL( CEikAppUi& aAppUi )
hgs
parents:
diff changeset
   127
    {
hgs
parents:
diff changeset
   128
    iPluginViewIdCache = CGSPluginAndViewIdCache::NewL( aAppUi );
hgs
parents:
diff changeset
   129
    }
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
// ----------------------------------------------------
hgs
parents:
diff changeset
   133
// CGSBaseDocument::PrepareForUIDestruction()
hgs
parents:
diff changeset
   134
//
hgs
parents:
diff changeset
   135
//
hgs
parents:
diff changeset
   136
// ----------------------------------------------------
hgs
parents:
diff changeset
   137
//
hgs
parents:
diff changeset
   138
EXPORT_C void CGSBaseDocument::PrepareForUIDestruction()
hgs
parents:
diff changeset
   139
    {
hgs
parents:
diff changeset
   140
    if  ( iPluginViewIdCache )
hgs
parents:
diff changeset
   141
        {
hgs
parents:
diff changeset
   142
        iPluginViewIdCache->PrepareForUIDestruction();
hgs
parents:
diff changeset
   143
        }
hgs
parents:
diff changeset
   144
    }
hgs
parents:
diff changeset
   145
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
// ----------------------------------------------------
hgs
parents:
diff changeset
   148
// CGSBaseDocument::CleanupPluginWrapperObject()
hgs
parents:
diff changeset
   149
// Cleanup support
hgs
parents:
diff changeset
   150
//
hgs
parents:
diff changeset
   151
// ----------------------------------------------------
hgs
parents:
diff changeset
   152
//
hgs
parents:
diff changeset
   153
void CGSBaseDocument::CleanupPluginWrapperObject( TAny* aWrapper )
hgs
parents:
diff changeset
   154
    {
hgs
parents:
diff changeset
   155
    CGSPluginWrapper* wrapper =
hgs
parents:
diff changeset
   156
        reinterpret_cast< CGSPluginWrapper* >( aWrapper );
hgs
parents:
diff changeset
   157
    CGSBaseDocument& document = wrapper->Document();
hgs
parents:
diff changeset
   158
    document.DoCleanupPluginWrapper( wrapper );
hgs
parents:
diff changeset
   159
    }
hgs
parents:
diff changeset
   160
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
// ----------------------------------------------------
hgs
parents:
diff changeset
   163
// CGSBaseDocument::DoCleanupPluginWrapper()
hgs
parents:
diff changeset
   164
// Cleanup support - called when loading a plugin fails
hgs
parents:
diff changeset
   165
//
hgs
parents:
diff changeset
   166
// ----------------------------------------------------
hgs
parents:
diff changeset
   167
//
hgs
parents:
diff changeset
   168
void CGSBaseDocument::DoCleanupPluginWrapper( CGSPluginWrapper* aWrapper )
hgs
parents:
diff changeset
   169
    {
hgs
parents:
diff changeset
   170
    const TInt index = iUnloadWrapperObjects.Find( aWrapper );
hgs
parents:
diff changeset
   171
    if  ( index >= 0 && index < iUnloadWrapperObjects.Count() )
hgs
parents:
diff changeset
   172
        {
hgs
parents:
diff changeset
   173
        iUnloadWrapperObjects.Remove( index );
hgs
parents:
diff changeset
   174
        delete aWrapper;
hgs
parents:
diff changeset
   175
        }
hgs
parents:
diff changeset
   176
    }
hgs
parents:
diff changeset
   177
hgs
parents:
diff changeset
   178
hgs
parents:
diff changeset
   179
// ----------------------------------------------------
hgs
parents:
diff changeset
   180
// CGSBaseDocument::PluginViewIdCache()
hgs
parents:
diff changeset
   181
//
hgs
parents:
diff changeset
   182
//
hgs
parents:
diff changeset
   183
// ----------------------------------------------------
hgs
parents:
diff changeset
   184
//
hgs
parents:
diff changeset
   185
CGSPluginAndViewIdCache& CGSBaseDocument::PluginViewIdCache()
hgs
parents:
diff changeset
   186
    {
hgs
parents:
diff changeset
   187
    ASSERT( iPluginViewIdCache );
hgs
parents:
diff changeset
   188
    return *iPluginViewIdCache;
hgs
parents:
diff changeset
   189
    }
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
// ----------------------------------------------------
hgs
parents:
diff changeset
   193
// CGSBaseDocument::PluginViewIdCache()
hgs
parents:
diff changeset
   194
//
hgs
parents:
diff changeset
   195
//
hgs
parents:
diff changeset
   196
// ----------------------------------------------------
hgs
parents:
diff changeset
   197
//
hgs
parents:
diff changeset
   198
const CGSPluginAndViewIdCache& CGSBaseDocument::PluginViewIdCache() const
hgs
parents:
diff changeset
   199
    {
hgs
parents:
diff changeset
   200
    ASSERT( iPluginViewIdCache );
hgs
parents:
diff changeset
   201
    return *iPluginViewIdCache;
hgs
parents:
diff changeset
   202
    }
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
hgs
parents:
diff changeset
   206
// ----------------------------------------------------
hgs
parents:
diff changeset
   207
// CGSBaseDocument::WatchDog()
hgs
parents:
diff changeset
   208
//
hgs
parents:
diff changeset
   209
//
hgs
parents:
diff changeset
   210
// ----------------------------------------------------
hgs
parents:
diff changeset
   211
//
hgs
parents:
diff changeset
   212
EXPORT_C MGSWatchDog* CGSBaseDocument::WatchDog()
hgs
parents:
diff changeset
   213
    {
hgs
parents:
diff changeset
   214
    return iWatchDog;
hgs
parents:
diff changeset
   215
    }
hgs
parents:
diff changeset
   216
hgs
parents:
diff changeset
   217
// ----------------------------------------------------
hgs
parents:
diff changeset
   218
// CGSBaseDocument::GetImplInfos()
hgs
parents:
diff changeset
   219
//
hgs
parents:
diff changeset
   220
//
hgs
parents:
diff changeset
   221
// ----------------------------------------------------
hgs
parents:
diff changeset
   222
//
hgs
parents:
diff changeset
   223
EXPORT_C RImplInfoPtrArray CGSBaseDocument::GetImplInfo()
hgs
parents:
diff changeset
   224
    {
hgs
parents:
diff changeset
   225
    return iImplInfoArray;
hgs
parents:
diff changeset
   226
    }
hgs
parents:
diff changeset
   227
hgs
parents:
diff changeset
   228
EXPORT_C void CGSBaseDocument::CreateShimmedViewL(const TUid aViewUid)
hgs
parents:
diff changeset
   229
	{
hgs
parents:
diff changeset
   230
	ASSERT(iPluginViewIdCache);
hgs
parents:
diff changeset
   231
	if ( !iPluginViewIdCache->PluginInstance(aViewUid) )
hgs
parents:
diff changeset
   232
		{
hgs
parents:
diff changeset
   233
		iPluginViewIdCache->RegisterViewAndImplementationAssociationL(aViewUid, aViewUid, ETrue);
hgs
parents:
diff changeset
   234
		}
hgs
parents:
diff changeset
   235
	}
hgs
parents:
diff changeset
   236
hgs
parents:
diff changeset
   237
void CGSBaseDocument::PrintImplInfoArray( const RImplInfoPtrArray& aImplInfoArray )
hgs
parents:
diff changeset
   238
    {
hgs
parents:
diff changeset
   239
    for( TInt i = 0; i < aImplInfoArray.Count(); i++ )
hgs
parents:
diff changeset
   240
        {
hgs
parents:
diff changeset
   241
        PrintImplInfo( *aImplInfoArray[ i ] );
hgs
parents:
diff changeset
   242
        }
hgs
parents:
diff changeset
   243
    }
hgs
parents:
diff changeset
   244
hgs
parents:
diff changeset
   245
hgs
parents:
diff changeset
   246
void CGSBaseDocument::PrintImplInfo( const CImplementationInformation& aInfo )
hgs
parents:
diff changeset
   247
    {
hgs
parents:
diff changeset
   248
    __GSLOGSTRING1( "[CGSBaseDocument] --Plugin 0x%X info--", &aInfo);
hgs
parents:
diff changeset
   249
    __GSLOGSTRING1( "[CGSBaseDocument] DisplayName:%S", &aInfo.DisplayName() );
hgs
parents:
diff changeset
   250
    __GSLOGSTRING1( "[CGSBaseDocument] ImplementationUid:0x%X",
hgs
parents:
diff changeset
   251
                    aInfo.ImplementationUid() );
hgs
parents:
diff changeset
   252
hgs
parents:
diff changeset
   253
    const TInt KMaxEComDataLength = 256;
hgs
parents:
diff changeset
   254
hgs
parents:
diff changeset
   255
    HBufC* dataType = HBufC::New( KMaxEComDataLength );
hgs
parents:
diff changeset
   256
    HBufC* opaqueData = HBufC::New( KMaxEComDataLength );
hgs
parents:
diff changeset
   257
hgs
parents:
diff changeset
   258
    dataType->Des().Copy( aInfo.DataType() );
hgs
parents:
diff changeset
   259
    opaqueData->Des().Copy( aInfo.OpaqueData() );
hgs
parents:
diff changeset
   260
    __GSLOGSTRING1( "[CGSBaseDocument] DataType:%S", dataType );
hgs
parents:
diff changeset
   261
    __GSLOGSTRING1( "[CGSBaseDocument] OpaqueData:%S", opaqueData );
hgs
parents:
diff changeset
   262
hgs
parents:
diff changeset
   263
    delete opaqueData;
hgs
parents:
diff changeset
   264
    delete dataType;
hgs
parents:
diff changeset
   265
    }
hgs
parents:
diff changeset
   266
hgs
parents:
diff changeset
   267
hgs
parents:
diff changeset
   268
hgs
parents:
diff changeset
   269
// End of File