creator/engine/src/creator_logelement.cpp
author William Roberts <williamr@symbian.org>
Thu, 22 Jul 2010 16:33:59 +0100
branchGCC_SURGE
changeset 37 c20154ccf3c0
parent 17 4f2773374eff
permissions -rw-r--r--
Catchup to latest Symbian^4

/*
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description: 
*
*/



#include "creator_logelement.h"
#include "creator_traces.h"
#include "creator_log.h"

using namespace creatorlog;

/*
 * 
 */
CCreatorLogElement* CCreatorLogElement::NewL(CCreatorEngine* aEngine, const TDesC& aName, const TDesC& aContext )
    {
    CCreatorLogElement* self = new (ELeave) CCreatorLogElement(aEngine);
    CleanupStack::PushL(self);
    self->ConstructL(aName, aContext);
    CleanupStack::Pop(self);
    return self;
    }
/*
 * 
 */
CCreatorLogElement::CCreatorLogElement(CCreatorEngine* aEngine) 
: 
CCreatorScriptElement(aEngine)
    {
    iIsCommandElement = ETrue;
    }
/*
 * 
 */
void CCreatorLogElement::ExecuteCommandL()
    {
    const CCreatorScriptAttribute* amountAttr = FindAttributeByName(KAmount);
    TInt logAmount = 1;    
    if( amountAttr )
        {
        logAmount = ConvertStrToIntL(amountAttr->Value());
        }
    // Get 'fields' element 
    CCreatorScriptElement* fieldsElement = FindSubElement(KFields);
    if( fieldsElement && fieldsElement->SubElements().Count() > 0 )
        {
        // Get sub-elements
        const RPointerArray<CCreatorScriptElement>& fields = fieldsElement->SubElements();        
        // Create log entries, the amount of entries is defined by logAmount:
        for( TInt cI = 0; cI < logAmount; ++cI )
            {
            TInt direction = -1;
            CLogsParameters* param = new (ELeave) CLogsParameters;
            CleanupStack::PushL(param);
            
            for( TInt i = 0; i < fields.Count(); ++i )
                {
                CCreatorScriptElement* field = fields[i];
                TPtrC elemName = field->Name();
                TPtrC elemContent = field->Content();
                const CCreatorScriptAttribute* randomAttr = field->FindAttributeByName(KRandomLength);
                const CCreatorScriptAttribute* increaseAttr = field->FindAttributeByName(KIncrease);
                TBool increase( EFalse );
                if ( increaseAttr )
                    {
                    increase = ConvertStrToBooleanL( increaseAttr->Value() );
                    }
                
                if( elemName == KDirection )
                    {
                    direction = GetLogCommandL(elemContent, randomAttr || elemContent.Length() == 0); 
                    }
                else if( elemName == KDuration )
                    {
                    if( randomAttr || elemContent.Length() == 0 )
                        {
                        param->iDuration = iEngine->RandomNumber(7200);
                        }
                    else
                        {
                        param->iDuration = ConvertStrToIntL(elemContent);
                        }
                    }
                else if( elemName == KPhonenumber )
                    {
                    if( randomAttr || elemContent.Length() == 0 )
                        {
                        SetContentToTextParamL(param->iPhoneNumber, iEngine->RandomString(CCreatorEngine::EPhoneNumber));
                        }
                    else
                        {
                        if ( increase )
                            {
                            delete param->iPhoneNumber;
                            param->iPhoneNumber = NULL;
                            param->iPhoneNumber = HBufC::NewL( elemContent.Length() + 3 );
                            IncreasePhoneNumL( elemContent, cI, param->iPhoneNumber );
                            }
                        else
                            {
                            SetContentToTextParamL(param->iPhoneNumber, elemContent);
                            }
                        }                    
                    }
                else if( elemName == KDatetime )
                    {
                    if( randomAttr || elemContent.Length() == 0 )
                        {
                        param->iEventTime = iEngine->RandomTime(iEngine->RandomDate(CCreatorEngine::EDatePast), CCreatorEngine::EDatePast); 
                        }
                    else
                        {
                        param->iEventTime = ConvertToDateTimeL(elemContent);
                        }
                    }
                }
            
            if( direction == -1 )
                {
                direction = GetLogCommandL(KEmpty, ETrue); 
                }
            iEngine->AppendToCommandArrayL(direction, param);
            CleanupStack::Pop(); // param
            }
        }
    else
    	{
    	for(TInt i = 0; i < logAmount; ++i )
    		{
    		iEngine->AppendToCommandArrayL(GetLogCommandL(KEmpty, ETrue), 0, 1);
    		}
    	}
    }

TInt CCreatorLogElement::GetLogCommandL( const TDesC& aLogCmdStr, TBool aRandom ) const
    {      
    if( aRandom )
        {
        TInt commandArray[] = {
                    ECmdCreateLogEntryMissedCalls,
                    ECmdCreateLogEntryReceivedCalls,
                    ECmdCreateLogEntryDialledNumbers
            };
        return commandArray[iEngine->RandomNumber(0, 2)];
        }
    
    if( CompareIgnoreCase(aLogCmdStr, KMissed) == 0 )
        return ECmdCreateLogEntryMissedCalls;
    else if( CompareIgnoreCase(aLogCmdStr, KIn) == 0 )
        return ECmdCreateLogEntryReceivedCalls;
    else if( CompareIgnoreCase(aLogCmdStr, KOut) == 0 )
        return ECmdCreateLogEntryDialledNumbers;
    
    LOGSTRING2("CCreatorLogElement::GetLogCommandL: Unknown log direction: %S", &aLogCmdStr);
    User::Leave(KErrNotFound);
    return -1; // Not reached, but disables compiler warning...
    }