omadmadapters/email/tsrc/src/dmatest.cpp
author hgs
Fri, 23 Jul 2010 16:30:56 +0530
changeset 49 c34c36d1c835
parent 46 b9b00b134b0d
child 52 6e38e48ee756
permissions -rw-r--r--
201029
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2008 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:  Implementation of DM adapter test component
hgs
parents:
diff changeset
    15
* 	This is part of omadmextensions/adapter test application.
hgs
parents:
diff changeset
    16
*
hgs
parents:
diff changeset
    17
*/
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
// INCLUDE FILES
hgs
parents:
diff changeset
    25
#include "dmatest.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
#include <StifParser.h>
hgs
parents:
diff changeset
    28
#include <Stiftestinterface.h>
hgs
parents:
diff changeset
    29
#include <S32FILE.H>
hgs
parents:
diff changeset
    30
#include <s32mem.h>
hgs
parents:
diff changeset
    31
#include <apgcli.h>
hgs
parents:
diff changeset
    32
#include <e32svr.h>
hgs
parents:
diff changeset
    33
#include <e32math.h>
hgs
parents:
diff changeset
    34
#include <f32file.h>
hgs
parents:
diff changeset
    35
#include <swinstapi.h>
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
#include "TestDmDDFObject.h"
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
_LIT8( KEmptyType, "" );
hgs
parents:
diff changeset
    40
_LIT8( KDefaultType, "text/plain" );
hgs
parents:
diff changeset
    41
_LIT( KMappingTableFile, "\\dmtestmappings.txt" );
hgs
parents:
diff changeset
    42
//_LIT8( KNSmlDMSeparator8, "/" );
hgs
parents:
diff changeset
    43
const TUint8 KNSmlDMUriSeparator = 0x2f; //forward slash
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
#define LEAVE_IF_ERROR(x,msg) \
hgs
parents:
diff changeset
    46
	{ TInt __xres = (x); if ( __xres < 0 ) { if ( iLog ) iLog->Log( (msg), __xres ); User::Leave( __xres );	} }
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
// ============================ MEMBER FUNCTIONS ===============================
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    52
// Cdmatest::Cdmatest
hgs
parents:
diff changeset
    53
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
    54
// leave.
hgs
parents:
diff changeset
    55
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    56
//
hgs
parents:
diff changeset
    57
Cdmatest::Cdmatest(CTestModuleIf& aTestModuleIf, TUid aUid ):
hgs
parents:
diff changeset
    58
        CScriptBase( aTestModuleIf ), iMappingTable(2), iUid( aUid )
hgs
parents:
diff changeset
    59
    {
hgs
parents:
diff changeset
    60
    
hgs
parents:
diff changeset
    61
    }
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    64
// Cdmatest::ConstructL
hgs
parents:
diff changeset
    65
// Symbian 2nd phase constructor can leave.
hgs
parents:
diff changeset
    66
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    67
//
hgs
parents:
diff changeset
    68
void Cdmatest::ConstructL()
hgs
parents:
diff changeset
    69
    {    
hgs
parents:
diff changeset
    70
    Adapter();
hgs
parents:
diff changeset
    71
	iEmptyMappingInfoArray = new ( ELeave ) CArrayFixFlat<TSmlDmMappingInfo>(1);
hgs
parents:
diff changeset
    72
	
hgs
parents:
diff changeset
    73
	TRAPD( err, LoadMappingsL() );
hgs
parents:
diff changeset
    74
	if (err != KErrEof && err != KErrNone && err != KErrNotFound)
hgs
parents:
diff changeset
    75
		{
hgs
parents:
diff changeset
    76
		User::Leave( err );
hgs
parents:
diff changeset
    77
		}
hgs
parents:
diff changeset
    78
    }
hgs
parents:
diff changeset
    79
    
hgs
parents:
diff changeset
    80
CNSmlDmEmailAdapter *Cdmatest::Adapter()  
hgs
parents:
diff changeset
    81
	{
hgs
parents:
diff changeset
    82
	if ( iAdapter == NULL )
hgs
parents:
diff changeset
    83
		{
hgs
parents:
diff changeset
    84
		if ( iLog )
hgs
parents:
diff changeset
    85
			{
hgs
parents:
diff changeset
    86
			iLog->Log( _L( "Loading Adapter" ) );
hgs
parents:
diff changeset
    87
			}
hgs
parents:
diff changeset
    88
  		
hgs
parents:
diff changeset
    89
  		TRAPD( err, iAdapter = (CNSmlDmEmailAdapter*) CSmlDmAdapter::NewL( iUid,*this ) );
hgs
parents:
diff changeset
    90
	if ( err == KErrNone )
hgs
parents:
diff changeset
    91
		{
hgs
parents:
diff changeset
    92
		if (iLog )
hgs
parents:
diff changeset
    93
			{
hgs
parents:
diff changeset
    94
			iLog->Log( _L( "Loaded" ) );	
hgs
parents:
diff changeset
    95
			}
hgs
parents:
diff changeset
    96
		}
hgs
parents:
diff changeset
    97
	else
hgs
parents:
diff changeset
    98
		{
hgs
parents:
diff changeset
    99
		if (iLog)
hgs
parents:
diff changeset
   100
			{
hgs
parents:
diff changeset
   101
			iLog->Log( _L( "Failed to load adapter: %d" ), err );
hgs
parents:
diff changeset
   102
			}
hgs
parents:
diff changeset
   103
		}
hgs
parents:
diff changeset
   104
		}
hgs
parents:
diff changeset
   105
	return iAdapter;
hgs
parents:
diff changeset
   106
	}
hgs
parents:
diff changeset
   107
    
hgs
parents:
diff changeset
   108
    
hgs
parents:
diff changeset
   109
void Cdmatest::LoadMappingsL()
hgs
parents:
diff changeset
   110
	{
hgs
parents:
diff changeset
   111
	TDataType type; 
hgs
parents:
diff changeset
   112
	HBufC8 *data = LoadFileLC( KMappingTableFile,  type );
hgs
parents:
diff changeset
   113
	RDesReadStream buf( *data );
hgs
parents:
diff changeset
   114
	CleanupClosePushL( buf );
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
	TInt len( data->Length() );
hgs
parents:
diff changeset
   117
	while (buf.Source()->TellL( MStreamBuf::ERead ).Offset() < len)
hgs
parents:
diff changeset
   118
		{
hgs
parents:
diff changeset
   119
		TUint32 val = buf.ReadUint32L();
hgs
parents:
diff changeset
   120
		TBuf8<256> uri;
hgs
parents:
diff changeset
   121
		TBuf8<64> luid;
hgs
parents:
diff changeset
   122
		buf.ReadL(uri, val);
hgs
parents:
diff changeset
   123
		val = buf.ReadUint32L();
hgs
parents:
diff changeset
   124
		buf.ReadL(luid, val);
hgs
parents:
diff changeset
   125
		TMapping m( uri, luid ) ;
hgs
parents:
diff changeset
   126
		TInt err( iMappingTable.Append( m )	);
hgs
parents:
diff changeset
   127
		if ( err == KErrNone )
hgs
parents:
diff changeset
   128
			{
hgs
parents:
diff changeset
   129
			iLog->Log( _L8( "Loaded mapping: '%S' : '%S'"), &m.iURI, &m.iLuid );
hgs
parents:
diff changeset
   130
			}
hgs
parents:
diff changeset
   131
		else
hgs
parents:
diff changeset
   132
			{
hgs
parents:
diff changeset
   133
			iLog->Log( _L8( "FAILED TO Load mapping: '%d' "), err );
hgs
parents:
diff changeset
   134
			}
hgs
parents:
diff changeset
   135
		}
hgs
parents:
diff changeset
   136
	CleanupStack::PopAndDestroy( &buf); // buf
hgs
parents:
diff changeset
   137
	CleanupStack::PopAndDestroy( data ); // data
hgs
parents:
diff changeset
   138
	}
hgs
parents:
diff changeset
   139
    	
hgs
parents:
diff changeset
   140
	
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
void Cdmatest::SaveMappingsL()
hgs
parents:
diff changeset
   143
    {
hgs
parents:
diff changeset
   144
	TInt c( iMappingTable.Count() );
hgs
parents:
diff changeset
   145
	if ( c > 0 )
hgs
parents:
diff changeset
   146
	{
hgs
parents:
diff changeset
   147
    	RFs fs;
hgs
parents:
diff changeset
   148
    	User::LeaveIfError( fs.Connect() );
hgs
parents:
diff changeset
   149
    	CleanupClosePushL( fs );
hgs
parents:
diff changeset
   150
    	RFileWriteStream buf;
hgs
parents:
diff changeset
   151
    	User::LeaveIfError( buf.Replace( fs, KMappingTableFile, EFileWrite ) );
hgs
parents:
diff changeset
   152
    	CleanupClosePushL( buf );
hgs
parents:
diff changeset
   153
		
hgs
parents:
diff changeset
   154
		TInt i( 0 ) ;
hgs
parents:
diff changeset
   155
		do 
hgs
parents:
diff changeset
   156
			{
hgs
parents:
diff changeset
   157
			buf.WriteUint32L( iMappingTable[i].iURI.Length() );
hgs
parents:
diff changeset
   158
			buf.WriteL( iMappingTable[i].iURI );
hgs
parents:
diff changeset
   159
			buf.WriteUint32L( iMappingTable[i].iLuid.Length() );
hgs
parents:
diff changeset
   160
			buf.WriteL( iMappingTable[i].iLuid );
hgs
parents:
diff changeset
   161
			}
hgs
parents:
diff changeset
   162
		while ( ++i < c )	;
hgs
parents:
diff changeset
   163
		buf.CommitL();
hgs
parents:
diff changeset
   164
		buf.Close();
hgs
parents:
diff changeset
   165
	
hgs
parents:
diff changeset
   166
		CleanupStack::PopAndDestroy(); // buf
hgs
parents:
diff changeset
   167
		CleanupStack::PopAndDestroy(); // fs
hgs
parents:
diff changeset
   168
		}
hgs
parents:
diff changeset
   169
    }
hgs
parents:
diff changeset
   170
    	
hgs
parents:
diff changeset
   171
    
hgs
parents:
diff changeset
   172
// Destructor
hgs
parents:
diff changeset
   173
Cdmatest::~Cdmatest()
hgs
parents:
diff changeset
   174
    {
hgs
parents:
diff changeset
   175
    // Delete resources allocated from test methods
hgs
parents:
diff changeset
   176
    TRAPD(err, SaveMappingsL() );
hgs
parents:
diff changeset
   177
    if ( err != KErrNone )
hgs
parents:
diff changeset
   178
    	{
hgs
parents:
diff changeset
   179
    	iLog->Log( _L8( "Failed to save mappings!: %d"), err );
hgs
parents:
diff changeset
   180
    	}
hgs
parents:
diff changeset
   181
    Delete();
hgs
parents:
diff changeset
   182
    
hgs
parents:
diff changeset
   183
    // Delete logger
hgs
parents:
diff changeset
   184
    delete iLog;  
hgs
parents:
diff changeset
   185
    delete iEmptyMappingInfoArray;
hgs
parents:
diff changeset
   186
    delete iAdapter;
hgs
parents:
diff changeset
   187
    delete iURI;
hgs
parents:
diff changeset
   188
    iMappingTable.Reset();
hgs
parents:
diff changeset
   189
    REComSession::FinalClose();    
hgs
parents:
diff changeset
   190
    }
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
hgs
parents:
diff changeset
   193
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   194
// Camatest::Delete
hgs
parents:
diff changeset
   195
// Delete here all resources allocated and opened from test methods. 
hgs
parents:
diff changeset
   196
// Called from destructor. 
hgs
parents:
diff changeset
   197
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   198
//
hgs
parents:
diff changeset
   199
void Cdmatest::Delete() 
hgs
parents:
diff changeset
   200
    {
hgs
parents:
diff changeset
   201
    
hgs
parents:
diff changeset
   202
    }
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   205
// Cdmatest::?member_function
hgs
parents:
diff changeset
   206
// ?implementation_description
hgs
parents:
diff changeset
   207
// (other items were commented in a header).
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
HBufC8 *Cdmatest::GetNextStringLC ( CStifItemParser& aItem, const TDesC &aName )
hgs
parents:
diff changeset
   213
	{
hgs
parents:
diff changeset
   214
	TPtrC nodename( KNullDesC );
hgs
parents:
diff changeset
   215
hgs
parents:
diff changeset
   216
    TInt i( aItem.GetNextString ( nodename ) );
hgs
parents:
diff changeset
   217
    if ( i != KErrNone ) 
hgs
parents:
diff changeset
   218
	    {
hgs
parents:
diff changeset
   219
	    iLog->Log( _L( "ERROR Reading '%S' argument: 0x%X" ), &aName, i );
hgs
parents:
diff changeset
   220
	    }
hgs
parents:
diff changeset
   221
	else
hgs
parents:
diff changeset
   222
		{
hgs
parents:
diff changeset
   223
		iLog->Log( _L("%S: %S"), &aName, &nodename);
hgs
parents:
diff changeset
   224
		}
hgs
parents:
diff changeset
   225
	
hgs
parents:
diff changeset
   226
	HBufC8 *buf = HBufC8::NewLC( nodename.Length() ) ;
hgs
parents:
diff changeset
   227
	buf->Des().Copy( nodename );
hgs
parents:
diff changeset
   228
	return buf;
hgs
parents:
diff changeset
   229
	}
hgs
parents:
diff changeset
   230
	
hgs
parents:
diff changeset
   231
TInt Cdmatest::FetchNodeL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   232
	{
hgs
parents:
diff changeset
   233
hgs
parents:
diff changeset
   234
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   235
    // Print to UI
hgs
parents:
diff changeset
   236
    TestModuleIf().Printf( 0, _L("Cdmatest"), _L("FetchNodeL") );
hgs
parents:
diff changeset
   237
hgs
parents:
diff changeset
   238
	iResultsFunction = FetchNodeResultsL;
hgs
parents:
diff changeset
   239
	
hgs
parents:
diff changeset
   240
    TPtrC8 nodename( GetNextStringLC( aItem, _L(" nodename" ) )->Des() ) ;
hgs
parents:
diff changeset
   241
		
hgs
parents:
diff changeset
   242
	SetURIL(nodename) ;//
hgs
parents:
diff changeset
   243
	HBufC8 *luid = GetLuidAllocLC( *iURI );
hgs
parents:
diff changeset
   244
hgs
parents:
diff changeset
   245
	Adapter()->ChildURIListL( *iURI, *luid, *iEmptyMappingInfoArray, 4, 5) ;
hgs
parents:
diff changeset
   246
hgs
parents:
diff changeset
   247
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   248
		{
hgs
parents:
diff changeset
   249
		}
hgs
parents:
diff changeset
   250
	else
hgs
parents:
diff changeset
   251
		{
hgs
parents:
diff changeset
   252
		iLog->Log( _L("FetchNodeL: ChildUriList Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   253
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   254
		}
hgs
parents:
diff changeset
   255
	CleanupStack::PopAndDestroy( luid ) ; 
hgs
parents:
diff changeset
   256
	CleanupStack::PopAndDestroy() ; // nodename
hgs
parents:
diff changeset
   257
	iLog->Log( _L("FetchNodeL: Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   258
hgs
parents:
diff changeset
   259
    return ret;
hgs
parents:
diff changeset
   260
	}
hgs
parents:
diff changeset
   261
	
hgs
parents:
diff changeset
   262
TInt Cdmatest::StartAtomicL( CStifItemParser& /*aItem*/ )	
hgs
parents:
diff changeset
   263
	{
hgs
parents:
diff changeset
   264
	TRAPD( err, Adapter()->StartAtomicL() ) ;
hgs
parents:
diff changeset
   265
	iLog->Log( _L("StartAtomicL: Atomic started resulting error %d" ), err );	
hgs
parents:
diff changeset
   266
    return err;
hgs
parents:
diff changeset
   267
	}
hgs
parents:
diff changeset
   268
hgs
parents:
diff changeset
   269
TInt Cdmatest::RollbackAtomicL( CStifItemParser& /*aItem*/ )	
hgs
parents:
diff changeset
   270
	{
hgs
parents:
diff changeset
   271
	TRAPD( err, Adapter()->RollbackAtomicL() ) ;
hgs
parents:
diff changeset
   272
	iLog->Log( _L("RollbackAtomicL: Atomic rolled back resulting error %d" ), err );	
hgs
parents:
diff changeset
   273
    return err;
hgs
parents:
diff changeset
   274
	}
hgs
parents:
diff changeset
   275
	
hgs
parents:
diff changeset
   276
TInt Cdmatest::CommitAtomicL( CStifItemParser& /*aItem*/ )	
hgs
parents:
diff changeset
   277
	{
hgs
parents:
diff changeset
   278
	TRAPD( err, Adapter()->CommitAtomicL() ) ;
hgs
parents:
diff changeset
   279
	iLog->Log( _L("RollbackAtomicL: Atomic commited resulting error %d" ), err );	
hgs
parents:
diff changeset
   280
    return err;
hgs
parents:
diff changeset
   281
	}
hgs
parents:
diff changeset
   282
	
hgs
parents:
diff changeset
   283
hgs
parents:
diff changeset
   284
TInt Cdmatest::DDFStructureL( CStifItemParser& /*aItem*/ )	
hgs
parents:
diff changeset
   285
	{
hgs
parents:
diff changeset
   286
	CTestDmDDFObject* ddfRoot = CTestDmDDFObject::NewLC( iLog ); //, aNodeName );
hgs
parents:
diff changeset
   287
hgs
parents:
diff changeset
   288
	TRAPD( err, iAdapter->DDFStructureL( *ddfRoot ) ) ;
hgs
parents:
diff changeset
   289
	CleanupStack::PopAndDestroy( ddfRoot );
hgs
parents:
diff changeset
   290
	iLog->Log( _L("DDFStructureL: method called resulting error %d" ), err );	
hgs
parents:
diff changeset
   291
    return err;
hgs
parents:
diff changeset
   292
	}
hgs
parents:
diff changeset
   293
		
hgs
parents:
diff changeset
   294
		
hgs
parents:
diff changeset
   295
TInt Cdmatest::AddNodeL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   296
	{
hgs
parents:
diff changeset
   297
hgs
parents:
diff changeset
   298
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   299
    // Print to UI
hgs
parents:
diff changeset
   300
    TestModuleIf().Printf( 0, _L("Cdmatest"), _L("AddNodeL") );
hgs
parents:
diff changeset
   301
hgs
parents:
diff changeset
   302
    
hgs
parents:
diff changeset
   303
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("nodename" ) )->Des() ) ;
hgs
parents:
diff changeset
   304
    SetURIL( nodename );
hgs
parents:
diff changeset
   305
hgs
parents:
diff changeset
   306
	Adapter()->AddNodeObjectL( *iURI, KEmptyType, 8 ) ;
hgs
parents:
diff changeset
   307
	
hgs
parents:
diff changeset
   308
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   309
		{
hgs
parents:
diff changeset
   310
		iLog->Log( _L("AddNodeL: AddNodeObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   311
		}
hgs
parents:
diff changeset
   312
	else
hgs
parents:
diff changeset
   313
		{
hgs
parents:
diff changeset
   314
		iLog->Log( _L("AddNodeL: AddNodeObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   315
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   316
		}
hgs
parents:
diff changeset
   317
		
hgs
parents:
diff changeset
   318
	CleanupStack::PopAndDestroy() ; // nodename
hgs
parents:
diff changeset
   319
	iLog->Log( _L("AddNodeL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   320
hgs
parents:
diff changeset
   321
    return ret;
hgs
parents:
diff changeset
   322
	}	
hgs
parents:
diff changeset
   323
		
hgs
parents:
diff changeset
   324
TInt Cdmatest::UpdateLeafL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   325
	{
hgs
parents:
diff changeset
   326
hgs
parents:
diff changeset
   327
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   328
    // Print to UI
hgs
parents:
diff changeset
   329
    TestModuleIf().Printf( 0, _L("Cdmatest"), _L("UpdateLeafL") );
hgs
parents:
diff changeset
   330
hgs
parents:
diff changeset
   331
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Node name") )->Des() ) ;
hgs
parents:
diff changeset
   332
    TPtrC8 data (GetNextStringLC( aItem, _L("datafile"))->Des() );
hgs
parents:
diff changeset
   333
    
hgs
parents:
diff changeset
   334
	HBufC8 *mime = GetNextStringLC( aItem, _L("mime") ) ;
hgs
parents:
diff changeset
   335
    SetURIL( nodename );
hgs
parents:
diff changeset
   336
    
hgs
parents:
diff changeset
   337
    TPtrC8 parentURI(RemoveLastSeg(nodename));
hgs
parents:
diff changeset
   338
    HBufC8 *luid = GetLuidAllocLC( parentURI );
hgs
parents:
diff changeset
   339
    
hgs
parents:
diff changeset
   340
    TDataType type; 
hgs
parents:
diff changeset
   341
hgs
parents:
diff changeset
   342
	TPtrC8 mimePtr( *mime == KNullDesC8 ? type.Des8() : mime->Des() );
hgs
parents:
diff changeset
   343
hgs
parents:
diff changeset
   344
    /**
hgs
parents:
diff changeset
   345
    virtual void UpdateLeafObjectL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   346
									const TDesC8& aObject, const TDesC8& aType,
hgs
parents:
diff changeset
   347
									TInt aStatusRef ) = 0;
hgs
parents:
diff changeset
   348
    */
hgs
parents:
diff changeset
   349
    
hgs
parents:
diff changeset
   350
	Adapter()->UpdateLeafObjectL( *iURI , *luid, data, mimePtr, 3);
hgs
parents:
diff changeset
   351
hgs
parents:
diff changeset
   352
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   353
	{
hgs
parents:
diff changeset
   354
		iLog->Log( _L("UpdateLeafL: UpdateLeafObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   355
	}
hgs
parents:
diff changeset
   356
	else
hgs
parents:
diff changeset
   357
	{
hgs
parents:
diff changeset
   358
		iLog->Log( _L("UpdateLeafL UpdateLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   359
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   360
	}
hgs
parents:
diff changeset
   361
hgs
parents:
diff changeset
   362
	CleanupStack::PopAndDestroy(); // loadfile
hgs
parents:
diff changeset
   363
	CleanupStack::PopAndDestroy(); // luid
hgs
parents:
diff changeset
   364
	CleanupStack::PopAndDestroy(); // mime
hgs
parents:
diff changeset
   365
	CleanupStack::PopAndDestroy(); // nodename
hgs
parents:
diff changeset
   366
hgs
parents:
diff changeset
   367
	iLog->Log( _L("UpdateLeafL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   368
hgs
parents:
diff changeset
   369
    return ret;
hgs
parents:
diff changeset
   370
	}	
hgs
parents:
diff changeset
   371
	
hgs
parents:
diff changeset
   372
hgs
parents:
diff changeset
   373
TInt Cdmatest::UpdateLeafDataURLL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   374
	{
hgs
parents:
diff changeset
   375
hgs
parents:
diff changeset
   376
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   377
    // Print to UI
hgs
parents:
diff changeset
   378
    TestModuleIf().Printf( 0, _L("Cdmatest"), _L("UpdateLeafDataL") );
hgs
parents:
diff changeset
   379
hgs
parents:
diff changeset
   380
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Node name") )->Des() ) ;
hgs
parents:
diff changeset
   381
    TPtrC8 http (GetNextStringLC( aItem, _L("http"))->Des() );
hgs
parents:
diff changeset
   382
    TPtrC8 url (GetNextStringLC( aItem, _L("rest of url"))->Des() );
hgs
parents:
diff changeset
   383
	HBufC8 *mime = GetNextStringLC( aItem, _L("mime") ) ;
hgs
parents:
diff changeset
   384
    SetURIL( nodename );
hgs
parents:
diff changeset
   385
    
hgs
parents:
diff changeset
   386
    _LIT8( KTag, "://" );
hgs
parents:
diff changeset
   387
    
hgs
parents:
diff changeset
   388
    HBufC8 *fullurl = HBufC8::NewLC( http.Length() + KTag().Length() + url.Length() );
hgs
parents:
diff changeset
   389
    TPtr8 pfullurl( fullurl->Des() );
hgs
parents:
diff changeset
   390
    pfullurl.Copy( http ) ;
hgs
parents:
diff changeset
   391
    pfullurl.Append( KTag );
hgs
parents:
diff changeset
   392
    pfullurl.Append( url );
hgs
parents:
diff changeset
   393
    TPtrC8 mimePtr( *mime == KNullDesC8 ? KDefaultType() : mime->Des() );
hgs
parents:
diff changeset
   394
    
hgs
parents:
diff changeset
   395
    HBufC8 *luid = GetLuidAllocLC( *iURI );
hgs
parents:
diff changeset
   396
    /**
hgs
parents:
diff changeset
   397
    virtual void UpdateLeafObjectL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   398
									const TDesC8& aObject, const TDesC8& aType,
hgs
parents:
diff changeset
   399
									TInt aStatusRef ) = 0;
hgs
parents:
diff changeset
   400
    */
hgs
parents:
diff changeset
   401
	Adapter()->UpdateLeafObjectL( *iURI , *luid, pfullurl, mimePtr, 3);
hgs
parents:
diff changeset
   402
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   403
		{
hgs
parents:
diff changeset
   404
		iLog->Log( _L("UpdateLeafDataL: UpdateLeafObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   405
		}
hgs
parents:
diff changeset
   406
	else
hgs
parents:
diff changeset
   407
		{
hgs
parents:
diff changeset
   408
		iLog->Log( _L("UpdateLeafDataL UpdateLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   409
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   410
		}
hgs
parents:
diff changeset
   411
	CleanupStack::PopAndDestroy( luid ); // 
hgs
parents:
diff changeset
   412
	CleanupStack::PopAndDestroy( mime ); // mime
hgs
parents:
diff changeset
   413
	CleanupStack::PopAndDestroy(); // url
hgs
parents:
diff changeset
   414
	CleanupStack::PopAndDestroy(); // http
hgs
parents:
diff changeset
   415
	CleanupStack::PopAndDestroy(); // nodename
hgs
parents:
diff changeset
   416
	iLog->Log( _L("UpdateLeafDataL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   417
hgs
parents:
diff changeset
   418
    return ret;
hgs
parents:
diff changeset
   419
	}
hgs
parents:
diff changeset
   420
    
hgs
parents:
diff changeset
   421
TInt Cdmatest::UpdateLeafDataL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   422
	{
hgs
parents:
diff changeset
   423
hgs
parents:
diff changeset
   424
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   425
    // Print to UI
hgs
parents:
diff changeset
   426
   TestModuleIf().Printf( 0, _L("Camtest"), _L("UpdateLeafDataL") );
hgs
parents:
diff changeset
   427
hgs
parents:
diff changeset
   428
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Node name") )->Des() ) ;
hgs
parents:
diff changeset
   429
    TPtrC8 data (GetNextStringLC( aItem, _L("data"))->Des() );
hgs
parents:
diff changeset
   430
	HBufC8 *mime = GetNextStringLC( aItem, _L("mime") ) ;
hgs
parents:
diff changeset
   431
	
hgs
parents:
diff changeset
   432
    SetURIL( nodename );
hgs
parents:
diff changeset
   433
    
hgs
parents:
diff changeset
   434
        
hgs
parents:
diff changeset
   435
    TPtrC8 mimePtr( *mime == KNullDesC8 ? KDefaultType() : mime->Des() );
hgs
parents:
diff changeset
   436
    
hgs
parents:
diff changeset
   437
    TPtrC8 parentURI(RemoveLastSeg(nodename));
hgs
parents:
diff changeset
   438
    HBufC8 *luid = GetLuidAllocLC( parentURI );
hgs
parents:
diff changeset
   439
     
hgs
parents:
diff changeset
   440
//    
hgs
parents:
diff changeset
   441
//    virtual void UpdateLeafObjectL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   442
//									const TDesC8& aObject, const TDesC8& aType,
hgs
parents:
diff changeset
   443
//									TInt aStatusRef ) = 0;
hgs
parents:
diff changeset
   444
//   
hgs
parents:
diff changeset
   445
	Adapter()->UpdateLeafObjectL( *iURI , *luid, data, mimePtr, 3);
hgs
parents:
diff changeset
   446
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   447
		{
hgs
parents:
diff changeset
   448
		iLog->Log( _L("UpdateLeafDataL: UpdateLeafObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   449
		}
hgs
parents:
diff changeset
   450
	else
hgs
parents:
diff changeset
   451
		{
hgs
parents:
diff changeset
   452
		iLog->Log( _L("UpdateLeafDataL UpdateLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   453
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   454
		}
hgs
parents:
diff changeset
   455
	
hgs
parents:
diff changeset
   456
	CleanupStack::PopAndDestroy(); // mime
hgs
parents:
diff changeset
   457
	CleanupStack::PopAndDestroy(); // luid
hgs
parents:
diff changeset
   458
	CleanupStack::PopAndDestroy(); // data
hgs
parents:
diff changeset
   459
	CleanupStack::PopAndDestroy(); // nodename
hgs
parents:
diff changeset
   460
	iLog->Log( _L("UpdateLeafDataL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   461
hgs
parents:
diff changeset
   462
    return ret;
hgs
parents:
diff changeset
   463
	}	
hgs
parents:
diff changeset
   464
			
hgs
parents:
diff changeset
   465
TInt Cdmatest::FetchLeafL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   466
	{
hgs
parents:
diff changeset
   467
hgs
parents:
diff changeset
   468
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   469
    // Print to UI
hgs
parents:
diff changeset
   470
    TestModuleIf().Printf( 0, _L("Camtest"), _L("FetchLeafL") );
hgs
parents:
diff changeset
   471
hgs
parents:
diff changeset
   472
	iResultsFunction = NULL;
hgs
parents:
diff changeset
   473
	
hgs
parents:
diff changeset
   474
    TInt i( 0 );
hgs
parents:
diff changeset
   475
    TPtrC8 nodename ( GetNextStringLC( aItem, _L( "nodename" ) )->Des() ) ;
hgs
parents:
diff changeset
   476
    
hgs
parents:
diff changeset
   477
    //TPtrC datafile;
hgs
parents:
diff changeset
   478
    TPtrC datafile( KNullDesC );
hgs
parents:
diff changeset
   479
    i = aItem.GetNextString ( datafile ) ;
hgs
parents:
diff changeset
   480
    if ( i != KErrNone ) 
hgs
parents:
diff changeset
   481
	    {
hgs
parents:
diff changeset
   482
	    iLog->Log(_L("FetchLeafL: ERROR Reading outfile argument: 0x%X"), i );
hgs
parents:
diff changeset
   483
	    //return i;
hgs
parents:
diff changeset
   484
	    }
hgs
parents:
diff changeset
   485
	else
hgs
parents:
diff changeset
   486
		{
hgs
parents:
diff changeset
   487
		iSaveFileName = datafile;
hgs
parents:
diff changeset
   488
		iLog->Log( _L( " Save file nameis '%S'" ), &iSaveFileName );
hgs
parents:
diff changeset
   489
		iResultsFunction = SaveDataL;
hgs
parents:
diff changeset
   490
		}
hgs
parents:
diff changeset
   491
    
hgs
parents:
diff changeset
   492
	SetURIL(nodename) ;
hgs
parents:
diff changeset
   493
		
hgs
parents:
diff changeset
   494
		/*
hgs
parents:
diff changeset
   495
			void FetchLeafObjectL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   496
								   const TDesC8& aType, TInt aResultsRef,
hgs
parents:
diff changeset
   497
								   TInt aStatusRef );
hgs
parents:
diff changeset
   498
		*/
hgs
parents:
diff changeset
   499
    TPtrC8 parentURI(RemoveLastSeg(nodename));
hgs
parents:
diff changeset
   500
    HBufC8 *luid = GetLuidAllocLC( parentURI );
hgs
parents:
diff changeset
   501
hgs
parents:
diff changeset
   502
	Adapter()->FetchLeafObjectL( *iURI, *luid, KEmptyType, 7, 8 ) ;
hgs
parents:
diff changeset
   503
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   504
		{
hgs
parents:
diff changeset
   505
		iLog->Log( _L("FetchLeafL: FetchLeafObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   506
		}
hgs
parents:
diff changeset
   507
	else
hgs
parents:
diff changeset
   508
		{
hgs
parents:
diff changeset
   509
		iLog->Log( _L("FetchLeafL: FetchLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   510
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   511
		}
hgs
parents:
diff changeset
   512
	CleanupStack::PopAndDestroy( luid );
hgs
parents:
diff changeset
   513
	CleanupStack::PopAndDestroy(  ); // nodename
hgs
parents:
diff changeset
   514
	iLog->Log( _L("FetchLeafL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   515
    return ret;
hgs
parents:
diff changeset
   516
	}	
hgs
parents:
diff changeset
   517
hgs
parents:
diff changeset
   518
hgs
parents:
diff changeset
   519
TInt Cdmatest::ExecuteLeafL( CStifItemParser& aItem )		
hgs
parents:
diff changeset
   520
	{
hgs
parents:
diff changeset
   521
	TInt ret( KErrNone );
hgs
parents:
diff changeset
   522
    // Print to UI
hgs
parents:
diff changeset
   523
    TestModuleIf().Printf( 0, _L("Camtest"), _L("ExecuteLeafL") );
hgs
parents:
diff changeset
   524
hgs
parents:
diff changeset
   525
	iResultsFunction = NULL;
hgs
parents:
diff changeset
   526
	
hgs
parents:
diff changeset
   527
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Nodename") )->Des() ) ;
hgs
parents:
diff changeset
   528
    TPtrC8 data( GetNextStringLC ( aItem, _L("Input file") )->Des() ) ;
hgs
parents:
diff changeset
   529
	
hgs
parents:
diff changeset
   530
	SetURIL(nodename) ;
hgs
parents:
diff changeset
   531
hgs
parents:
diff changeset
   532
		/*
hgs
parents:
diff changeset
   533
			virtual void ExecuteCommandL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   534
							      const TDesC8& aArgument, const TDesC8& aType,
hgs
parents:
diff changeset
   535
								  TInt aStatusRef ) = 0;
hgs
parents:
diff changeset
   536
		*/
hgs
parents:
diff changeset
   537
	TDataType type;
hgs
parents:
diff changeset
   538
	
hgs
parents:
diff changeset
   539
    TPtrC8 parentURI(RemoveLastSeg(nodename));
hgs
parents:
diff changeset
   540
    HBufC8 *luid = GetLuidAllocLC( parentURI );
hgs
parents:
diff changeset
   541
hgs
parents:
diff changeset
   542
	Adapter()->ExecuteCommandL( *iURI, *luid, data, KEmptyType, 11 ) ;
hgs
parents:
diff changeset
   543
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   544
		{
hgs
parents:
diff changeset
   545
		iLog->Log( _L("ExecuteLeafL: ExecuteCommandL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   546
		}
hgs
parents:
diff changeset
   547
	else
hgs
parents:
diff changeset
   548
		{
hgs
parents:
diff changeset
   549
		iLog->Log( _L("ExecuteLeafL: ExecuteCommandL FetchLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   550
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   551
		}
hgs
parents:
diff changeset
   552
	CleanupStack::PopAndDestroy( luid ); // luid
hgs
parents:
diff changeset
   553
	CleanupStack::PopAndDestroy(); // data
hgs
parents:
diff changeset
   554
	CleanupStack::PopAndDestroy(); // nodename
hgs
parents:
diff changeset
   555
	
hgs
parents:
diff changeset
   556
	iLog->Log( _L("ExecuteLeafL: Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   557
hgs
parents:
diff changeset
   558
    return ret;
hgs
parents:
diff changeset
   559
	}
hgs
parents:
diff changeset
   560
	
hgs
parents:
diff changeset
   561
TInt Cdmatest::CompleteCommandsL( CStifItemParser& /*aItem*/ )
hgs
parents:
diff changeset
   562
	{
hgs
parents:
diff changeset
   563
	TRAPD( err, Adapter()->CompleteOutstandingCmdsL() );
hgs
parents:
diff changeset
   564
	delete iAdapter;
hgs
parents:
diff changeset
   565
	iAdapter = NULL;
hgs
parents:
diff changeset
   566
	return err;
hgs
parents:
diff changeset
   567
	}
hgs
parents:
diff changeset
   568
TInt Cdmatest::DeleteObjectL( CStifItemParser& aItem )
hgs
parents:
diff changeset
   569
{
hgs
parents:
diff changeset
   570
	TInt ret( KErrNone );
hgs
parents:
diff changeset
   571
    // Print to UI
hgs
parents:
diff changeset
   572
    TestModuleIf().Printf( 0, _L("Camtest"), _L("DeleteObjectL") );
hgs
parents:
diff changeset
   573
hgs
parents:
diff changeset
   574
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Nodename") )->Des() ) ;
hgs
parents:
diff changeset
   575
hgs
parents:
diff changeset
   576
	SetURIL(nodename) ;
hgs
parents:
diff changeset
   577
hgs
parents:
diff changeset
   578
	HBufC8 *luid = GetLuidAllocLC( *iURI );
hgs
parents:
diff changeset
   579
	Adapter()->DeleteObjectL( *iURI, *luid, 11 ) ;
hgs
parents:
diff changeset
   580
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   581
		{
hgs
parents:
diff changeset
   582
		iLog->Log( _L("DeleteNode: DeleteObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   583
		}
hgs
parents:
diff changeset
   584
	else
hgs
parents:
diff changeset
   585
		{
hgs
parents:
diff changeset
   586
		iLog->Log( _L("DeleteNode: DeleteObjectL FetchLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   587
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   588
		}
hgs
parents:
diff changeset
   589
	CleanupStack::PopAndDestroy( luid ); // luid
hgs
parents:
diff changeset
   590
	CleanupStack::PopAndDestroy(); // nodename	
hgs
parents:
diff changeset
   591
	iLog->Log( _L("ExecuteLeafDataL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   592
hgs
parents:
diff changeset
   593
    return ret;	
hgs
parents:
diff changeset
   594
}
hgs
parents:
diff changeset
   595
	
hgs
parents:
diff changeset
   596
TInt Cdmatest::ExecuteLeafDataL( CStifItemParser& aItem )		
hgs
parents:
diff changeset
   597
	{
hgs
parents:
diff changeset
   598
	TInt ret( KErrNone );
hgs
parents:
diff changeset
   599
hgs
parents:
diff changeset
   600
    // Print to UI
hgs
parents:
diff changeset
   601
    TestModuleIf().Printf( 0, _L("Camtest"), _L("ExecuteLeafL") );
hgs
parents:
diff changeset
   602
hgs
parents:
diff changeset
   603
	iResultsFunction = NULL;
hgs
parents:
diff changeset
   604
	
hgs
parents:
diff changeset
   605
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Nodename") )->Des() ) ;
hgs
parents:
diff changeset
   606
    TPtrC8 data( GetNextStringLC ( aItem, _L("Input data") )->Des() ) ;
hgs
parents:
diff changeset
   607
    
hgs
parents:
diff changeset
   608
	SetURIL(nodename) ;
hgs
parents:
diff changeset
   609
hgs
parents:
diff changeset
   610
		/*
hgs
parents:
diff changeset
   611
			virtual void ExecuteCommandL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   612
							      const TDesC8& aArgument, const TDesC8& aType,
hgs
parents:
diff changeset
   613
								  TInt aStatusRef ) = 0;
hgs
parents:
diff changeset
   614
		*/
hgs
parents:
diff changeset
   615
	HBufC8 *luid = GetLuidAllocLC( *iURI );
hgs
parents:
diff changeset
   616
	Adapter()->ExecuteCommandL( *iURI, *luid, data, KEmptyType, 11 ) ;
hgs
parents:
diff changeset
   617
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   618
		{
hgs
parents:
diff changeset
   619
		iLog->Log( _L("ExecuteLeafDataL: ExecuteCommandL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   620
		}
hgs
parents:
diff changeset
   621
	else
hgs
parents:
diff changeset
   622
		{
hgs
parents:
diff changeset
   623
		iLog->Log( _L("ExecuteLeafDataL: ExecuteCommandL FetchLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   624
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   625
		}
hgs
parents:
diff changeset
   626
	CleanupStack::PopAndDestroy(); // luid
hgs
parents:
diff changeset
   627
	CleanupStack::PopAndDestroy(); // data		
hgs
parents:
diff changeset
   628
	CleanupStack::PopAndDestroy(); // nodename	
hgs
parents:
diff changeset
   629
	iLog->Log( _L("ExecuteLeafDataL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   630
hgs
parents:
diff changeset
   631
    return ret;
hgs
parents:
diff changeset
   632
	}
hgs
parents:
diff changeset
   633
hgs
parents:
diff changeset
   634
hgs
parents:
diff changeset
   635
HBufC8 *Cdmatest::LoadFileLC( const TDesC &aFileName, TDataType &aType )	
hgs
parents:
diff changeset
   636
	{
hgs
parents:
diff changeset
   637
	RFs fs ;
hgs
parents:
diff changeset
   638
	LEAVE_IF_ERROR( fs.Connect(), _L( "Could not connect fileserver: %d"  ) );
hgs
parents:
diff changeset
   639
	
hgs
parents:
diff changeset
   640
	CleanupClosePushL( fs );
hgs
parents:
diff changeset
   641
	RFile file ;
hgs
parents:
diff changeset
   642
	LEAVE_IF_ERROR( file.Open(fs,aFileName,EFileRead), _L( "Could not open file: %d" ) );
hgs
parents:
diff changeset
   643
	
hgs
parents:
diff changeset
   644
	
hgs
parents:
diff changeset
   645
	
hgs
parents:
diff changeset
   646
	CleanupClosePushL( file );
hgs
parents:
diff changeset
   647
	TInt dataSize ;
hgs
parents:
diff changeset
   648
	LEAVE_IF_ERROR( file.Size( dataSize ), _L( "Could not get file size: %d" ) );
hgs
parents:
diff changeset
   649
	HBufC8 *nodedata = HBufC8::NewL ( dataSize );
hgs
parents:
diff changeset
   650
	CleanupStack::PushL( nodedata );
hgs
parents:
diff changeset
   651
	TPtr8 nodedataptr( nodedata->Des() );
hgs
parents:
diff changeset
   652
	LEAVE_IF_ERROR( file.Read( nodedataptr ), _L( "Could not read file: %d" ) );
hgs
parents:
diff changeset
   653
	TDataRecognitionResult aDataType;
hgs
parents:
diff changeset
   654
	RApaLsSession ls ;
hgs
parents:
diff changeset
   655
	TInt err( ls.Connect() );
hgs
parents:
diff changeset
   656
	if ( err == KErrNone )
hgs
parents:
diff changeset
   657
		{
hgs
parents:
diff changeset
   658
		CleanupClosePushL( ls );
hgs
parents:
diff changeset
   659
		err = ls.RecognizeData(aFileName, nodedataptr, aDataType)  ;
hgs
parents:
diff changeset
   660
		if ( err == KErrNone )
hgs
parents:
diff changeset
   661
			{
hgs
parents:
diff changeset
   662
			aType = aDataType.iDataType;
hgs
parents:
diff changeset
   663
			}
hgs
parents:
diff changeset
   664
		else
hgs
parents:
diff changeset
   665
			{
hgs
parents:
diff changeset
   666
			iLog->Log( _L("LoadFileLC: WARNING Failed to get type: %d" ), err );
hgs
parents:
diff changeset
   667
			aType = TDataType( KDefaultType );
hgs
parents:
diff changeset
   668
			}	
hgs
parents:
diff changeset
   669
		CleanupStack::PopAndDestroy( &ls ); 
hgs
parents:
diff changeset
   670
		}
hgs
parents:
diff changeset
   671
	else
hgs
parents:
diff changeset
   672
		{
hgs
parents:
diff changeset
   673
		iLog->Log( _L("LoadFileLC: WARNING Failed to connect rapalssession: %d" ), err );
hgs
parents:
diff changeset
   674
		}	
hgs
parents:
diff changeset
   675
	CleanupStack::Pop( nodedata );
hgs
parents:
diff changeset
   676
	CleanupStack::PopAndDestroy( &file ); 
hgs
parents:
diff changeset
   677
	CleanupStack::PopAndDestroy( &fs ); 
hgs
parents:
diff changeset
   678
	CleanupStack::PushL( nodedata );
hgs
parents:
diff changeset
   679
	return nodedata ;
hgs
parents:
diff changeset
   680
	}
hgs
parents:
diff changeset
   681
hgs
parents:
diff changeset
   682
HBufC8 *Cdmatest::LoadFileLC( const TDesC8 &aFileName, TDataType &aType )	
hgs
parents:
diff changeset
   683
	{
hgs
parents:
diff changeset
   684
	TFileName fn ;
hgs
parents:
diff changeset
   685
	fn.Copy( aFileName );
hgs
parents:
diff changeset
   686
	return LoadFileLC( fn, aType );
hgs
parents:
diff changeset
   687
	}
hgs
parents:
diff changeset
   688
	
hgs
parents:
diff changeset
   689
hgs
parents:
diff changeset
   690
void Cdmatest::SaveDataL( TInt /*aResultsRef*/, CBufBase& aObject,
hgs
parents:
diff changeset
   691
							  const TDesC8& aType ) 
hgs
parents:
diff changeset
   692
	{
hgs
parents:
diff changeset
   693
	iLog->Log( _L8( "Saving data of type: '%S'" ), &aType );
hgs
parents:
diff changeset
   694
	RFs fs;
hgs
parents:
diff changeset
   695
	User::LeaveIfError( fs.Connect() );
hgs
parents:
diff changeset
   696
	CleanupClosePushL( fs );
hgs
parents:
diff changeset
   697
	RFile file;
hgs
parents:
diff changeset
   698
	User::LeaveIfError( file.Replace ( fs, iSaveFileName, EFileWrite ) );
hgs
parents:
diff changeset
   699
	CleanupClosePushL( file );
hgs
parents:
diff changeset
   700
	TPtrC8 p( aObject.Ptr( 0 ) );
hgs
parents:
diff changeset
   701
	User::LeaveIfError( file.Write( p ) );
hgs
parents:
diff changeset
   702
	CleanupStack::PopAndDestroy( 2 ); // file, fs
hgs
parents:
diff changeset
   703
	}
hgs
parents:
diff changeset
   704
							  
hgs
parents:
diff changeset
   705
		
hgs
parents:
diff changeset
   706
	
hgs
parents:
diff changeset
   707
void Cdmatest::FetchNodeResultsL( TInt /*aResultsRef*/, CBufBase& aObject,
hgs
parents:
diff changeset
   708
							  const TDesC8& /*aType*/ )
hgs
parents:
diff changeset
   709
	{
hgs
parents:
diff changeset
   710
	TPtrC8 ptr( aObject.Ptr( 0 ) );	
hgs
parents:
diff changeset
   711
	iLog->Log( _L8("FetchNodeResultsL for '%S': '%S'" ), iURI, &ptr );
hgs
parents:
diff changeset
   712
	
hgs
parents:
diff changeset
   713
	if ( ptr.Length() > 0 )
hgs
parents:
diff changeset
   714
		{
hgs
parents:
diff changeset
   715
		TPtrC8 last( LastURISeg( ptr ) );
hgs
parents:
diff changeset
   716
		HBufC8 *oldUri = HBufC8::NewL( iURI->Length() );
hgs
parents:
diff changeset
   717
		(*oldUri) = *iURI; 
hgs
parents:
diff changeset
   718
		do 
hgs
parents:
diff changeset
   719
			{
hgs
parents:
diff changeset
   720
			iLog->Log ( _L8( " Node: '%S' "), &last );
hgs
parents:
diff changeset
   721
			HBufC8 *nUri = HBufC8::NewLC( oldUri->Length() + 1 + last.Length() );
hgs
parents:
diff changeset
   722
			nUri->Des().Copy( *oldUri ) ;
hgs
parents:
diff changeset
   723
			nUri->Des().Append( '/' );
hgs
parents:
diff changeset
   724
			nUri->Des().Append( last );
hgs
parents:
diff changeset
   725
			
hgs
parents:
diff changeset
   726
			SetURIL( nUri );
hgs
parents:
diff changeset
   727
			//iResultsFunction = FetchNodeResultsL;
hgs
parents:
diff changeset
   728
			
hgs
parents:
diff changeset
   729
		    //TPtrC8 parentURI(RemoveLastSeg(*nUri));
hgs
parents:
diff changeset
   730
		    //HBufC8 *luid = GetLuidAllocLC( parentURI );
hgs
parents:
diff changeset
   731
		    CleanupStack::Pop( nUri );
hgs
parents:
diff changeset
   732
			
hgs
parents:
diff changeset
   733
			HBufC8 *luid = GetLuidAllocLC( *iURI );
hgs
parents:
diff changeset
   734
			
hgs
parents:
diff changeset
   735
			Adapter()->ChildURIListL( *nUri, KNullDesC8, *iEmptyMappingInfoArray, 4, 5 );//Dipak
hgs
parents:
diff changeset
   736
			
hgs
parents:
diff changeset
   737
			CleanupStack::PopAndDestroy( luid ); 			
hgs
parents:
diff changeset
   738
			
hgs
parents:
diff changeset
   739
			ptr.Set( RemoveLastURISeg( ptr ) );
hgs
parents:
diff changeset
   740
			last.Set( LastURISeg( ptr ) );
hgs
parents:
diff changeset
   741
			
hgs
parents:
diff changeset
   742
			}
hgs
parents:
diff changeset
   743
		while (last != KNullDesC8);	
hgs
parents:
diff changeset
   744
		}
hgs
parents:
diff changeset
   745
	
hgs
parents:
diff changeset
   746
	}
hgs
parents:
diff changeset
   747
	
hgs
parents:
diff changeset
   748
hgs
parents:
diff changeset
   749
	
hgs
parents:
diff changeset
   750
TPtrC8 Cdmatest::LastURISeg( const TDesC8& aURI )
hgs
parents:
diff changeset
   751
	{
hgs
parents:
diff changeset
   752
	TInt i;
hgs
parents:
diff changeset
   753
	for( i = aURI.Length() - 1; i >= 0; i-- ) 
hgs
parents:
diff changeset
   754
		{
hgs
parents:
diff changeset
   755
		if( aURI[i] == '/' )
hgs
parents:
diff changeset
   756
			{
hgs
parents:
diff changeset
   757
			break;
hgs
parents:
diff changeset
   758
			}
hgs
parents:
diff changeset
   759
		}
hgs
parents:
diff changeset
   760
hgs
parents:
diff changeset
   761
	if( i == 0 )
hgs
parents:
diff changeset
   762
		{
hgs
parents:
diff changeset
   763
		return aURI;
hgs
parents:
diff changeset
   764
		}
hgs
parents:
diff changeset
   765
	else
hgs
parents:
diff changeset
   766
		{
hgs
parents:
diff changeset
   767
		return aURI.Mid( i+1 );
hgs
parents:
diff changeset
   768
		}
hgs
parents:
diff changeset
   769
	}
hgs
parents:
diff changeset
   770
TPtrC8 Cdmatest::RemoveLastSeg(const TDesC8& aURI)
hgs
parents:
diff changeset
   771
	{
hgs
parents:
diff changeset
   772
	TInt i;
hgs
parents:
diff changeset
   773
	for(i=aURI.Length()-1;i>=0;i--)
hgs
parents:
diff changeset
   774
		{
hgs
parents:
diff changeset
   775
		if(aURI[i]==KNSmlDMUriSeparator)
hgs
parents:
diff changeset
   776
			{
hgs
parents:
diff changeset
   777
			break;
hgs
parents:
diff changeset
   778
			}
hgs
parents:
diff changeset
   779
		}
hgs
parents:
diff changeset
   780
hgs
parents:
diff changeset
   781
	if(i>0)
hgs
parents:
diff changeset
   782
		{
hgs
parents:
diff changeset
   783
		return aURI.Left(i);
hgs
parents:
diff changeset
   784
		}
hgs
parents:
diff changeset
   785
	else
hgs
parents:
diff changeset
   786
		{
hgs
parents:
diff changeset
   787
		return KNullDesC8();
hgs
parents:
diff changeset
   788
		}
hgs
parents:
diff changeset
   789
	}
hgs
parents:
diff changeset
   790
hgs
parents:
diff changeset
   791
// ------------------------------------------------------------------------------------------------
hgs
parents:
diff changeset
   792
// TPtrC8 Cdmatest::RemoveLastURISeg(const TDesC8& aURI)
hgs
parents:
diff changeset
   793
// returns parent uri, i.e. removes last uri segment
hgs
parents:
diff changeset
   794
// ------------------------------------------------------------------------------------------------
hgs
parents:
diff changeset
   795
TPtrC8 Cdmatest::RemoveLastURISeg( const TDesC8& aURI )
hgs
parents:
diff changeset
   796
	{
hgs
parents:
diff changeset
   797
	TInt i;
hgs
parents:
diff changeset
   798
	for ( i = aURI.Length() - 1; i >= 0 ; i-- )
hgs
parents:
diff changeset
   799
		{
hgs
parents:
diff changeset
   800
		if( aURI[i] == '/' )
hgs
parents:
diff changeset
   801
			{
hgs
parents:
diff changeset
   802
			break;
hgs
parents:
diff changeset
   803
			}
hgs
parents:
diff changeset
   804
		}
hgs
parents:
diff changeset
   805
	if ( i > -1 )
hgs
parents:
diff changeset
   806
		{
hgs
parents:
diff changeset
   807
		return aURI.Left( i );	
hgs
parents:
diff changeset
   808
		}
hgs
parents:
diff changeset
   809
	else
hgs
parents:
diff changeset
   810
		{
hgs
parents:
diff changeset
   811
		return KNullDesC8();
hgs
parents:
diff changeset
   812
		}
hgs
parents:
diff changeset
   813
	}	
hgs
parents:
diff changeset
   814
	
hgs
parents:
diff changeset
   815
TPtrC Cdmatest::RemoveLastURISeg( const TDesC& aURI )
hgs
parents:
diff changeset
   816
	{
hgs
parents:
diff changeset
   817
	TInt i;
hgs
parents:
diff changeset
   818
	for ( i = aURI.Length() - 1; i >= 0 ; i-- )
hgs
parents:
diff changeset
   819
		{
hgs
parents:
diff changeset
   820
		if( aURI[i] == '/' )
hgs
parents:
diff changeset
   821
			{
hgs
parents:
diff changeset
   822
			break;
hgs
parents:
diff changeset
   823
			}
hgs
parents:
diff changeset
   824
		}
hgs
parents:
diff changeset
   825
	if ( i > -1 )
hgs
parents:
diff changeset
   826
		{
hgs
parents:
diff changeset
   827
		return aURI.Left( i );	
hgs
parents:
diff changeset
   828
		}
hgs
parents:
diff changeset
   829
	else
hgs
parents:
diff changeset
   830
hgs
parents:
diff changeset
   831
		{
hgs
parents:
diff changeset
   832
		return KNullDesC();
hgs
parents:
diff changeset
   833
		}
hgs
parents:
diff changeset
   834
	}		
hgs
parents:
diff changeset
   835
	
hgs
parents:
diff changeset
   836
void Cdmatest::SetURIL( const TDesC& aURI )
hgs
parents:
diff changeset
   837
	{
hgs
parents:
diff changeset
   838
	if ( iURI != NULL )
hgs
parents:
diff changeset
   839
		{
hgs
parents:
diff changeset
   840
		delete iURI ;
hgs
parents:
diff changeset
   841
		iURI = NULL;
hgs
parents:
diff changeset
   842
		}
hgs
parents:
diff changeset
   843
	iURI = HBufC8::NewL( aURI.Length() ) ;
hgs
parents:
diff changeset
   844
	iURI->Des().Copy( aURI );
hgs
parents:
diff changeset
   845
	}
hgs
parents:
diff changeset
   846
	
hgs
parents:
diff changeset
   847
void Cdmatest::SetURIL( const TDesC8& aURI )
hgs
parents:
diff changeset
   848
	{
hgs
parents:
diff changeset
   849
	if ( iURI != NULL )
hgs
parents:
diff changeset
   850
		{
hgs
parents:
diff changeset
   851
		delete iURI ;
hgs
parents:
diff changeset
   852
		iURI = NULL;
hgs
parents:
diff changeset
   853
		}
hgs
parents:
diff changeset
   854
	iURI = HBufC8::NewL( aURI.Length() ) ;
hgs
parents:
diff changeset
   855
	iURI->Des().Copy( aURI );
hgs
parents:
diff changeset
   856
	}	
hgs
parents:
diff changeset
   857
hgs
parents:
diff changeset
   858
void Cdmatest::SetURIL( HBufC8* aURI )
hgs
parents:
diff changeset
   859
	{
hgs
parents:
diff changeset
   860
	if ( iURI != NULL )
hgs
parents:
diff changeset
   861
		{
hgs
parents:
diff changeset
   862
		delete iURI ;
hgs
parents:
diff changeset
   863
		iURI = NULL;
hgs
parents:
diff changeset
   864
		}
hgs
parents:
diff changeset
   865
	iURI = aURI ;
hgs
parents:
diff changeset
   866
	}
hgs
parents:
diff changeset
   867
		
hgs
parents:
diff changeset
   868
		
hgs
parents:
diff changeset
   869
		
hgs
parents:
diff changeset
   870
void Cdmatest::SetResultsL( 
hgs
parents:
diff changeset
   871
	TInt aResultsRef, 
hgs
parents:
diff changeset
   872
	CBufBase& aObject,
hgs
parents:
diff changeset
   873
	const TDesC8& aType )
hgs
parents:
diff changeset
   874
	{
hgs
parents:
diff changeset
   875
	TPtrC8 ptr( aObject.Ptr(0) );
hgs
parents:
diff changeset
   876
	iLog->Log( _L8( "SetResults, ref=%d, object='%S', type='%S'" ), aResultsRef, &ptr, &aType );
hgs
parents:
diff changeset
   877
	if ( iResultsFunction )
hgs
parents:
diff changeset
   878
		{
hgs
parents:
diff changeset
   879
		(this->*iResultsFunction)( aResultsRef, aObject, aType );
hgs
parents:
diff changeset
   880
		iResultsFunction = NULL ;
hgs
parents:
diff changeset
   881
		}
hgs
parents:
diff changeset
   882
	
hgs
parents:
diff changeset
   883
	}
hgs
parents:
diff changeset
   884
hgs
parents:
diff changeset
   885
hgs
parents:
diff changeset
   886
void Cdmatest::SetStatusL( TInt aStatusRef,
hgs
parents:
diff changeset
   887
							 MSmlDmAdapter::TError aErrorCode ) 
hgs
parents:
diff changeset
   888
	{
hgs
parents:
diff changeset
   889
	iStatus = aErrorCode ;
hgs
parents:
diff changeset
   890
	iLog->Log( _L( "SetStatusL, ref=%d, code=%d" ), aStatusRef, aErrorCode );
hgs
parents:
diff changeset
   891
	
hgs
parents:
diff changeset
   892
	
hgs
parents:
diff changeset
   893
	}
hgs
parents:
diff changeset
   894
	
hgs
parents:
diff changeset
   895
void Cdmatest::SetMappingL( const TDesC8& aURI, const TDesC8& aLUID ) 
hgs
parents:
diff changeset
   896
	{
hgs
parents:
diff changeset
   897
	iLog->Log( _L8( "SetMappingL, aURI='%s', aLUID='%s'" ), aURI.Ptr(), aLUID.Ptr() );	
hgs
parents:
diff changeset
   898
	
hgs
parents:
diff changeset
   899
	iMappingTable.Append(TMapping( aURI, aLUID ) )	;
hgs
parents:
diff changeset
   900
	}
hgs
parents:
diff changeset
   901
	
hgs
parents:
diff changeset
   902
HBufC8* Cdmatest::GetLuidAllocL( const TDesC8& aURI ) 
hgs
parents:
diff changeset
   903
	{
hgs
parents:
diff changeset
   904
	iLog->Log( _L8( "GetLuidAllocL, aURI='%S'" ), &aURI );		
hgs
parents:
diff changeset
   905
	HBufC8 *res = NULL;		
hgs
parents:
diff changeset
   906
	for( TInt i(0); i < iMappingTable.Count(); i++ )	
hgs
parents:
diff changeset
   907
		{
hgs
parents:
diff changeset
   908
		if ( aURI == iMappingTable[i].iURI )
hgs
parents:
diff changeset
   909
			{
hgs
parents:
diff changeset
   910
			res = iMappingTable[i].iLuid.AllocL();
hgs
parents:
diff changeset
   911
			}
hgs
parents:
diff changeset
   912
		}
hgs
parents:
diff changeset
   913
	if ( res == NULL )
hgs
parents:
diff changeset
   914
		{
hgs
parents:
diff changeset
   915
		res = HBufC8::NewL( 0 );
hgs
parents:
diff changeset
   916
		}
hgs
parents:
diff changeset
   917
	iLog->Log( _L8( "GetLuidAllocL, response='%S'" ), res );
hgs
parents:
diff changeset
   918
	return res;
hgs
parents:
diff changeset
   919
	}	    
hgs
parents:
diff changeset
   920
    
hgs
parents:
diff changeset
   921
HBufC8* Cdmatest::GetLuidAllocLC( const TDesC8& aURI ) 
hgs
parents:
diff changeset
   922
	{
hgs
parents:
diff changeset
   923
	iLog->Log( _L8( "GetLuidAllocL, aURI='%S'" ), &aURI );
hgs
parents:
diff changeset
   924
	HBufC8 *res = NULL;		
hgs
parents:
diff changeset
   925
	for( TInt i(0); i < iMappingTable.Count(); i++ )	
hgs
parents:
diff changeset
   926
		{
hgs
parents:
diff changeset
   927
		if ( aURI == iMappingTable[i].iURI )
hgs
parents:
diff changeset
   928
			{
hgs
parents:
diff changeset
   929
			res = iMappingTable[i].iLuid.AllocLC();
hgs
parents:
diff changeset
   930
			break;
hgs
parents:
diff changeset
   931
			}
hgs
parents:
diff changeset
   932
		}
hgs
parents:
diff changeset
   933
	if ( res == NULL )
hgs
parents:
diff changeset
   934
		{
hgs
parents:
diff changeset
   935
		res = HBufC8::NewLC( 0 );
hgs
parents:
diff changeset
   936
		}
hgs
parents:
diff changeset
   937
	iLog->Log( _L8( "GetLuidAllocLC, response='%S'" ), res );
hgs
parents:
diff changeset
   938
	return res ;
hgs
parents:
diff changeset
   939
	}	
hgs
parents:
diff changeset
   940
    	
hgs
parents:
diff changeset
   941
#ifdef __TARM_SYMBIAN_CONVERGENCY
hgs
parents:
diff changeset
   942
    
hgs
parents:
diff changeset
   943
void Cdmatest::GetMappingInfoListL( const TDesC8& /*aURI*/,
hgs
parents:
diff changeset
   944
								CArrayFix<TSmlDmMappingInfo>& /*aSegmentList*/ )
hgs
parents:
diff changeset
   945
	{
hgs
parents:
diff changeset
   946
	// do nothing
hgs
parents:
diff changeset
   947
	}								
hgs
parents:
diff changeset
   948
hgs
parents:
diff changeset
   949
#else
hgs
parents:
diff changeset
   950
// nothing
hgs
parents:
diff changeset
   951
#endif
hgs
parents:
diff changeset
   952
//***************************************************************************
hgs
parents:
diff changeset
   953
//  End of File