omads/omadsextensions/adapters/mediads/src/changefinder.cpp
author hgs
Tue, 13 Jul 2010 03:39:25 +0530
changeset 40 b63e67867dcd
permissions -rw-r--r--
201025
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
40
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 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:  Part of SyncML Data Synchronization Plug In Adapter
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 "changefinder.h"
hgs
parents:
diff changeset
    20
#include "logger.h"
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
const TUint KSnapshotFormatVersion ( 0xf0000001 ); // format version
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    25
// CChangeFinder::NewL
hgs
parents:
diff changeset
    26
// Static function to create CChangeFider object(s)
hgs
parents:
diff changeset
    27
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    28
CChangeFinder* CChangeFinder::NewL( MSmlSyncRelationship& aSyncRelationship, TKeyArrayFix aKey,
hgs
parents:
diff changeset
    29
        TBool& aHasHistory, TInt aStreamUid )
hgs
parents:
diff changeset
    30
    {
hgs
parents:
diff changeset
    31
    CChangeFinder* self = new (ELeave) CChangeFinder( aSyncRelationship, aKey, aStreamUid );
hgs
parents:
diff changeset
    32
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
    33
    self->ConstructL( aHasHistory );
hgs
parents:
diff changeset
    34
    CleanupStack::Pop( self );
hgs
parents:
diff changeset
    35
    return self;
hgs
parents:
diff changeset
    36
    }
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    39
// CChangeFinder::CChangeFinder
hgs
parents:
diff changeset
    40
// Constructor for the class
hgs
parents:
diff changeset
    41
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    42
CChangeFinder::CChangeFinder( MSmlSyncRelationship& aSyncRelationship, TKeyArrayFix aKey, TInt aStreamUid ) :
hgs
parents:
diff changeset
    43
iSyncRelationship( aSyncRelationship ),
hgs
parents:
diff changeset
    44
iKey(aKey),
hgs
parents:
diff changeset
    45
iStreamUid( aStreamUid ),
hgs
parents:
diff changeset
    46
iDataStoreUid( KErrNotFound )
hgs
parents:
diff changeset
    47
    {
hgs
parents:
diff changeset
    48
        
hgs
parents:
diff changeset
    49
    }
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    52
// CChangeFinder::~CChangeFinder
hgs
parents:
diff changeset
    53
// Destructor for the class, closes the ChangeFinder and writes snapshot to stream
hgs
parents:
diff changeset
    54
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    55
CChangeFinder::~CChangeFinder()
hgs
parents:
diff changeset
    56
    {
hgs
parents:
diff changeset
    57
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
    58
    TInt error;
hgs
parents:
diff changeset
    59
    TRAP( error, CloseL() );
hgs
parents:
diff changeset
    60
    if ( error != KErrNone )
hgs
parents:
diff changeset
    61
        {
hgs
parents:
diff changeset
    62
        LOGGER_WRITE( "CChangeFinder::~CChangeFinder, CloseL failed." );
hgs
parents:
diff changeset
    63
        }
hgs
parents:
diff changeset
    64
    
hgs
parents:
diff changeset
    65
    delete iCurrentSnapshot;
hgs
parents:
diff changeset
    66
    iCurrentSnapshot = NULL;
hgs
parents:
diff changeset
    67
    delete iOldSnapshot;
hgs
parents:
diff changeset
    68
    iOldSnapshot = NULL;
hgs
parents:
diff changeset
    69
    
hgs
parents:
diff changeset
    70
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
    71
    }
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    74
// CChangeFinder::ConstructL
hgs
parents:
diff changeset
    75
// 2nd phase constructor for the class, reads snapshot from stream
hgs
parents:
diff changeset
    76
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    77
void CChangeFinder::ConstructL( TBool& aHasHistory )
hgs
parents:
diff changeset
    78
    {
hgs
parents:
diff changeset
    79
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
    80
    
hgs
parents:
diff changeset
    81
    TUid streamId;
hgs
parents:
diff changeset
    82
    streamId.iUid = iStreamUid;
hgs
parents:
diff changeset
    83
    
hgs
parents:
diff changeset
    84
    aHasHistory = iSyncRelationship.IsStreamPresentL(streamId);
hgs
parents:
diff changeset
    85
    
hgs
parents:
diff changeset
    86
    if ( aHasHistory )
hgs
parents:
diff changeset
    87
        {
hgs
parents:
diff changeset
    88
        LOGGER_WRITE("CChangeFinder::ConstructL, history exists.");
hgs
parents:
diff changeset
    89
        RReadStream readStream;
hgs
parents:
diff changeset
    90
        iSyncRelationship.OpenReadStreamLC(readStream, streamId);
hgs
parents:
diff changeset
    91
        
hgs
parents:
diff changeset
    92
        // Read the index, first create snapshot array
hgs
parents:
diff changeset
    93
        iOldSnapshot = new (ELeave) CSnapshotArray( KSnapshotGranularity );
hgs
parents:
diff changeset
    94
        
hgs
parents:
diff changeset
    95
        // Read used format version
hgs
parents:
diff changeset
    96
        TUint formatVer = readStream.ReadUint32L();
hgs
parents:
diff changeset
    97
        if ( formatVer != KSnapshotFormatVersion )
hgs
parents:
diff changeset
    98
            {
hgs
parents:
diff changeset
    99
            // Wrong version, do not try to import data
hgs
parents:
diff changeset
   100
            LOGGER_WRITE("CChangeFinder::ConstructL, Wrong format version -> no history");
hgs
parents:
diff changeset
   101
            aHasHistory = EFalse;
hgs
parents:
diff changeset
   102
            CleanupStack::PopAndDestroy( &readStream );
hgs
parents:
diff changeset
   103
            TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   104
            return;
hgs
parents:
diff changeset
   105
            }
hgs
parents:
diff changeset
   106
        
hgs
parents:
diff changeset
   107
        // Read item count
hgs
parents:
diff changeset
   108
        TInt count = readStream.ReadUint32L();
hgs
parents:
diff changeset
   109
        // Read items
hgs
parents:
diff changeset
   110
        for ( TInt i=0; i<count; i++ )
hgs
parents:
diff changeset
   111
            {
hgs
parents:
diff changeset
   112
            TSnapshotItem item;
hgs
parents:
diff changeset
   113
            item.InternalizeL( readStream );
hgs
parents:
diff changeset
   114
            iOldSnapshot->InsertIsqL( item, iKey );
hgs
parents:
diff changeset
   115
            }
hgs
parents:
diff changeset
   116
hgs
parents:
diff changeset
   117
        CleanupStack::PopAndDestroy( &readStream );
hgs
parents:
diff changeset
   118
        }
hgs
parents:
diff changeset
   119
    else
hgs
parents:
diff changeset
   120
        {
hgs
parents:
diff changeset
   121
        LOGGER_WRITE("CChangeFinder::ConstructL, no sync history.");
hgs
parents:
diff changeset
   122
        }
hgs
parents:
diff changeset
   123
    
hgs
parents:
diff changeset
   124
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   125
    }
hgs
parents:
diff changeset
   126
hgs
parents:
diff changeset
   127
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   128
// CChangeFinder::CloseL
hgs
parents:
diff changeset
   129
// Closes ChangeFinder object and writes snapshot to stream
hgs
parents:
diff changeset
   130
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   131
void CChangeFinder::CloseL()
hgs
parents:
diff changeset
   132
    {
hgs
parents:
diff changeset
   133
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   134
    
hgs
parents:
diff changeset
   135
    // Write to stream
hgs
parents:
diff changeset
   136
    RWriteStream writeStream;
hgs
parents:
diff changeset
   137
    
hgs
parents:
diff changeset
   138
    TUid streamId;
hgs
parents:
diff changeset
   139
    streamId.iUid = iStreamUid; 
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
    // Open write stream
hgs
parents:
diff changeset
   142
    iSyncRelationship.OpenWriteStreamLC( writeStream, streamId );
hgs
parents:
diff changeset
   143
    
hgs
parents:
diff changeset
   144
    // Write used format version
hgs
parents:
diff changeset
   145
    writeStream.WriteUint32L( KSnapshotFormatVersion );
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
    // Write item count
hgs
parents:
diff changeset
   148
    TInt count(0);
hgs
parents:
diff changeset
   149
    if ( iOldSnapshot )
hgs
parents:
diff changeset
   150
        {
hgs
parents:
diff changeset
   151
        count = iOldSnapshot->Count();
hgs
parents:
diff changeset
   152
        }
hgs
parents:
diff changeset
   153
    writeStream.WriteUint32L(count);
hgs
parents:
diff changeset
   154
    
hgs
parents:
diff changeset
   155
    // Write items
hgs
parents:
diff changeset
   156
    for (TInt i=0; i<count; i++)
hgs
parents:
diff changeset
   157
        {
hgs
parents:
diff changeset
   158
        const TSnapshotItem& item = iOldSnapshot->At( i );
hgs
parents:
diff changeset
   159
        item.ExternalizeL( writeStream );
hgs
parents:
diff changeset
   160
        }
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
    writeStream.CommitL();
hgs
parents:
diff changeset
   163
    CleanupStack::PopAndDestroy( &writeStream );
hgs
parents:
diff changeset
   164
    
hgs
parents:
diff changeset
   165
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   166
    }
hgs
parents:
diff changeset
   167
hgs
parents:
diff changeset
   168
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   169
// CChangeFinder::ResetL
hgs
parents:
diff changeset
   170
// Resets synchronization history, all contetn is considered new after this call
hgs
parents:
diff changeset
   171
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   172
void CChangeFinder::ResetL()
hgs
parents:
diff changeset
   173
    {
hgs
parents:
diff changeset
   174
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   175
    
hgs
parents:
diff changeset
   176
    // Delete old change information
hgs
parents:
diff changeset
   177
    if ( iOldSnapshot )
hgs
parents:
diff changeset
   178
        {
hgs
parents:
diff changeset
   179
        LOGGER_WRITE("iOldSnapshot->Reset()");
hgs
parents:
diff changeset
   180
        iOldSnapshot->Reset();
hgs
parents:
diff changeset
   181
        }
hgs
parents:
diff changeset
   182
    
hgs
parents:
diff changeset
   183
    // Write 'null' data to file, 
hgs
parents:
diff changeset
   184
    // this removes change history from the file
hgs
parents:
diff changeset
   185
    CloseL();
hgs
parents:
diff changeset
   186
    
hgs
parents:
diff changeset
   187
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   188
    }
hgs
parents:
diff changeset
   189
hgs
parents:
diff changeset
   190
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   191
// CChangeFinder::FindChangedItemsL
hgs
parents:
diff changeset
   192
// Compares snapshots, finds changed items
hgs
parents:
diff changeset
   193
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   194
void CChangeFinder::FindChangedItemsL( CNSmlDataItemUidSet& aChangedUids )
hgs
parents:
diff changeset
   195
    {   
hgs
parents:
diff changeset
   196
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   197
    
hgs
parents:
diff changeset
   198
    if ( !iCurrentSnapshot )
hgs
parents:
diff changeset
   199
        {
hgs
parents:
diff changeset
   200
        LOGGER_WRITE( "CChangeFinder::FindChangedItemsL leaved, no current snapshot." );
hgs
parents:
diff changeset
   201
        User::Leave( KErrNotFound );
hgs
parents:
diff changeset
   202
        }
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
    if ( !iOldSnapshot )
hgs
parents:
diff changeset
   205
        {
hgs
parents:
diff changeset
   206
        LOGGER_WRITE( "CChangeFinder::FindChangedItemsL leaved, no old snapshot." );
hgs
parents:
diff changeset
   207
        User::Leave( KErrNotFound );
hgs
parents:
diff changeset
   208
        }
hgs
parents:
diff changeset
   209
        
hgs
parents:
diff changeset
   210
    TInt index;
hgs
parents:
diff changeset
   211
    TInt count = iCurrentSnapshot->Count();
hgs
parents:
diff changeset
   212
    LOGGER_WRITE_1( "CChangeFinder::FindChangedItemsL count: %d", count );
hgs
parents:
diff changeset
   213
    for ( TInt i=0; i < count; i++ )
hgs
parents:
diff changeset
   214
        {
hgs
parents:
diff changeset
   215
        const TSnapshotItem& currentItem = iCurrentSnapshot->At( i );
hgs
parents:
diff changeset
   216
        // Find this entry from the old snapshot
hgs
parents:
diff changeset
   217
        if ( iOldSnapshot->FindIsq( currentItem, iKey, index ) == KErrNone)
hgs
parents:
diff changeset
   218
            {
hgs
parents:
diff changeset
   219
            // This is the old item
hgs
parents:
diff changeset
   220
            TSnapshotItem& oldItem = iOldSnapshot->At( index );
hgs
parents:
diff changeset
   221
            // Compare hash to see whether this was changed
hgs
parents:
diff changeset
   222
            if ( oldItem.Hash().Compare( currentItem.Hash() ) != 0
hgs
parents:
diff changeset
   223
                    || oldItem.ParentId() != currentItem.ParentId() )
hgs
parents:
diff changeset
   224
                {
hgs
parents:
diff changeset
   225
                aChangedUids.AddItem( currentItem.ItemId() );
hgs
parents:
diff changeset
   226
                //LOGGER_WRITE_1( "Item %d was changed.", currentItem.ItemId() );  
hgs
parents:
diff changeset
   227
                }
hgs
parents:
diff changeset
   228
            }
hgs
parents:
diff changeset
   229
        }
hgs
parents:
diff changeset
   230
    
hgs
parents:
diff changeset
   231
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   232
    }
hgs
parents:
diff changeset
   233
hgs
parents:
diff changeset
   234
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   235
// CChangeFinder::FindDeletedItemsL
hgs
parents:
diff changeset
   236
// Compares snapshots, finds deleted items
hgs
parents:
diff changeset
   237
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   238
void CChangeFinder::FindDeletedItemsL( CNSmlDataItemUidSet& aDeletedUids )
hgs
parents:
diff changeset
   239
    {
hgs
parents:
diff changeset
   240
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   241
    
hgs
parents:
diff changeset
   242
    if ( !iOldSnapshot )
hgs
parents:
diff changeset
   243
        {
hgs
parents:
diff changeset
   244
        LOGGER_WRITE( "CChangeFinder::FindDeletedItemsL leaved, no old snapshot." );
hgs
parents:
diff changeset
   245
        User::Leave( KErrNotFound );
hgs
parents:
diff changeset
   246
        }
hgs
parents:
diff changeset
   247
    
hgs
parents:
diff changeset
   248
    TInt index;
hgs
parents:
diff changeset
   249
    TInt count = iOldSnapshot->Count();
hgs
parents:
diff changeset
   250
    for ( TInt i=0; i < count; i++ )
hgs
parents:
diff changeset
   251
        {
hgs
parents:
diff changeset
   252
        const TSnapshotItem& currentItem = iOldSnapshot->At( i );
hgs
parents:
diff changeset
   253
        
hgs
parents:
diff changeset
   254
        // If there's no current snapshot, this definately is deleted item
hgs
parents:
diff changeset
   255
        if ( !iCurrentSnapshot )
hgs
parents:
diff changeset
   256
            {
hgs
parents:
diff changeset
   257
            aDeletedUids.AddItem( currentItem.ItemId() );
hgs
parents:
diff changeset
   258
            //LOGGER_WRITE_1( "Item %d was deleted.", currentItem.ItemId() );
hgs
parents:
diff changeset
   259
            }
hgs
parents:
diff changeset
   260
        // It is also new if it doesn't exist int the current snapshot.
hgs
parents:
diff changeset
   261
        else if ( iCurrentSnapshot->FindIsq( currentItem, iKey, index ) != KErrNone )
hgs
parents:
diff changeset
   262
            {
hgs
parents:
diff changeset
   263
            aDeletedUids.AddItem( currentItem.ItemId() );
hgs
parents:
diff changeset
   264
            //LOGGER_WRITE_1( "Item %d was deleted.", currentItem.ItemId() );
hgs
parents:
diff changeset
   265
            }       
hgs
parents:
diff changeset
   266
        }
hgs
parents:
diff changeset
   267
        
hgs
parents:
diff changeset
   268
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   269
    }
hgs
parents:
diff changeset
   270
hgs
parents:
diff changeset
   271
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   272
// CChangeFinder::FindNewItemsL
hgs
parents:
diff changeset
   273
// Compares snapshots, finds new items
hgs
parents:
diff changeset
   274
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   275
void CChangeFinder::FindNewItemsL( CNSmlDataItemUidSet& aNewUids )
hgs
parents:
diff changeset
   276
    {
hgs
parents:
diff changeset
   277
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   278
    
hgs
parents:
diff changeset
   279
    if ( !iCurrentSnapshot )
hgs
parents:
diff changeset
   280
        {
hgs
parents:
diff changeset
   281
        LOGGER_WRITE( "CChangeFinder::FindNewItemsL leaved, no current snapshot." );
hgs
parents:
diff changeset
   282
        User::Leave( KErrNotFound );
hgs
parents:
diff changeset
   283
        }
hgs
parents:
diff changeset
   284
hgs
parents:
diff changeset
   285
    TInt index;
hgs
parents:
diff changeset
   286
    TInt count = iCurrentSnapshot->Count();
hgs
parents:
diff changeset
   287
    for ( TInt i=0; i < count; i++ )
hgs
parents:
diff changeset
   288
        {
hgs
parents:
diff changeset
   289
        const TSnapshotItem& currentItem = iCurrentSnapshot->At( i );
hgs
parents:
diff changeset
   290
        
hgs
parents:
diff changeset
   291
        // If there's no old snapshot, all items are new
hgs
parents:
diff changeset
   292
        if ( !iOldSnapshot )
hgs
parents:
diff changeset
   293
            {
hgs
parents:
diff changeset
   294
            aNewUids.AddItem( currentItem.ItemId() );
hgs
parents:
diff changeset
   295
            //LOGGER_WRITE_1( "Item %d was new.", currentItem.ItemId() );
hgs
parents:
diff changeset
   296
            }
hgs
parents:
diff changeset
   297
        // It is also new if it doesn't exist int the old snapshot.
hgs
parents:
diff changeset
   298
        else if ( iOldSnapshot->FindIsq( currentItem, iKey, index ) != KErrNone )
hgs
parents:
diff changeset
   299
            {
hgs
parents:
diff changeset
   300
            aNewUids.AddItem( currentItem.ItemId() );
hgs
parents:
diff changeset
   301
            //LOGGER_WRITE_1( "Item %d was new.", currentItem.ItemId() );
hgs
parents:
diff changeset
   302
            }       
hgs
parents:
diff changeset
   303
        }
hgs
parents:
diff changeset
   304
        
hgs
parents:
diff changeset
   305
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   306
    }
hgs
parents:
diff changeset
   307
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   310
// CChangeFinder::ItemAddedL
hgs
parents:
diff changeset
   311
// Adds item to snapshot, this item is no longer considered new
hgs
parents:
diff changeset
   312
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   313
void CChangeFinder::ItemAddedL( const TSnapshotItem& aItem )
hgs
parents:
diff changeset
   314
    {
hgs
parents:
diff changeset
   315
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   316
    
hgs
parents:
diff changeset
   317
    // Add this to old snapshot, if there's no old snapshot it must be created
hgs
parents:
diff changeset
   318
    if ( !iOldSnapshot )
hgs
parents:
diff changeset
   319
        {
hgs
parents:
diff changeset
   320
        iOldSnapshot = new (ELeave) CSnapshotArray( KSnapshotGranularity );
hgs
parents:
diff changeset
   321
        }
hgs
parents:
diff changeset
   322
        
hgs
parents:
diff changeset
   323
    LOGGER_WRITE_1( "Adding item %d.", aItem.ItemId() );
hgs
parents:
diff changeset
   324
    
hgs
parents:
diff changeset
   325
    TRAPD( error, iOldSnapshot->InsertIsqL( aItem, iKey ) );
hgs
parents:
diff changeset
   326
    if ( error == KErrAlreadyExists )
hgs
parents:
diff changeset
   327
        {
hgs
parents:
diff changeset
   328
        // It was already committed, no actions required
hgs
parents:
diff changeset
   329
        LOGGER_WRITE( "iOldSnapshot->InsertIsqL leaved with KErrAlreadyExists" );
hgs
parents:
diff changeset
   330
        }
hgs
parents:
diff changeset
   331
    else if ( error != KErrNone )
hgs
parents:
diff changeset
   332
        {
hgs
parents:
diff changeset
   333
        LOGGER_WRITE_1( "iOldSnapshot->InsertIsqL leaved with %d.", error );
hgs
parents:
diff changeset
   334
        User::Leave( error );
hgs
parents:
diff changeset
   335
        }
hgs
parents:
diff changeset
   336
    iOldSnapshot->Compress();
hgs
parents:
diff changeset
   337
    
hgs
parents:
diff changeset
   338
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   339
    }
hgs
parents:
diff changeset
   340
hgs
parents:
diff changeset
   341
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   342
// CChangeFinder::ItemDeletedL
hgs
parents:
diff changeset
   343
// Removes item to snapshot, this item is no longer considered deleted
hgs
parents:
diff changeset
   344
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   345
void CChangeFinder::ItemDeletedL( const TSnapshotItem& aItem )
hgs
parents:
diff changeset
   346
    {
hgs
parents:
diff changeset
   347
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   348
    
hgs
parents:
diff changeset
   349
    LOGGER_WRITE_1( "deleting item %d.", aItem.ItemId() );
hgs
parents:
diff changeset
   350
    
hgs
parents:
diff changeset
   351
    if ( !iOldSnapshot )
hgs
parents:
diff changeset
   352
        {
hgs
parents:
diff changeset
   353
        LOGGER_WRITE( "CChangeFinder::ItemDeleted leaved, no old snapshot." );
hgs
parents:
diff changeset
   354
        User::Leave( KErrNotFound );
hgs
parents:
diff changeset
   355
        }
hgs
parents:
diff changeset
   356
hgs
parents:
diff changeset
   357
    // Delete item from the old snapshot
hgs
parents:
diff changeset
   358
    TInt index;
hgs
parents:
diff changeset
   359
    if ( iOldSnapshot->FindIsq( aItem, iKey, index ) == KErrNone )
hgs
parents:
diff changeset
   360
        {
hgs
parents:
diff changeset
   361
        iOldSnapshot->Delete( index );
hgs
parents:
diff changeset
   362
        }
hgs
parents:
diff changeset
   363
    else // Skip, there wasn't such entry
hgs
parents:
diff changeset
   364
        {
hgs
parents:
diff changeset
   365
        LOGGER_WRITE( "iOldSnapshot->FindIsq, item was not found." );
hgs
parents:
diff changeset
   366
        }
hgs
parents:
diff changeset
   367
    iOldSnapshot->Compress();
hgs
parents:
diff changeset
   368
    
hgs
parents:
diff changeset
   369
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   370
    }
hgs
parents:
diff changeset
   371
hgs
parents:
diff changeset
   372
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   373
// CChangeFinder::ItemUpdatedL
hgs
parents:
diff changeset
   374
// Updates item to snapshot, this item is no longer considered changed
hgs
parents:
diff changeset
   375
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   376
void CChangeFinder::ItemUpdatedL( const TSnapshotItem& aItem )
hgs
parents:
diff changeset
   377
    {
hgs
parents:
diff changeset
   378
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   379
hgs
parents:
diff changeset
   380
    LOGGER_WRITE_1( "Updating item %d.", aItem.ItemId() );
hgs
parents:
diff changeset
   381
    
hgs
parents:
diff changeset
   382
    // There must be such entry in the snapshot after this
hgs
parents:
diff changeset
   383
    // If there isn't old snapshot, we'll create it and add the item
hgs
parents:
diff changeset
   384
    if ( !iOldSnapshot )
hgs
parents:
diff changeset
   385
        {
hgs
parents:
diff changeset
   386
        iOldSnapshot = new (ELeave) CSnapshotArray( KSnapshotGranularity );
hgs
parents:
diff changeset
   387
        ItemAddedL( aItem );
hgs
parents:
diff changeset
   388
        }
hgs
parents:
diff changeset
   389
    else
hgs
parents:
diff changeset
   390
        {
hgs
parents:
diff changeset
   391
        // Update item in the old snapshot
hgs
parents:
diff changeset
   392
        TInt index;
hgs
parents:
diff changeset
   393
        if ( iOldSnapshot->FindIsq( aItem, iKey, index ) == KErrNone )
hgs
parents:
diff changeset
   394
            {
hgs
parents:
diff changeset
   395
            TSnapshotItem& oldItem = iOldSnapshot->At( index );
hgs
parents:
diff changeset
   396
            oldItem = aItem;
hgs
parents:
diff changeset
   397
            }
hgs
parents:
diff changeset
   398
        else 
hgs
parents:
diff changeset
   399
            {
hgs
parents:
diff changeset
   400
            // There was old snapshot but no such item. Let's add it
hgs
parents:
diff changeset
   401
            ItemAddedL( aItem );
hgs
parents:
diff changeset
   402
            }
hgs
parents:
diff changeset
   403
        
hgs
parents:
diff changeset
   404
        }
hgs
parents:
diff changeset
   405
    iOldSnapshot->Compress();
hgs
parents:
diff changeset
   406
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   407
    }
hgs
parents:
diff changeset
   408
hgs
parents:
diff changeset
   409
hgs
parents:
diff changeset
   410
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   411
// CChangeFinder::CommitChangesL
hgs
parents:
diff changeset
   412
// Commits current changes to snapshot
hgs
parents:
diff changeset
   413
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   414
void CChangeFinder::CommitChangesL()
hgs
parents:
diff changeset
   415
    {
hgs
parents:
diff changeset
   416
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   417
    
hgs
parents:
diff changeset
   418
    if ( !iCurrentSnapshot )
hgs
parents:
diff changeset
   419
        {
hgs
parents:
diff changeset
   420
        LOGGER_WRITE( "CChangeFinder::CommitChangesL leaved, current snapshot missing." );
hgs
parents:
diff changeset
   421
        User::Leave( KErrNotFound );
hgs
parents:
diff changeset
   422
        }
hgs
parents:
diff changeset
   423
        
hgs
parents:
diff changeset
   424
    if ( !iOldSnapshot )
hgs
parents:
diff changeset
   425
        {
hgs
parents:
diff changeset
   426
        iOldSnapshot = new (ELeave) CSnapshotArray( KSnapshotGranularity );
hgs
parents:
diff changeset
   427
        }
hgs
parents:
diff changeset
   428
        
hgs
parents:
diff changeset
   429
    // Delete everything from the old snapshot
hgs
parents:
diff changeset
   430
    iOldSnapshot->Reset();
hgs
parents:
diff changeset
   431
    
hgs
parents:
diff changeset
   432
    // Loop through all the items in current snapshot
hgs
parents:
diff changeset
   433
    TInt count = iCurrentSnapshot->Count();
hgs
parents:
diff changeset
   434
    
hgs
parents:
diff changeset
   435
    // Copy everything from current to old snapshot
hgs
parents:
diff changeset
   436
    for ( TInt i = 0; i < count; i++ )
hgs
parents:
diff changeset
   437
        {
hgs
parents:
diff changeset
   438
        // Commit it to the old array.
hgs
parents:
diff changeset
   439
        iOldSnapshot->InsertIsqL( iCurrentSnapshot->At( i ), iKey );
hgs
parents:
diff changeset
   440
        }
hgs
parents:
diff changeset
   441
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   442
    }
hgs
parents:
diff changeset
   443
hgs
parents:
diff changeset
   444
hgs
parents:
diff changeset
   445
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   446
// CChangeFinder::CommitChangesL
hgs
parents:
diff changeset
   447
// Commits current changes to snapshot, affects only a specified group of items
hgs
parents:
diff changeset
   448
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   449
void CChangeFinder::CommitChangesL( const MSmlDataItemUidSet& aUids )
hgs
parents:
diff changeset
   450
    {
hgs
parents:
diff changeset
   451
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   452
    
hgs
parents:
diff changeset
   453
    
hgs
parents:
diff changeset
   454
    // This function commits changes from current snapshot to old snapshot
hgs
parents:
diff changeset
   455
    // But commits only the entries in the parameter array
hgs
parents:
diff changeset
   456
    if ( !iCurrentSnapshot )
hgs
parents:
diff changeset
   457
        {
hgs
parents:
diff changeset
   458
        LOGGER_WRITE( "CChangeFinder::CommitChangesL leaved, current snapshot missing." );
hgs
parents:
diff changeset
   459
        User::Leave( KErrNotFound );
hgs
parents:
diff changeset
   460
        }
hgs
parents:
diff changeset
   461
        
hgs
parents:
diff changeset
   462
    if ( !iOldSnapshot )
hgs
parents:
diff changeset
   463
        {
hgs
parents:
diff changeset
   464
        iOldSnapshot = new (ELeave) CSnapshotArray( KSnapshotGranularity );
hgs
parents:
diff changeset
   465
        }
hgs
parents:
diff changeset
   466
    
hgs
parents:
diff changeset
   467
    for ( TInt i = 0; i < aUids.ItemCount(); i++ )
hgs
parents:
diff changeset
   468
        {
hgs
parents:
diff changeset
   469
        TSmlDbItemUid itemId = aUids.ItemAt( i );
hgs
parents:
diff changeset
   470
        TSnapshotItem temp( itemId );
hgs
parents:
diff changeset
   471
        TInt indexOld( -1 );
hgs
parents:
diff changeset
   472
        TInt indexNew( -1 );
hgs
parents:
diff changeset
   473
        TInt err = iOldSnapshot->FindIsq( temp, iKey, indexOld);
hgs
parents:
diff changeset
   474
        if ( !err )
hgs
parents:
diff changeset
   475
            {
hgs
parents:
diff changeset
   476
            // founded from old snapshot
hgs
parents:
diff changeset
   477
            if ( !iCurrentSnapshot->FindIsq(temp, iKey, indexNew) )
hgs
parents:
diff changeset
   478
                {
hgs
parents:
diff changeset
   479
                // Replace
hgs
parents:
diff changeset
   480
                iOldSnapshot->At( indexOld ) = iCurrentSnapshot->At( indexNew );
hgs
parents:
diff changeset
   481
                }
hgs
parents:
diff changeset
   482
            else
hgs
parents:
diff changeset
   483
                {
hgs
parents:
diff changeset
   484
                // not found from current snapshot, delete from old also.
hgs
parents:
diff changeset
   485
                iOldSnapshot->Delete( indexOld );
hgs
parents:
diff changeset
   486
                }
hgs
parents:
diff changeset
   487
            }
hgs
parents:
diff changeset
   488
        else
hgs
parents:
diff changeset
   489
            {
hgs
parents:
diff changeset
   490
            // not found from old snapshot, add it.
hgs
parents:
diff changeset
   491
            if ( !iCurrentSnapshot->FindIsq( temp, iKey, indexNew ) )
hgs
parents:
diff changeset
   492
                {
hgs
parents:
diff changeset
   493
                iOldSnapshot->InsertIsqL( iCurrentSnapshot->At( indexNew ), iKey );
hgs
parents:
diff changeset
   494
                }
hgs
parents:
diff changeset
   495
            }
hgs
parents:
diff changeset
   496
        }
hgs
parents:
diff changeset
   497
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   498
    }
hgs
parents:
diff changeset
   499
hgs
parents:
diff changeset
   500
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   501
// CChangeFinder::SetNewSnapshot
hgs
parents:
diff changeset
   502
// Sets new snapshot (to be compared against), ChangeFinder takes ownership
hgs
parents:
diff changeset
   503
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   504
void CChangeFinder::SetNewSnapshot( CSnapshotArray* aNewSnapshot )
hgs
parents:
diff changeset
   505
    {
hgs
parents:
diff changeset
   506
    TRACE_FUNC_ENTRY;
hgs
parents:
diff changeset
   507
    
hgs
parents:
diff changeset
   508
    // Delete existing snapshot
hgs
parents:
diff changeset
   509
    delete iCurrentSnapshot;
hgs
parents:
diff changeset
   510
    
hgs
parents:
diff changeset
   511
    // Set submitted snapshot as active
hgs
parents:
diff changeset
   512
    iCurrentSnapshot = aNewSnapshot;
hgs
parents:
diff changeset
   513
    iCurrentSnapshot->Compress();
hgs
parents:
diff changeset
   514
    
hgs
parents:
diff changeset
   515
    TRACE_FUNC_EXIT;
hgs
parents:
diff changeset
   516
    }
hgs
parents:
diff changeset
   517
hgs
parents:
diff changeset
   518
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   519
// CChangeFinder::DataStoreUid
hgs
parents:
diff changeset
   520
// returns stored data store id number
hgs
parents:
diff changeset
   521
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   522
TInt64 CChangeFinder::DataStoreUid() const
hgs
parents:
diff changeset
   523
    {
hgs
parents:
diff changeset
   524
    TRACE_FUNC;
hgs
parents:
diff changeset
   525
    return iDataStoreUid;
hgs
parents:
diff changeset
   526
    }
hgs
parents:
diff changeset
   527
hgs
parents:
diff changeset
   528
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   529
// CChangeFinder::SetDataStoreUid
hgs
parents:
diff changeset
   530
// Sets data store id number
hgs
parents:
diff changeset
   531
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   532
void CChangeFinder::SetDataStoreUid( TInt64 aUid )
hgs
parents:
diff changeset
   533
    {
hgs
parents:
diff changeset
   534
    TRACE_FUNC;
hgs
parents:
diff changeset
   535
    iDataStoreUid = aUid;
hgs
parents:
diff changeset
   536
    }
hgs
parents:
diff changeset
   537