phoneengine/phonemodel/src/cpeparsermanufacturerhandler.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 19 Mar 2010 09:28:42 +0200
changeset 21 92ab7f8d0eab
parent 0 5f000ab63145
child 51 f39ed5e045e0
permissions -rw-r--r--
Revision: 201007 Kit: 201011

/*
* Copyright (c) 2006-2008 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:  Battery state monitoring class methods implementation
*
*/
 

//  ==================== INCLUDE FILES  ====================
#include "cpeparsermanufacturerhandler.h"
#include "mpephonemodelinternal.h"
#include <mpecallhandling.h>
#include <mpedatastore.h>
#include <sysutil.h>
#include <talogger.h>


// CONSTANTS
const TInt KPESwVersionLineCount = 3;
const TInt KPEVersionLineFeed = '\n';
const TInt KPESalesModelNameMaxLength = 20; 
_LIT( KPESalesModelFileName, "Z:\\resource\\versions\\model.txt");

// ================= MEMBER FUNCTIONS =======================

// C++ default constructor can NOT contain any code, that
// might leave.
//
CPEParserManufacturerHandler::CPEParserManufacturerHandler( 
        MPEPhoneModelInternal& aModel,
        MPECallHandling& aCallHandling,
        RFs& aFsSession )
        : iModel( aModel ),
            iCallHandling( aCallHandling ),
            iFsSession( aFsSession )
    {
    TEFLOGSTRING( KTAOBJECT, "PE CPEParserManufacturerHandler::CPEParserManufacturerHandler()" );
    }

// Destructor
CPEParserManufacturerHandler::~CPEParserManufacturerHandler()
    {    
    TEFLOGSTRING( KTAOBJECT, "PE CPEParserManufacturerHandler::~CPEParserManufacturerHandler()" );
    }

// -----------------------------------------------------------------------------
// CPhoneManufacturerHandler::ProcessCommandL
// -----------------------------------------------------------------------------
//
void CPEParserManufacturerHandler::ProcessCommandL( 
        TUint aCommand )       // aCommand command enumeration.
    {
    TEFLOGSTRING( KTAINT, "PE CPEParserManufacturerHandler::ProcessCommandL" );

    switch ( aCommand )
        {
        case EShowVersion: // *#0000#
            {
            TEFLOGSTRING( KTAINT, "PE CPEParserManufacturerHandler::ProcessCommandL, EShowVersion" );
            
            TPEPhoneIdentityParameters phoneIdentity;
            phoneIdentity = iModel.DataStore()->PhoneIdentityParameters();
            if ( GetSwVersionAndPhoneModelL( phoneIdentity.iRevision ) == KErrNone )
                {
                iModel.DataStore()->SetPhoneIdentityParameters( phoneIdentity );
                iModel.SendMessage( MEngineMonitor::EPEMessageShowVersion );
                }
            else
                {
                iModel.SendMessage( MEngineMonitor::EPEMessageError );
                TEFLOGSTRING( KTAERROR, 
                    "PE CPEGSMPARSERMANUFACTURERHANDLER::PROCESSCOMMANDL: FAILED TO RETRIEVE SW VERSION" );
                }
            break;
            }
        case EBadPinChange:    
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageBadPin1Change );
            break;
            }
        case EBadPin2Change:
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageBadPin2Change );
            break;
            }
        case EBadPinUnblock:    
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageBadPin1Unblock );
            break;
            }
        case EBadPin2Unblock:
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageBadPin2Unblock );
            break;
            }
        case EActivateRfsNormal:
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageActivateRfsNormal );
            break;
            }
        case EActivateRfsDeep:    
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageActivateRfsDeep );
            break;
            }
        case EActivateWarranty:
            //lint -fallthrough
        case ELifeTimer:
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageActivateWarrantyMode );
            break;
            }
        case EShowBtAddress: // *#2820#
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageShowBTDeviceAddress );
            break;
            }
        case EBTLoopback: // *#9990#
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageShowBTLoopback );
            break;
            }
        case EShowWlanMac: // *#62209526#
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageShowWlanMacAddress );
            break;
            }
        case EBTDebugMode: // *#2873#
            {
            iModel.SendMessage( MEngineMonitor::EPEMessageBTDebugMode );
            break;
            }
        default:
            {
            TEFLOGSTRING( KTAERROR, "PE CPEGSMPARSERMANUFACTURERHANDLER::PROCESSCOMMANDL: UNEXPECTED COMMAND" );
            break;
            }
        }
    }

// -----------------------------------------------------------------------------
// CPEParserManufacturerHandler::ProcessDebugL
// -----------------------------------------------------------------------------
//
void CPEParserManufacturerHandler::ProcessDebugL(
        const TDesC& aCode
        )
    {
    TEFLOGSTRING( KTAINT, "PE CPEParserManufacturerHandler::ProcessDebugL" );
    
    if ( aCode.Length() )
        {
        TInt cmd = KErrNotFound;
        TLex( aCode.Left( 1 ) ).Val( cmd ); // first character.

        TInt param = KErrNotFound;
        TLex( aCode.Mid( 1 ) ).Val( param ); // rest

        switch ( cmd )
            {
            case EPhoneCmdDebugPrint:
                {
                //Copied from S60 Telephony. To be migrated to CoTe
                TEFLOGSTRING( KTAERROR, "PE CPEGSMPARSERMANUFACTURERHANDLER::PROCESSDEBUGL EPHONECMDDEBUGPRINT" );
                }
                break;

            case EPhoneCmdHeapFailure:
                {
#ifdef PHONE_HEAP_FAILURE_SUPPORT
                if ( param <= 0 )
                    {
                    // Reset alloc failure
                    User::__DbgSetAllocFail(
                        RHeap::EUser,
                        RHeap::ENone,
                        1 );
                    }
                else
                    {
                    // Set heap failure
                    User::__DbgSetAllocFail(
                        RHeap::EUser,
                        RHeap::ERandom,
                        param );
                    }
#endif // PHONE_HEAP_FAILURE_SUPPORT
                } 
                break;

            default:
                break;
            }
        }
    }

// -----------------------------------------------------------------------------
// CPEParserManufacturerHandler::GetSwVersionAndPhoneModelL
// Gets sw version from SysUtil::GetSwVersion and loads phone model information
// from file. This information is set to aSwVersion.
// -----------------------------------------------------------------------------
//
TInt CPEParserManufacturerHandler::GetSwVersionAndPhoneModelL( 
    TDes& aSwVersion )
    {
    TEFLOGSTRING( KTAINT, "PE CPEParserManufacturerHandler::GetSwVersionAndPhoneModelL" );
    
    TInt errorCode = SysUtil::GetSWVersion( aSwVersion ) ;
    
    TEFLOGSTRING2( KTAINT,
        "PE CPEParserManufacturerHandler::GetSwVersionAndPhoneModelL > SysUtil::GetSWVersion, error code: %d",
        errorCode );

    if ( errorCode == KErrNone )
        {
        // Remove needless lines
        RemoveLinesAfterThreeLines( aSwVersion );
        // Add phone model
        AppendPhoneModelL( aSwVersion );
        }
        
    return errorCode;  
    }

// -----------------------------------------------------------------------------
// CPEParserManufacturerHandler::RemoveNeedlessLinesL
// Removes lines after 3 end-of-line (\n) chars.
// -----------------------------------------------------------------------------
//
void CPEParserManufacturerHandler::RemoveLinesAfterThreeLines( 
    TDes& aSwVersion ) 
    {
    TEFLOGSTRING( KTAINT, "PE CPEParserManufacturerHandler::RemoveLinesAfterThreeLines" );
    
    TInt lineFeedCount = 0;
    
    const TInt swVersionLength( aSwVersion.Length() );
    for( TInt i = 0; i < swVersionLength ; i++ )
        {
        if( aSwVersion[i] == KPEVersionLineFeed )
            {
            lineFeedCount++;
            if( lineFeedCount == KPESwVersionLineCount )
                {
                const TInt charsToDelete( aSwVersion.Length() - i );
                
                // Dont delete the last line feed characted, thats why
                // i + 1.
                aSwVersion.Delete( i + 1, charsToDelete );
                return;
                }
            }
        }
    }
    
// -----------------------------------------------------------------------------
// CPEParserManufacturerHandler::AppendPhoneModelL
// Reads phone model info from disk and appends it to aSwVersion.
// -----------------------------------------------------------------------------
//
void CPEParserManufacturerHandler::AppendPhoneModelL(   
    TDes& aSwVersion ) 
    {   
    RFile file;
    User::LeaveIfError( file.Open( iFsSession, 
                                   KPESalesModelFileName, 
                                   EFileShareReadersOnly | EFileRead ) );
    CleanupClosePushL( file );
    
    HBufC* model = HBufC::NewLC( KPESalesModelNameMaxLength );
    TPtr ptr = model->Des();

    // Read the data from file.
    TFileText reader;
    reader.Set( file );
    User::LeaveIfError( reader.Read( ptr ) );

    // Append the phone model to aSwVersion
    aSwVersion.Append( *model );
    
    CleanupStack::PopAndDestroy( 2 ); // model, file
    }

// End of File