os/persistentdata/loggingservices/eventlogger/LogServ/src/LOGREC.CPP
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
// Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
//
sl@0
    15
sl@0
    16
#include "LOGREC.H"
sl@0
    17
sl@0
    18
// User includes
sl@0
    19
#include "logservpanic.h"
sl@0
    20
#include "LogServDatabaseTransactionInterface.h"
sl@0
    21
sl@0
    22
sl@0
    23
CLogRecover::CLogRecover(MLogServDatabaseTransactionInterface& aDatabase, TInt aPriority)
sl@0
    24
: CLogActive(aPriority), iDatabase(aDatabase)
sl@0
    25
	{
sl@0
    26
	}
sl@0
    27
sl@0
    28
TBool CLogRecover::Start(TRequestStatus& aStatus)
sl@0
    29
	{
sl@0
    30
	if (!iDatabase.DTIDatabaseIsDamaged())
sl@0
    31
		return EFalse;
sl@0
    32
sl@0
    33
	TInt error = iOperation.Recover(iDatabase.DTIDatabase(), iStep());
sl@0
    34
	if (error != KErrNone)
sl@0
    35
		{
sl@0
    36
		__ASSERT_DEBUG(ETrue, Panic(ELogRecoverError));
sl@0
    37
		return EFalse;
sl@0
    38
		}
sl@0
    39
sl@0
    40
	if (iStep() > 0)
sl@0
    41
		{
sl@0
    42
		Queue(aStatus);
sl@0
    43
		TRequestStatus* st = &iStatus;
sl@0
    44
		User::RequestComplete(st, KErrNone);
sl@0
    45
		SetActive();
sl@0
    46
sl@0
    47
		return ETrue;
sl@0
    48
		}
sl@0
    49
sl@0
    50
	return EFalse;
sl@0
    51
	}
sl@0
    52
sl@0
    53
void CLogRecover::DoRunL()
sl@0
    54
	{
sl@0
    55
	if (iStep() > 0)
sl@0
    56
		{
sl@0
    57
		iOperation.Next(iStep, iStatus);
sl@0
    58
		SetActive();
sl@0
    59
		}
sl@0
    60
	else
sl@0
    61
		__ASSERT_DEBUG(!iDatabase.DTIInTransaction(), Panic(ELogDatabaseDamaged3));
sl@0
    62
	}
sl@0
    63
sl@0
    64
void CLogRecover::DoComplete(TInt& /*aCompletionCode*/)
sl@0
    65
	{
sl@0
    66
	iOperation.Close();
sl@0
    67
	}