os/persistentdata/loggingservices/eventlogger/LogServ/src/LogDynBuf.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) 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
#include "LogDynBuf.h"
sl@0
    16
sl@0
    17
/**
sl@0
    18
Constructs RLogDynBuf object with the specified granularity.
sl@0
    19
sl@0
    20
@param aGranularity RLogDynBuf granularity. 
sl@0
    21
@endcode
sl@0
    22
sl@0
    23
@leave KErrNoMemory Out of memory.
sl@0
    24
*/
sl@0
    25
void RLogDynBuf::CreateLC(TInt aGranularity)
sl@0
    26
	{
sl@0
    27
	iGranularity = aGranularity;
sl@0
    28
	iBuf.CreateL(aGranularity);
sl@0
    29
	CleanupClosePushL(*this);
sl@0
    30
	}
sl@0
    31
sl@0
    32
/**
sl@0
    33
Destroys the buffer
sl@0
    34
*/
sl@0
    35
void RLogDynBuf::Close()
sl@0
    36
	{
sl@0
    37
	iBuf.Close();	
sl@0
    38
	}
sl@0
    39
sl@0
    40
/**
sl@0
    41
Attempts to append aStr to the end of the buffer. If the buffer has not enough available space,
sl@0
    42
AppendL() will try to expand the buffer before the append operation.
sl@0
    43
sl@0
    44
@param aStr 16-bit desrpiptor to be appended to the end of the buffer.
sl@0
    45
sl@0
    46
@leave KErrNoMemory Out of memory.
sl@0
    47
*/	
sl@0
    48
void RLogDynBuf::AppendL(const TDesC& aStr)
sl@0
    49
	{
sl@0
    50
	DoAllocL(aStr.Length());
sl@0
    51
	iBuf.Append(aStr);
sl@0
    52
	}
sl@0
    53
sl@0
    54
/**
sl@0
    55
If aLen is bigger than the available buffer space, the buffer will be expanded.
sl@0
    56
sl@0
    57
@param aLen The new size of the buffer, in bytes.  
sl@0
    58
sl@0
    59
@leave KErrNoMemory Out of memory.
sl@0
    60
*/
sl@0
    61
void RLogDynBuf::DoAllocL(TInt aLen)
sl@0
    62
	{
sl@0
    63
	__ASSERT_DEBUG(aLen >= 0, User::Invariant());
sl@0
    64
	const TInt len = iBuf.Length();
sl@0
    65
	TInt maxLen = iBuf.MaxLength();
sl@0
    66
	TInt available = maxLen - len;
sl@0
    67
	TInt overflow = aLen - available;
sl@0
    68
	if(overflow > 0)
sl@0
    69
		{
sl@0
    70
		iBuf.ReAllocL(maxLen + (overflow / iGranularity + 1) * iGranularity);
sl@0
    71
		}
sl@0
    72
	}