mds_plat/harvester_framework_api/tsrc/HarvesterPluginTest/src/HarvesterPluginTestBlocks.cpp
author hgs
Wed, 06 Oct 2010 15:08:08 +0300
changeset 60 79f826a55db2
permissions -rw-r--r--
201039
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
60
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002 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:  
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 FILES] - do not remove
hgs
parents:
diff changeset
    20
#include <e32svr.h>
hgs
parents:
diff changeset
    21
#include <StifParser.h>
hgs
parents:
diff changeset
    22
#include <StifTestEventInterface.h>
hgs
parents:
diff changeset
    23
#include <StifTestInterface.h>
hgs
parents:
diff changeset
    24
#include "HarvesterPluginTest.h"
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
#include "mdsutils.h"
hgs
parents:
diff changeset
    27
#include "harvesterblacklist.h"
hgs
parents:
diff changeset
    28
#include "mdeobject.h"
hgs
parents:
diff changeset
    29
#include "mdeobjecthandler.h"
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
// ============================ MEMBER FUNCTIONS ===============================
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    35
// CHarvesterPluginTest::Delete
hgs
parents:
diff changeset
    36
// Delete here all resources allocated and opened from test methods. 
hgs
parents:
diff changeset
    37
// Called from destructor. 
hgs
parents:
diff changeset
    38
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    39
//
hgs
parents:
diff changeset
    40
void CHarvesterPluginTest::Delete() 
hgs
parents:
diff changeset
    41
    {
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
    }
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    46
// CHarvesterPluginTest::RunMethodL
hgs
parents:
diff changeset
    47
// Run specified method. Contains also table of test mothods and their names.
hgs
parents:
diff changeset
    48
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    49
//
hgs
parents:
diff changeset
    50
TInt CHarvesterPluginTest::RunMethodL( 
hgs
parents:
diff changeset
    51
    CStifItemParser& aItem ) 
hgs
parents:
diff changeset
    52
    {
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
    static TStifFunctionInfo const KFunctions[] =
hgs
parents:
diff changeset
    55
        {  
hgs
parents:
diff changeset
    56
        // Copy this line for every implemented function.
hgs
parents:
diff changeset
    57
        // First string is the function name used in TestScripter script file.
hgs
parents:
diff changeset
    58
        // Second is the actual implementation member function. 
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
        ENTRY( "BeginTestSession", CHarvesterPluginTest::BeginTestSessionL ),
hgs
parents:
diff changeset
    61
        ENTRY( "EndTestSession", CHarvesterPluginTest::EndTestSession ),
hgs
parents:
diff changeset
    62
        ENTRY( "LoadPlugins", CHarvesterPluginTest::LoadPluginsL ),
hgs
parents:
diff changeset
    63
        ENTRY( "TestFunctions", CHarvesterPluginTest::TestFunctionsL ),
hgs
parents:
diff changeset
    64
        		
hgs
parents:
diff changeset
    65
        };
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
    const TInt count = sizeof( KFunctions ) / 
hgs
parents:
diff changeset
    68
                        sizeof( TStifFunctionInfo );
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
    return RunInternalL( KFunctions, count, aItem );
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
    }
hgs
parents:
diff changeset
    73
hgs
parents:
diff changeset
    74
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    75
// CHarvesterPluginTest::HandleSessionOpened
hgs
parents:
diff changeset
    76
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    77
//
hgs
parents:
diff changeset
    78
void CHarvesterPluginTest::HandleSessionOpened( CMdESession& /*aClient*/, TInt aError )
hgs
parents:
diff changeset
    79
    {
hgs
parents:
diff changeset
    80
    _LIT( KMsg, "CallBck HandleSessionOpened - Error code : %d" );
hgs
parents:
diff changeset
    81
    TBuf <100> msg;
hgs
parents:
diff changeset
    82
    msg.Format(KMsg, aError);
hgs
parents:
diff changeset
    83
    iLog->Log( msg );     
hgs
parents:
diff changeset
    84
    RDebug::Print(msg);
hgs
parents:
diff changeset
    85
    
hgs
parents:
diff changeset
    86
    TRAP_IGNORE( iMdeObjectHandler = CMdeObjectHandler::NewL( *iMdeSession ) );
hgs
parents:
diff changeset
    87
    
hgs
parents:
diff changeset
    88
    // session event
hgs
parents:
diff changeset
    89
    TEventIf event( TEventIf::ESetEvent, _L("Session") );
hgs
parents:
diff changeset
    90
    TestModuleIf().Event( event );
hgs
parents:
diff changeset
    91
    }
hgs
parents:
diff changeset
    92
hgs
parents:
diff changeset
    93
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    94
// CHarvesterPluginTest::HandleSessionError
hgs
parents:
diff changeset
    95
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    96
//
hgs
parents:
diff changeset
    97
void CHarvesterPluginTest::HandleSessionError( CMdESession& /*aClient*/, TInt aError )
hgs
parents:
diff changeset
    98
    {
hgs
parents:
diff changeset
    99
    _LIT( KMsg, "CallBck HandleSessionError - Error code : %d" );
hgs
parents:
diff changeset
   100
    TBuf <100> msg;
hgs
parents:
diff changeset
   101
    msg.Format(KMsg, aError);
hgs
parents:
diff changeset
   102
    iLog->Log( msg );
hgs
parents:
diff changeset
   103
    RDebug::Print(msg);
hgs
parents:
diff changeset
   104
    
hgs
parents:
diff changeset
   105
    // session event
hgs
parents:
diff changeset
   106
    TEventIf event( TEventIf::ESetEvent, _L("Session") );
hgs
parents:
diff changeset
   107
    TestModuleIf().Event( event );
hgs
parents:
diff changeset
   108
    }
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   111
// CHarvesterPluginTest::HarvestingCompleted
hgs
parents:
diff changeset
   112
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   113
//
hgs
parents:
diff changeset
   114
void CHarvesterPluginTest::HarvestingCompleted( CHarvesterData* /* aHarvesterData */ )
hgs
parents:
diff changeset
   115
	{ 
hgs
parents:
diff changeset
   116
    // harvest event
hgs
parents:
diff changeset
   117
    TEventIf event( TEventIf::ESetEvent, _L("Harvest") );
hgs
parents:
diff changeset
   118
    TestModuleIf().Event( event );
hgs
parents:
diff changeset
   119
	}
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   122
// CHarvesterPluginTest::BeginTestSessionL
hgs
parents:
diff changeset
   123
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   124
//
hgs
parents:
diff changeset
   125
TInt CHarvesterPluginTest::BeginTestSessionL( CStifItemParser& /* aItem */ )
hgs
parents:
diff changeset
   126
    {
hgs
parents:
diff changeset
   127
    TRAPD( error, iMdeSession = CMdESession::NewL( *this ) );
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
    iSession = CMdEHarvesterSession::NewL( *iMdeSession );
hgs
parents:
diff changeset
   130
    
hgs
parents:
diff changeset
   131
    iCtxEngine = NULL;
hgs
parents:
diff changeset
   132
    	
hgs
parents:
diff changeset
   133
    iBlacklist = CHarvesterBlacklist::NewL();
hgs
parents:
diff changeset
   134
    
hgs
parents:
diff changeset
   135
    _LIT( KMsg, "Exit BeginTestSession - Error code : %d" );
hgs
parents:
diff changeset
   136
    TBuf <100> msg;
hgs
parents:
diff changeset
   137
    msg.Format(KMsg, error);
hgs
parents:
diff changeset
   138
    iLog->Log( msg );
hgs
parents:
diff changeset
   139
    RDebug::Print( msg );
hgs
parents:
diff changeset
   140
    
hgs
parents:
diff changeset
   141
    User::LeaveIfError( error );
hgs
parents:
diff changeset
   142
    
hgs
parents:
diff changeset
   143
    return KErrNone;
hgs
parents:
diff changeset
   144
    }    
hgs
parents:
diff changeset
   145
hgs
parents:
diff changeset
   146
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   147
// CHarvesterPluginTest::EndTestSession
hgs
parents:
diff changeset
   148
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   149
//
hgs
parents:
diff changeset
   150
TInt CHarvesterPluginTest::EndTestSession( CStifItemParser& /* aItem */ )
hgs
parents:
diff changeset
   151
	{       
hgs
parents:
diff changeset
   152
	iPluginInfoArray.ResetAndDestroy();
hgs
parents:
diff changeset
   153
	iPluginInfoArray.Close();
hgs
parents:
diff changeset
   154
	
hgs
parents:
diff changeset
   155
	REComSession::FinalClose();
hgs
parents:
diff changeset
   156
    
hgs
parents:
diff changeset
   157
    if ( iCtxEngine )
hgs
parents:
diff changeset
   158
    	{
hgs
parents:
diff changeset
   159
    	iCtxEngine->ReleaseInstance();
hgs
parents:
diff changeset
   160
    	iCtxEngine = NULL;
hgs
parents:
diff changeset
   161
    	}
hgs
parents:
diff changeset
   162
hgs
parents:
diff changeset
   163
    if ( iBlacklist )
hgs
parents:
diff changeset
   164
        {
hgs
parents:
diff changeset
   165
        iBlacklist->CloseDatabase();
hgs
parents:
diff changeset
   166
        delete iBlacklist;
hgs
parents:
diff changeset
   167
        }
hgs
parents:
diff changeset
   168
    
hgs
parents:
diff changeset
   169
    if ( iSession )
hgs
parents:
diff changeset
   170
    	{
hgs
parents:
diff changeset
   171
    	delete iSession;
hgs
parents:
diff changeset
   172
    	iSession = NULL;
hgs
parents:
diff changeset
   173
    	}
hgs
parents:
diff changeset
   174
    
hgs
parents:
diff changeset
   175
    if ( iMdeObjectHandler )
hgs
parents:
diff changeset
   176
    	{
hgs
parents:
diff changeset
   177
    	delete iMdeObjectHandler;
hgs
parents:
diff changeset
   178
    	iMdeObjectHandler = NULL;
hgs
parents:
diff changeset
   179
    	}
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
    if( iMdeSession )
hgs
parents:
diff changeset
   182
    	{
hgs
parents:
diff changeset
   183
    	delete iMdeSession;
hgs
parents:
diff changeset
   184
    	iMdeSession = NULL;
hgs
parents:
diff changeset
   185
    	}
hgs
parents:
diff changeset
   186
    
hgs
parents:
diff changeset
   187
    _LIT( KMsg, "Exit    EndTestSession" );
hgs
parents:
diff changeset
   188
    iLog->Log( KMsg );  
hgs
parents:
diff changeset
   189
    RDebug::Print(KMsg);
hgs
parents:
diff changeset
   190
	
hgs
parents:
diff changeset
   191
    return KErrNone;
hgs
parents:
diff changeset
   192
    }
hgs
parents:
diff changeset
   193
hgs
parents:
diff changeset
   194
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   195
// CHarvesterPluginTest::LoadPluginsL
hgs
parents:
diff changeset
   196
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   197
//
hgs
parents:
diff changeset
   198
TInt CHarvesterPluginTest::LoadPluginsL( CStifItemParser& /* aItem */ )
hgs
parents:
diff changeset
   199
    {
hgs
parents:
diff changeset
   200
    _LIT( KMsg1, "Enter LoadPlugins" );
hgs
parents:
diff changeset
   201
    iLog->Log( KMsg1 );
hgs
parents:
diff changeset
   202
    RDebug::Print( KMsg1 );
hgs
parents:
diff changeset
   203
    
hgs
parents:
diff changeset
   204
    RImplInfoPtrArray infoArray;
hgs
parents:
diff changeset
   205
    	
hgs
parents:
diff changeset
   206
	TCleanupItem cleanupItem( MdsUtils::CleanupEComArray, &infoArray );
hgs
parents:
diff changeset
   207
	CleanupStack::PushL( cleanupItem );
hgs
parents:
diff changeset
   208
	
hgs
parents:
diff changeset
   209
	CHarvesterPlugin::ListImplementationsL( infoArray );
hgs
parents:
diff changeset
   210
	TInt count( 0 );
hgs
parents:
diff changeset
   211
	count = infoArray.Count();
hgs
parents:
diff changeset
   212
	
hgs
parents:
diff changeset
   213
	if( count == 0 )
hgs
parents:
diff changeset
   214
	    {
hgs
parents:
diff changeset
   215
	    return KErrNotFound;
hgs
parents:
diff changeset
   216
	    }
hgs
parents:
diff changeset
   217
	
hgs
parents:
diff changeset
   218
	for ( TInt i=0; i < count; i++ )
hgs
parents:
diff changeset
   219
		{
hgs
parents:
diff changeset
   220
		// Parse the file extensions and resolve plug-in's uids from infoArray to iDataTypeArray
hgs
parents:
diff changeset
   221
        TBufC8<256> type;
hgs
parents:
diff changeset
   222
        TBufC8<256> opaque;
hgs
parents:
diff changeset
   223
        
hgs
parents:
diff changeset
   224
        type = infoArray[i]->DataType();
hgs
parents:
diff changeset
   225
        opaque = infoArray[i]->OpaqueData();
hgs
parents:
diff changeset
   226
        TUid implUID = infoArray[i]->ImplementationUid(); 
hgs
parents:
diff changeset
   227
                
hgs
parents:
diff changeset
   228
        AddNewPluginL(type, opaque, implUID);
hgs
parents:
diff changeset
   229
		}
hgs
parents:
diff changeset
   230
	
hgs
parents:
diff changeset
   231
	CleanupStack::PopAndDestroy( &infoArray ); // infoArray, results in a call to CleanupEComArray
hgs
parents:
diff changeset
   232
    
hgs
parents:
diff changeset
   233
    _LIT( KMsg2, "Exit    LoadPlugins" );
hgs
parents:
diff changeset
   234
    iLog->Log( KMsg2 );
hgs
parents:
diff changeset
   235
    RDebug::Print( KMsg2 );
hgs
parents:
diff changeset
   236
    
hgs
parents:
diff changeset
   237
    return KErrNone;
hgs
parents:
diff changeset
   238
    }
hgs
parents:
diff changeset
   239
hgs
parents:
diff changeset
   240
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   241
// CHarvesterPluginTest::TestFunctionsL
hgs
parents:
diff changeset
   242
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   243
//
hgs
parents:
diff changeset
   244
TInt CHarvesterPluginTest::TestFunctionsL( CStifItemParser& aItem )
hgs
parents:
diff changeset
   245
    {
hgs
parents:
diff changeset
   246
    _LIT( KMsg1, "Enter TestFunctions" );
hgs
parents:
diff changeset
   247
    iLog->Log( KMsg1 );
hgs
parents:
diff changeset
   248
    RDebug::Print( KMsg1 );
hgs
parents:
diff changeset
   249
    
hgs
parents:
diff changeset
   250
	TPtrC inputFile;
hgs
parents:
diff changeset
   251
	User::LeaveIfError( aItem.GetNextString( inputFile ) );
hgs
parents:
diff changeset
   252
	
hgs
parents:
diff changeset
   253
	iMdeSession->RemoveObjectL( inputFile );
hgs
parents:
diff changeset
   254
	
hgs
parents:
diff changeset
   255
	TBuf<100> aObjectDef;
hgs
parents:
diff changeset
   256
hgs
parents:
diff changeset
   257
    _LIT( KMsg2_1, "enter GetObjectDef" );
hgs
parents:
diff changeset
   258
    iLog->Log( KMsg2_1 );
hgs
parents:
diff changeset
   259
    RDebug::Print( KMsg2_1 );
hgs
parents:
diff changeset
   260
	
hgs
parents:
diff changeset
   261
	GetObjectDef( inputFile, aObjectDef, EFalse );
hgs
parents:
diff changeset
   262
    
hgs
parents:
diff changeset
   263
	_LIT( KMsg2_2, "return from GetObjectDef" );
hgs
parents:
diff changeset
   264
    iLog->Log( KMsg2_2 );
hgs
parents:
diff changeset
   265
    RDebug::Print( KMsg2_2 );
hgs
parents:
diff changeset
   266
	
hgs
parents:
diff changeset
   267
	// harvesterdata object
hgs
parents:
diff changeset
   268
	HBufC* uriBuf = inputFile.AllocLC();
hgs
parents:
diff changeset
   269
hgs
parents:
diff changeset
   270
    _LIT( KMsg3, "Creating harvester data" );
hgs
parents:
diff changeset
   271
    iLog->Log( KMsg3 );
hgs
parents:
diff changeset
   272
    RDebug::Print( KMsg3 );
hgs
parents:
diff changeset
   273
	
hgs
parents:
diff changeset
   274
	CHarvesterData* data = CHarvesterData::NewL( uriBuf );
hgs
parents:
diff changeset
   275
	data->SetPluginObserver( *this );
hgs
parents:
diff changeset
   276
	CMdEObject* mdeObject = NULL;
hgs
parents:
diff changeset
   277
	_LIT( string, "Image" );
hgs
parents:
diff changeset
   278
hgs
parents:
diff changeset
   279
    _LIT( KMsg4, "Getting metadata object" );
hgs
parents:
diff changeset
   280
    iLog->Log( KMsg4 );
hgs
parents:
diff changeset
   281
    RDebug::Print( KMsg4 );
hgs
parents:
diff changeset
   282
	
hgs
parents:
diff changeset
   283
	mdeObject = iMdeObjectHandler->GetMetadataObjectL( *data, string );
hgs
parents:
diff changeset
   284
	
hgs
parents:
diff changeset
   285
    _LIT( KMsg5, "Setting metadata object" );
hgs
parents:
diff changeset
   286
    iLog->Log( KMsg5 );
hgs
parents:
diff changeset
   287
    RDebug::Print( KMsg5 );
hgs
parents:
diff changeset
   288
	
hgs
parents:
diff changeset
   289
	data->SetMdeObject( mdeObject );
hgs
parents:
diff changeset
   290
	
hgs
parents:
diff changeset
   291
    _LIT( KMsg6, "Metadata object set" );
hgs
parents:
diff changeset
   292
    iLog->Log( KMsg6 );
hgs
parents:
diff changeset
   293
    RDebug::Print( KMsg6 );
hgs
parents:
diff changeset
   294
	
hgs
parents:
diff changeset
   295
	CleanupStack::Pop( uriBuf );
hgs
parents:
diff changeset
   296
hgs
parents:
diff changeset
   297
    _LIT( KMsg7, "Calling HarvestL" );
hgs
parents:
diff changeset
   298
    iLog->Log( KMsg7 );
hgs
parents:
diff changeset
   299
    RDebug::Print( KMsg7 );
hgs
parents:
diff changeset
   300
	
hgs
parents:
diff changeset
   301
	HarvestL( data );
hgs
parents:
diff changeset
   302
	
hgs
parents:
diff changeset
   303
    _LIT( KMsg8, "Exit TestFunctions" );
hgs
parents:
diff changeset
   304
    iLog->Log( KMsg8 );
hgs
parents:
diff changeset
   305
    RDebug::Print( KMsg8 );
hgs
parents:
diff changeset
   306
    
hgs
parents:
diff changeset
   307
    return KErrNone;
hgs
parents:
diff changeset
   308
    }
hgs
parents:
diff changeset
   309
hgs
parents:
diff changeset
   310
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   311
// GetObjectDef
hgs
parents:
diff changeset
   312
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   313
//
hgs
parents:
diff changeset
   314
TBool CHarvesterPluginTest::GetObjectDef(const TDesC& aUri, TDes& aObjectDef, TBool aCheck)
hgs
parents:
diff changeset
   315
	{
hgs
parents:
diff changeset
   316
    _LIT( KMsg1, "GetObjectDef" );
hgs
parents:
diff changeset
   317
    iLog->Log( KMsg1 );
hgs
parents:
diff changeset
   318
    RDebug::Print( KMsg1 );
hgs
parents:
diff changeset
   319
    
hgs
parents:
diff changeset
   320
	CHarvesterPluginInfo* hpi = NULL; 
hgs
parents:
diff changeset
   321
hgs
parents:
diff changeset
   322
	TRAPD( err, hpi = GetHPIFromFileNameL(aUri) );
hgs
parents:
diff changeset
   323
	if ( err != KErrNone )
hgs
parents:
diff changeset
   324
		{
hgs
parents:
diff changeset
   325
	    _LIT( KMsg2, "GetHPIFromFileNameL not KErrNone, objectDef is 0, return" );
hgs
parents:
diff changeset
   326
	    iLog->Log( KMsg2 );
hgs
parents:
diff changeset
   327
	    RDebug::Print( KMsg2 );
hgs
parents:
diff changeset
   328
	    
hgs
parents:
diff changeset
   329
		aObjectDef.Zero();
hgs
parents:
diff changeset
   330
		return EFalse;
hgs
parents:
diff changeset
   331
		}
hgs
parents:
diff changeset
   332
hgs
parents:
diff changeset
   333
	if ( !hpi )
hgs
parents:
diff changeset
   334
		{
hgs
parents:
diff changeset
   335
        _LIT( KMsg3, "no hpi, objectDef is 0, return" );
hgs
parents:
diff changeset
   336
        iLog->Log( KMsg3 );
hgs
parents:
diff changeset
   337
        RDebug::Print( KMsg3 );
hgs
parents:
diff changeset
   338
		aObjectDef.Zero();
hgs
parents:
diff changeset
   339
		}
hgs
parents:
diff changeset
   340
	else
hgs
parents:
diff changeset
   341
		{
hgs
parents:
diff changeset
   342
        _LIT( KMsg4, "hpi found" );
hgs
parents:
diff changeset
   343
        iLog->Log( KMsg4 );
hgs
parents:
diff changeset
   344
        RDebug::Print( KMsg4 );
hgs
parents:
diff changeset
   345
        
hgs
parents:
diff changeset
   346
		if( hpi->iObjectTypes.Count() > 1)
hgs
parents:
diff changeset
   347
			{
hgs
parents:
diff changeset
   348
	        _LIT( KMsg5_1, "plugin supports over 1 object type" );
hgs
parents:
diff changeset
   349
	        iLog->Log( KMsg5_1 );
hgs
parents:
diff changeset
   350
	        RDebug::Print( KMsg5_1 );
hgs
parents:
diff changeset
   351
	        
hgs
parents:
diff changeset
   352
			if( aCheck )
hgs
parents:
diff changeset
   353
				{
hgs
parents:
diff changeset
   354
				aObjectDef.Zero();
hgs
parents:
diff changeset
   355
				return ETrue;
hgs
parents:
diff changeset
   356
				}
hgs
parents:
diff changeset
   357
			
hgs
parents:
diff changeset
   358
			if ( ! hpi->iPlugin )
hgs
parents:
diff changeset
   359
	    		{
hgs
parents:
diff changeset
   360
	    		TRAPD( error, hpi->iPlugin = CHarvesterPlugin::NewL( hpi->iPluginUid ) );
hgs
parents:
diff changeset
   361
	             if( error )
hgs
parents:
diff changeset
   362
	                    {
hgs
parents:
diff changeset
   363
	                    aObjectDef.Zero();
hgs
parents:
diff changeset
   364
	                    return EFalse;
hgs
parents:
diff changeset
   365
	                    }
hgs
parents:
diff changeset
   366
	             else
hgs
parents:
diff changeset
   367
	                 {
hgs
parents:
diff changeset
   368
	                 hpi->iPlugin->SetQueue( hpi->iQueue );
hgs
parents:
diff changeset
   369
	                 }
hgs
parents:
diff changeset
   370
	    		}
hgs
parents:
diff changeset
   371
			
hgs
parents:
diff changeset
   372
            _LIT( KMsg5_2, "calling iPlugin->GetObjectType" );
hgs
parents:
diff changeset
   373
            iLog->Log( KMsg5_2 );
hgs
parents:
diff changeset
   374
            RDebug::Print( KMsg5_2 );
hgs
parents:
diff changeset
   375
            
hgs
parents:
diff changeset
   376
			hpi->iPlugin->GetObjectType( aUri, aObjectDef );
hgs
parents:
diff changeset
   377
			
hgs
parents:
diff changeset
   378
	        _LIT( KMsg5_3, "object type selected" );
hgs
parents:
diff changeset
   379
	        iLog->Log( KMsg5_3 );
hgs
parents:
diff changeset
   380
	        RDebug::Print( KMsg5_3 );
hgs
parents:
diff changeset
   381
			}
hgs
parents:
diff changeset
   382
		else
hgs
parents:
diff changeset
   383
			{
hgs
parents:
diff changeset
   384
            _LIT( KMsg6_1, "plugin supports 1 object type, select it" );
hgs
parents:
diff changeset
   385
            iLog->Log( KMsg6_1 );
hgs
parents:
diff changeset
   386
            RDebug::Print( KMsg6_1 );
hgs
parents:
diff changeset
   387
		    
hgs
parents:
diff changeset
   388
			aObjectDef.Copy( *(hpi->iObjectTypes[0]) );
hgs
parents:
diff changeset
   389
			_LIT( KMsg6_2, "object type selected" );
hgs
parents:
diff changeset
   390
            iLog->Log( KMsg6_2 );
hgs
parents:
diff changeset
   391
            RDebug::Print( KMsg6_2 );
hgs
parents:
diff changeset
   392
			}
hgs
parents:
diff changeset
   393
		}
hgs
parents:
diff changeset
   394
	
hgs
parents:
diff changeset
   395
	return EFalse;
hgs
parents:
diff changeset
   396
	}
hgs
parents:
diff changeset
   397
hgs
parents:
diff changeset
   398
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   399
// HarvestL
hgs
parents:
diff changeset
   400
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   401
//
hgs
parents:
diff changeset
   402
TInt CHarvesterPluginTest::HarvestL( CHarvesterData* aHD )
hgs
parents:
diff changeset
   403
	{
hgs
parents:
diff changeset
   404
    _LIT( KMsg1, "Enter HarvestL" );
hgs
parents:
diff changeset
   405
    iLog->Log( KMsg1 );
hgs
parents:
diff changeset
   406
    RDebug::Print( KMsg1 );
hgs
parents:
diff changeset
   407
	
hgs
parents:
diff changeset
   408
	CHarvesterPluginInfo* hpi = aHD->HarvesterPluginInfo();
hgs
parents:
diff changeset
   409
	
hgs
parents:
diff changeset
   410
	if ( !hpi ) 
hgs
parents:
diff changeset
   411
		{
hgs
parents:
diff changeset
   412
		 hpi = GetHPIFromFileNameL( aHD->Uri() );
hgs
parents:
diff changeset
   413
		}
hgs
parents:
diff changeset
   414
	
hgs
parents:
diff changeset
   415
	if ( hpi )
hgs
parents:
diff changeset
   416
		{
hgs
parents:
diff changeset
   417
		if ( ! hpi->iPlugin )
hgs
parents:
diff changeset
   418
    		{
hgs
parents:
diff changeset
   419
    		hpi->iPlugin = CHarvesterPlugin::NewL( hpi->iPluginUid );
hgs
parents:
diff changeset
   420
    		hpi->iPlugin->SetQueue( hpi->iQueue );
hgs
parents:
diff changeset
   421
    		hpi->iPlugin->SetBlacklist( *iBlacklist );
hgs
parents:
diff changeset
   422
    		}
hgs
parents:
diff changeset
   423
		
hgs
parents:
diff changeset
   424
	    if( aHD->ObjectType() == EFastHarvest || aHD->Origin() == MdeConstants::Object::ECamera )
hgs
parents:
diff changeset
   425
	    	{
hgs
parents:
diff changeset
   426
	    	hpi->iQueue.Insert( aHD, 0 );
hgs
parents:
diff changeset
   427
	    	}
hgs
parents:
diff changeset
   428
	    else
hgs
parents:
diff changeset
   429
			{
hgs
parents:
diff changeset
   430
			hpi->iQueue.AppendL( aHD );
hgs
parents:
diff changeset
   431
			}
hgs
parents:
diff changeset
   432
	    
hgs
parents:
diff changeset
   433
		hpi->iPlugin->StartHarvest();
hgs
parents:
diff changeset
   434
	
hgs
parents:
diff changeset
   435
	    _LIT( KMsg2, "Exit HarvestL" );
hgs
parents:
diff changeset
   436
	    iLog->Log( KMsg2 );
hgs
parents:
diff changeset
   437
	    RDebug::Print( KMsg2 );
hgs
parents:
diff changeset
   438
		
hgs
parents:
diff changeset
   439
		return KErrNone;
hgs
parents:
diff changeset
   440
		}
hgs
parents:
diff changeset
   441
	
hgs
parents:
diff changeset
   442
	return KErrNotFound;
hgs
parents:
diff changeset
   443
	}
hgs
parents:
diff changeset
   444
hgs
parents:
diff changeset
   445
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   446
// AddNewPluginL
hgs
parents:
diff changeset
   447
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   448
//
hgs
parents:
diff changeset
   449
void CHarvesterPluginTest::AddNewPluginL( const TDesC8& aType, const TDesC8& aOpaque, TUid aPluginUid )
hgs
parents:
diff changeset
   450
    {      
hgs
parents:
diff changeset
   451
    CHarvesterPluginInfo* pluginInfo = new (ELeave) CHarvesterPluginInfo;
hgs
parents:
diff changeset
   452
    CleanupStack::PushL( pluginInfo );
hgs
parents:
diff changeset
   453
hgs
parents:
diff changeset
   454
    // get file extensions
hgs
parents:
diff changeset
   455
    TLex8 lex( aOpaque );
hgs
parents:
diff changeset
   456
    while ( !lex.Eos() )
hgs
parents:
diff changeset
   457
        {
hgs
parents:
diff changeset
   458
        /* Tokenizing file extensions using TLex8 */
hgs
parents:
diff changeset
   459
        lex.SkipSpaceAndMark();
hgs
parents:
diff changeset
   460
hgs
parents:
diff changeset
   461
        TPtrC8 extToken = lex.NextToken();
hgs
parents:
diff changeset
   462
hgs
parents:
diff changeset
   463
        HBufC* str = HBufC::NewLC( extToken.Length() );
hgs
parents:
diff changeset
   464
        str->Des().Copy( extToken );
hgs
parents:
diff changeset
   465
        pluginInfo->iExtensions.AppendL( str );
hgs
parents:
diff changeset
   466
        CleanupStack::Pop( str );
hgs
parents:
diff changeset
   467
        }
hgs
parents:
diff changeset
   468
hgs
parents:
diff changeset
   469
    // get object types
hgs
parents:
diff changeset
   470
    TLex8 lexObjectTypes( aType );
hgs
parents:
diff changeset
   471
    while ( !lexObjectTypes.Eos() )
hgs
parents:
diff changeset
   472
        {
hgs
parents:
diff changeset
   473
        /* Tokenizing object types using TLex8 */
hgs
parents:
diff changeset
   474
        lexObjectTypes.SkipSpaceAndMark();
hgs
parents:
diff changeset
   475
        
hgs
parents:
diff changeset
   476
        TPtrC8 objectTypeToken = lexObjectTypes.NextToken();
hgs
parents:
diff changeset
   477
hgs
parents:
diff changeset
   478
        HBufC* str = HBufC::NewLC( objectTypeToken.Length() );
hgs
parents:
diff changeset
   479
        str->Des().Copy( objectTypeToken );
hgs
parents:
diff changeset
   480
        pluginInfo->iObjectTypes.AppendL( str );
hgs
parents:
diff changeset
   481
        CleanupStack::Pop( str );
hgs
parents:
diff changeset
   482
        }
hgs
parents:
diff changeset
   483
hgs
parents:
diff changeset
   484
    /* We set plugin as NULL - we only load them when needed */
hgs
parents:
diff changeset
   485
    pluginInfo->iPlugin = NULL;
hgs
parents:
diff changeset
   486
    pluginInfo->iPluginUid = aPluginUid;
hgs
parents:
diff changeset
   487
    iPluginInfoArray.AppendL( pluginInfo );
hgs
parents:
diff changeset
   488
    CleanupStack::Pop( pluginInfo );
hgs
parents:
diff changeset
   489
    }
hgs
parents:
diff changeset
   490
hgs
parents:
diff changeset
   491
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   492
// GetHPIFromFileNameL
hgs
parents:
diff changeset
   493
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   494
//
hgs
parents:
diff changeset
   495
CHarvesterPluginInfo* CHarvesterPluginTest::GetHPIFromFileNameL(const TDesC& aFileName)
hgs
parents:
diff changeset
   496
	{
hgs
parents:
diff changeset
   497
    _LIT( KMsg1, "Enter GetHPIFromFileNameL" );
hgs
parents:
diff changeset
   498
    iLog->Log( KMsg1 );
hgs
parents:
diff changeset
   499
    RDebug::Print( KMsg1 );
hgs
parents:
diff changeset
   500
	
hgs
parents:
diff changeset
   501
	TParsePtrC parser( aFileName );
hgs
parents:
diff changeset
   502
    
hgs
parents:
diff changeset
   503
    // without trailing dot "."
hgs
parents:
diff changeset
   504
    TPtrC ptr = parser.Ext();
hgs
parents:
diff changeset
   505
    if ( ptr.Length() > 1 )
hgs
parents:
diff changeset
   506
    	{
hgs
parents:
diff changeset
   507
    	ptr.Set( ptr.Mid( 1 ) );
hgs
parents:
diff changeset
   508
    	}
hgs
parents:
diff changeset
   509
hgs
parents:
diff changeset
   510
    _LIT( KMsg2, "Exit GetHPIFromFileNameL" );
hgs
parents:
diff changeset
   511
    iLog->Log( KMsg2 );
hgs
parents:
diff changeset
   512
    RDebug::Print( KMsg2 );
hgs
parents:
diff changeset
   513
    
hgs
parents:
diff changeset
   514
	return GetFromNormalFileL( ptr );
hgs
parents:
diff changeset
   515
	}
hgs
parents:
diff changeset
   516
hgs
parents:
diff changeset
   517
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   518
// GetFromNormalFile
hgs
parents:
diff changeset
   519
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   520
//
hgs
parents:
diff changeset
   521
CHarvesterPluginInfo* CHarvesterPluginTest::GetFromNormalFileL( TDesC& aExt )
hgs
parents:
diff changeset
   522
	{
hgs
parents:
diff changeset
   523
    _LIT( KMsg1, "Enter GetFromNormalFileL" );
hgs
parents:
diff changeset
   524
    iLog->Log( KMsg1 );
hgs
parents:
diff changeset
   525
    RDebug::Print( KMsg1 );
hgs
parents:
diff changeset
   526
	
hgs
parents:
diff changeset
   527
	CHarvesterPluginInfo* retVal = NULL;
hgs
parents:
diff changeset
   528
hgs
parents:
diff changeset
   529
	for ( TInt i = iPluginInfoArray.Count(); --i >= 0; )
hgs
parents:
diff changeset
   530
        {
hgs
parents:
diff changeset
   531
        CHarvesterPluginInfo* info = iPluginInfoArray[i];
hgs
parents:
diff changeset
   532
        TBool found = EFalse;
hgs
parents:
diff changeset
   533
        
hgs
parents:
diff changeset
   534
        for ( TInt k = info->iExtensions.Count(); --k >= 0; )
hgs
parents:
diff changeset
   535
            {
hgs
parents:
diff changeset
   536
            TDesC* ext = info->iExtensions[k];
hgs
parents:
diff changeset
   537
            
hgs
parents:
diff changeset
   538
            // checking against supported plugin file extensions
hgs
parents:
diff changeset
   539
            TInt result = ext->CompareF( aExt );
hgs
parents:
diff changeset
   540
            if ( result == 0 )
hgs
parents:
diff changeset
   541
                {
hgs
parents:
diff changeset
   542
                retVal = info;
hgs
parents:
diff changeset
   543
                found = ETrue;
hgs
parents:
diff changeset
   544
                break;
hgs
parents:
diff changeset
   545
                }
hgs
parents:
diff changeset
   546
            }
hgs
parents:
diff changeset
   547
        if ( found )
hgs
parents:
diff changeset
   548
        	{
hgs
parents:
diff changeset
   549
        	break;
hgs
parents:
diff changeset
   550
        	}
hgs
parents:
diff changeset
   551
        }
hgs
parents:
diff changeset
   552
hgs
parents:
diff changeset
   553
    _LIT( KMsg2, "Exit GetFromNormalFileL" );
hgs
parents:
diff changeset
   554
    iLog->Log( KMsg2 );
hgs
parents:
diff changeset
   555
    RDebug::Print( KMsg2 );
hgs
parents:
diff changeset
   556
	
hgs
parents:
diff changeset
   557
	return retVal;
hgs
parents:
diff changeset
   558
	}
hgs
parents:
diff changeset
   559
hgs
parents:
diff changeset
   560
//  [End of File] - Do not remove