logsui/EngineSrc/CLogsModel.cpp
changeset 0 e686773b3f54
equal deleted inserted replaced
-1:000000000000 0:e686773b3f54
       
     1 /*
       
     2 * Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description: 
       
    15 *     Produces objects that implement MLogsModel
       
    16 *
       
    17 */
       
    18 
       
    19 
       
    20 // INCLUDE FILES
       
    21 #include "CLogsModel.h"
       
    22 #include "MLogsReader.h"
       
    23 #include "MLogsEvent.h"
       
    24 #include "MLogsStateHolder.h"
       
    25 #include "CLogsEventGetter.h"
       
    26 #include "CLogsReaderFactory.h"
       
    27 #include "CLogsGetEventFactory.h"
       
    28 #include "MLogsEventArray.h"
       
    29 // CONSTANTS
       
    30 
       
    31 // ----------------------------------------------------------------------------
       
    32 // CLogsModel::NewL
       
    33 // ----------------------------------------------------------------------------
       
    34 //
       
    35 CLogsModel* CLogsModel::NewL( 
       
    36     RFs& aFsSession,
       
    37     TLogsModel aModel,
       
    38     TLogsEventStrings& aStrings,
       
    39     CLogsEngine* aLogsEngineRef )
       
    40      
       
    41     {
       
    42     CLogsModel* self = new (ELeave) CLogsModel( aFsSession, aModel, aStrings, aLogsEngineRef );
       
    43     CleanupStack::PushL( self );
       
    44     self->ConstructL();
       
    45     CleanupStack::Pop();
       
    46     return self;
       
    47     }
       
    48 
       
    49 // ----------------------------------------------------------------------------
       
    50 // CLogsModel::CLogsModel
       
    51 // ----------------------------------------------------------------------------
       
    52 //
       
    53 CLogsModel::CLogsModel( 
       
    54     RFs& aFsSession,
       
    55     TLogsModel aModel,
       
    56     TLogsEventStrings& aStrings,
       
    57     CLogsEngine* aLogsEngineRef ) :
       
    58         iFsSession( aFsSession ),
       
    59         iModel( aModel ), 
       
    60         iStrings( aStrings ),
       
    61         iState( EStateUndefined ),
       
    62         iLogsEngineRef( aLogsEngineRef )     
       
    63     {
       
    64     }
       
    65 
       
    66 // ----------------------------------------------------------------------------
       
    67 // CLogsModel::ConstructL
       
    68 // ----------------------------------------------------------------------------
       
    69 //
       
    70 void CLogsModel::ConstructL()
       
    71     {
       
    72     iEventArray = CLogsGetEventFactory::LogsEventArrayL( iModel, 20 );
       
    73     iWrapper = CLogsEventGetter::NewL();    
       
    74     }
       
    75 
       
    76 // ----------------------------------------------------------------------------
       
    77 // CLogsModel::~CLogsModel
       
    78 // ----------------------------------------------------------------------------
       
    79 //
       
    80 CLogsModel::~CLogsModel()
       
    81     {
       
    82     if( iEventArray )
       
    83         {
       
    84         iEventArray->Reset();
       
    85         }
       
    86 
       
    87     delete iEventArray;
       
    88     delete iWrapper;
       
    89     delete iReader;
       
    90     }
       
    91 
       
    92 // ----------------------------------------------------------------------------
       
    93 // CLogsModel::Delete
       
    94 // ----------------------------------------------------------------------------
       
    95 //
       
    96 void CLogsModel::Delete( TInt aIndex )
       
    97 	{
       
    98 	iEventArray->Delete( aIndex );
       
    99 	}
       
   100 
       
   101 // ----------------------------------------------------------------------------
       
   102 // CLogsModel::Count
       
   103 // ----------------------------------------------------------------------------
       
   104 //
       
   105 TInt CLogsModel::Count()
       
   106     {
       
   107     return iEventArray->Count();
       
   108     }
       
   109 
       
   110 // ----------------------------------------------------------------------------
       
   111 // CLogsModel::KickStartL
       
   112 // ----------------------------------------------------------------------------
       
   113 //
       
   114 void CLogsModel::KickStartL( TBool aReset )
       
   115     {
       
   116     if( iObserver && iEventArray && aReset )              
       
   117         {
       
   118         iState = EStateInitializing; //This informs observers that e.g. a complete re-read of recent events is about to begin
       
   119                                      // so that they can e.g. change their view focus settings accordingly
       
   120                                      // (e.g. CLogsRecentListView::StateChangedL ).
       
   121         iEventArray->Reset();        //Delete the old rows as it might take too long to read the new correct contents
       
   122         iObserver->StateChangedL( this );
       
   123         }
       
   124     
       
   125     if( iReader )
       
   126         {
       
   127         // call ActivateL first, cause KickStartL is called directly from CLogsEngine too
       
   128         iReader->ActivateL();  
       
   129         iReader->StartL();
       
   130         }
       
   131     }
       
   132 
       
   133 // ----------------------------------------------------------------------------
       
   134 // CLogsModel::At
       
   135 // ----------------------------------------------------------------------------
       
   136 //
       
   137 const MLogsEventGetter* CLogsModel::At( TInt aIndex )
       
   138     {
       
   139     if( aIndex < 0 || aIndex >= Count() )
       
   140         {
       
   141         iWrapper->Wrap( NULL );
       
   142         return NULL;
       
   143         }
       
   144         
       
   145     return iWrapper->Wrap(&iEventArray->At( aIndex ) );  //Log events in iEventArray 
       
   146     }
       
   147 
       
   148 // ----------------------------------------------------------------------------
       
   149 // CLogsModel::SetObserver
       
   150 // ----------------------------------------------------------------------------
       
   151 //
       
   152 void CLogsModel::SetObserver( MLogsObserver* aObserver )
       
   153     {
       
   154     iObserver = aObserver;
       
   155     }
       
   156 
       
   157 //This function can be called several times without calling DoDeactivate between calls
       
   158 // ----------------------------------------------------------------------------
       
   159 // CLogsModel::DoActivateL
       
   160 // ----------------------------------------------------------------------------
       
   161 //
       
   162 void CLogsModel::DoActivateL( TDoActivate aDoActivate )
       
   163     {
       
   164     if( !iReader )
       
   165         {
       
   166         TRAPD( err, iReader = CLogsReaderFactory::LogsReaderL( iFsSession, 
       
   167                                         *iEventArray, iStrings, iModel, this, iLogsEngineRef ) );
       
   168 		if( err == KErrAccessDenied )
       
   169 			{
       
   170 			delete iReader;
       
   171 			iReader = NULL;
       
   172 			return;
       
   173 			}
       
   174         User::LeaveIfError(err);
       
   175         }
       
   176  
       
   177     iReader->ActivateL();  //This needs to be done before any other iReader call
       
   178 
       
   179     //Update list only if refresh requested, otherwise leave as it is
       
   180     if( aDoActivate != EActivateOnly )
       
   181         {
       
   182         if( iReader->IsDirty() )
       
   183             {
       
   184             //ETrue: reset list before reading
       
   185             KickStartL( aDoActivate == EResetAndRefresh ? ETrue : EFalse );
       
   186             }
       
   187         else if( iReader->IsInterrupted() )
       
   188             {
       
   189             iReader->ContinueL();
       
   190             }
       
   191         }        
       
   192     }
       
   193 
       
   194 // ----------------------------------------------------------------------------
       
   195 // CLogsModel::DoDeactivate
       
   196 // ----------------------------------------------------------------------------
       
   197 //
       
   198 void CLogsModel::DoDeactivate( 
       
   199     TClearMissedCalls aClearMissedCalls,
       
   200     TDoDeactivate aDisconnectDb )
       
   201     {
       
   202     if( iModel == ELogsMissedModel && 
       
   203         aClearMissedCalls == ENormalOperation ) 
       
   204         {
       
   205         if( iReader ) 
       
   206             {
       
   207             TInt count(iEventArray->Count());
       
   208             for(TInt i = 0; i < count; i++)
       
   209                 {
       
   210                 iEventArray->At(i).SetDuplicates(0);
       
   211                 }
       
   212             //We need to clear duplicates from the db too
       
   213             TInt err;        
       
   214             TRAP( err, iReader->ClearDuplicatesL() );
       
   215             }
       
   216         }
       
   217 
       
   218     /**************************************************************************************************        
       
   219      * This did not help enough for EMSH-6JDFBV, therefore original below still in use.
       
   220     //if( aDisconnectDb ) //Needs to be done always, otherwise happened a bit too late when MT call is received.
       
   221         {
       
   222         //iReader->Stop(); //This seems to be not enough for EMSH-6JDFBV, two rows below work a bit better instead
       
   223         iReader->Interrupt();   
       
   224         iReader->DeActivate( ); 
       
   225         }
       
   226     **************************************************************************************************/
       
   227 
       
   228     //For main model we cannot delete the reader, otherwise the use must wait long for the lines to show up again 
       
   229     //in the event view. Also we cannot update the view in CLogsEventListView::StateChangedL too frequently when the 
       
   230     //model is being reread. 
       
   231     if( iModel == ELogsMainModel )
       
   232         {
       
   233         if( iReader )
       
   234             {
       
   235             iReader->DeActivate();
       
   236             iReader->Interrupt();
       
   237             }
       
   238         }
       
   239     else
       
   240         {
       
   241         if( aDisconnectDb == ECloseDBConnectionAndResetArray ||
       
   242             aDisconnectDb == ECloseDBConnection )
       
   243             {
       
   244             //The rows below stop effectively cpu and I/O consumption in view of EMSH-6JDFBV. However, 
       
   245             //they also kill user's perceived UI responsiviness so aDisconnectDb should be used sparingly. 
       
   246             //Because reader may be deleted when reading of db is ongoing, we need also explicitly inform 
       
   247             //observer that we are finished.
       
   248             delete iReader; 
       
   249             iReader = NULL; 
       
   250             iState = EStateReaderDeletedOrStopped; 
       
   251             
       
   252             if (aDisconnectDb == ECloseDBConnectionAndResetArray)
       
   253                 {
       
   254                 iState = EStateArrayReseted; 
       
   255                 iEventArray->Reset();  
       
   256                 }  
       
   257             
       
   258             if( iObserver )
       
   259                 {
       
   260                 TInt err;        
       
   261                 TRAP( err, iObserver->StateChangedL( this ) );
       
   262                 }
       
   263             }
       
   264         // Special case, just reset the array. This is needed to avoid flicker of 
       
   265         // old list since reread of events is done when regaining foreground
       
   266         else if (aDisconnectDb == EResetOnlyArray || aDisconnectDb == EResetOnlyArrayWithDirty )
       
   267             {
       
   268             iState = EStateArrayReseted;
       
   269             iEventArray->Reset(); 
       
   270             
       
   271             if ( aDisconnectDb == EResetOnlyArrayWithDirty )
       
   272                 {
       
   273                 if( iReader )
       
   274                     {
       
   275                     iReader->SetDirty();
       
   276                     }              
       
   277                 }
       
   278             
       
   279             if( iObserver )
       
   280                 {
       
   281                 TInt err;        
       
   282                 TRAP( err, iObserver->StateChangedL( this ) );
       
   283                 }
       
   284             }
       
   285        
       
   286         }
       
   287     }
       
   288 
       
   289 // ----------------------------------------------------------------------------
       
   290 // CLogsModel::Reset
       
   291 // ----------------------------------------------------------------------------
       
   292 //
       
   293 void CLogsModel::Reset()
       
   294     {
       
   295     iWrapper->Wrap( NULL );
       
   296     }
       
   297 
       
   298 // ----------------------------------------------------------------------------
       
   299 // CLogsModel::State
       
   300 // ----------------------------------------------------------------------------
       
   301 //
       
   302 TLogsState CLogsModel::State() const
       
   303     {
       
   304     return iState;
       
   305     }
       
   306 
       
   307 // ----------------------------------------------------------------------------
       
   308 // CLogsModel::ConfigureL
       
   309 // ----------------------------------------------------------------------------
       
   310 //
       
   311 void CLogsModel::ConfigureL( const MLogsReaderConfig* aConfig )
       
   312     {
       
   313     if( iReader )
       
   314         {
       
   315         iReader->Stop();
       
   316         iReader->ConfigureL( aConfig );
       
   317         KickStartL( ETrue );
       
   318         }
       
   319     } 
       
   320 
       
   321 // ----------------------------------------------------------------------------
       
   322 // CLogsModel::StateChangedL
       
   323 // ----------------------------------------------------------------------------
       
   324 //
       
   325 void CLogsModel::StateChangedL( MLogsStateHolder* aHolder )
       
   326     {
       
   327     if( aHolder->State() == EStateClearLogFinished )
       
   328         {
       
   329         KickStartL( ETrue );
       
   330         }
       
   331 
       
   332 /*
       
   333     if( aHolder->State() == EStateFreeToDelete )
       
   334         {
       
   335         delete iReader;
       
   336         iReader = NULL;
       
   337         }
       
   338     else
       
   339 */    
       
   340         {
       
   341         iState = aHolder->State();
       
   342         if( iObserver )
       
   343             {
       
   344             iObserver->StateChangedL( this );
       
   345             }
       
   346         }
       
   347     }
       
   348 
       
   349