homescreenpluginsrv/inc/hspstimemon.h
author William Roberts <williamr@symbian.org>
Sun, 14 Mar 2010 13:11:02 +0000
branchCompilerCompatibility
changeset 15 bcb8d447d716
parent 0 79c6a41cd166
permissions -rw-r--r--
Automatic merge from PDK_3.0.h

/*
* Copyright (c) 2002-2004 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:  ?Description
*
*/



#ifndef ChspsTIMEMON_H
#define ChspsTIMEMON_H

//  INCLUDES
#include <e32debug.h>
#include <e32base.h>
#include <e32std.h>
#include <hal.h>
#include <e32cmn.h>

/**
*  ?one_line_short_description.
*  ?other_description_lines
*
*  @lib ?library
*  @since Series ?XX ?SeriesXX_version
*/
class ChspsTimeMon : public CBase
    {
    public:  // Constructors and destructor
        
        /**
        * Two-phased constructor.
        */
        static ChspsTimeMon * NewL();
        
        /**
        * Destructor.
        */
        virtual ~ChspsTimeMon ();

    public: // New functions
        /**
        * ?member_description.
        * @since Series ?XX ?SeriesXX_version
        * @param ?arg1 ?description
        * @return ?description
        */
        inline static TTime StartTiming( const TDesC& aMsg );

        /**
        * ?member_description.
        * @since Series ?XX ?SeriesXX_version
        * @param ?arg1 ?description
        * @return ?description
        */
        inline static void StopTiming( TTime aStartTime, const TDesC& aMsg );
        
        /**
        * ?member_description.
        * @since Series ?XX ?SeriesXX_version
        * @param ?arg1 ?description
        * @return ?description
        */
        inline static void PrintUserMem(const TDesC& aMsg);

    public: // Functions from base classes

        /**
        * From ?base_class ?member_description.
        * @since Series ?XX ?SeriesXX_version
        * @param ?arg1 ?description
        * @return ?description
        */
        //?type ?member_function( ?type ?arg1 );
        
    protected:  // New functions
        
        /**
        * ?member_description.
        * @since Series ?XX ?SeriesXX_version
        * @param ?arg1 ?description
        * @return ?description
        */
        //?type ?member_function( ?type ?arg1 );

    protected:  // Functions from base classes
        
        /**
        * From ?base_class ?member_description
        */
        //?type ?member_function();

    private:

        /**
        * C++ default constructor.
        */
        ChspsTimeMon ();

        /**
        * By default Symbian 2nd phase constructor is private.
        */
        void ConstructL();

        // Prohibit copy constructor if not deriving from CBase.
        // ?classname( const ?classname& );
        // Prohibit assigment operator if not deriving from CBase.
        // ?classname& operator=( const ?classname& );

    public:     // Data
        // ?one_line_short_description_of_data
        //?data_declaration;
    
    protected:  // Data
        // ?one_line_short_description_of_data
        //?data_declaration;

    private:    // Data
        // ?one_line_short_description_of_data
        //?data_declaration;
        // Reserved pointer for future extension
        //TAny* iReserved;

    public:     // Friend classes
        //?friend_class_declaration;
    protected:  // Friend classes
        //?friend_class_declaration;
    private:    // Friend classes
        //?friend_class_declaration;

    };

inline TTime ChspsTimeMon::StartTiming(const TDesC& aMsg )
    {
    TTime startTime;
    startTime.HomeTime(); 
    RDebug::Print( aMsg );
    return startTime;
    }

inline void ChspsTimeMon::StopTiming( TTime aStartTime, const TDesC& aMsg )
    {
    // calculating service time
    TTime readyTime;
    readyTime.HomeTime();
    TTimeIntervalMicroSeconds delay = readyTime.MicroSecondsFrom( aStartTime );
    TTime transferTime(delay.Int64());
    TBuf<64> timeString;
    transferTime.FormatL(timeString,_L(" Time: %S%C microseconds"));
    TBuf<256> tmp;
    tmp.Append( aMsg );
    tmp.Append( timeString );
    RDebug::Print( tmp ); 
    }

inline void ChspsTimeMon::PrintUserMem(const TDesC& aMsg)
    {
    TBuf<512> buffer;
    TInt    freeRAM;
    HAL::Get( HALData::EMemoryRAMFree, freeRAM );
    RHeap heap = User::Heap();
    heap.Open();
    TInt _size = heap.Size();
    TInt largest = 0;
    TInt available = heap.Available( largest );
    heap.Close();
    _LIT( KMemoryFormat, "FreeRAM: %d kB, User: - heap %d kB, available %d kB, largest block %d kB" );
    buffer.Format( KMemoryFormat, ( freeRAM / 1024), (_size / 1024),
                                    (available / 1024), (largest / 1024 ) );

    RDebug::Print( _L("ChspsTimeMon::PrintUserMem RAM:%S: %S"), &aMsg, &buffer ); 
    }

#endif      // ChspsTIMEMON_H
            
// End of File