screensaver/inc/snsrtest_global.h
author hgs
Fri, 25 Jun 2010 19:19:22 +0300
changeset 62 341166945d65
permissions -rw-r--r--
201025
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
62
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
* 
hgs
parents:
diff changeset
    14
* Description: Global Screensaver macros for testing purposes.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef SNSRTEST_GLOBAL_H
hgs
parents:
diff changeset
    19
#define SNSRTEST_GLOBAL_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#ifndef SCREENSAVER_TEST
hgs
parents:
diff changeset
    22
    #define SCREENSAVER_TEST_CLASS(aClassName)
hgs
parents:
diff changeset
    23
    #define SCREENSAVER_TEST_FRIEND_CLASS(aClassName)
hgs
parents:
diff changeset
    24
#else
hgs
parents:
diff changeset
    25
    #define SCREENSAVER_TEST_CLASS(aClassName) class aClassName;
hgs
parents:
diff changeset
    26
    #define SCREENSAVER_TEST_FRIEND_CLASS(aClassName) friend class aClassName;
hgs
parents:
diff changeset
    27
#endif //SCREENSAVER_TEST
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
/*!    
hgs
parents:
diff changeset
    30
To enable logging of function entry and exit use the following flag for qmake:
hgs
parents:
diff changeset
    31
-config nft
hgs
parents:
diff changeset
    32
To enable logging of function entry and exit aswell as RAM usage (Symbian only!)
hgs
parents:
diff changeset
    33
use the following flag for qmake:
hgs
parents:
diff changeset
    34
-config nft_ram
hgs
parents:
diff changeset
    35
*/
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
#ifdef NFT
hgs
parents:
diff changeset
    38
    #include <QDebug>
hgs
parents:
diff changeset
    39
    #include <QTime>
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
#ifdef NFT_RAM && Q_OS_SYMBIAN
hgs
parents:
diff changeset
    42
    #include <hal.h>
hgs
parents:
diff changeset
    43
    #include <e32std.h>
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
    #define SCREENSAVER_TEST_FREERAM_ENTRY(function) \
hgs
parents:
diff changeset
    46
    TInt gEntryFreeRam(0); \
hgs
parents:
diff changeset
    47
    TInt gEntryFreeHeap(0); \
hgs
parents:
diff changeset
    48
    TInt gEntryTotalHeap(0); \
hgs
parents:
diff changeset
    49
    { \
hgs
parents:
diff changeset
    50
        HAL::Get(HAL::EMemoryRAMFree, gEntryFreeRam); \
hgs
parents:
diff changeset
    51
        RHeap &heap = User::Heap(); \
hgs
parents:
diff changeset
    52
        TInt biggestBlock(0); \
hgs
parents:
diff changeset
    53
        gEntryFreeHeap = heap.Available(biggestBlock); \
hgs
parents:
diff changeset
    54
        gEntryTotalHeap = heap.Size(); \
hgs
parents:
diff changeset
    55
        qDebug("(snsr nft RAM in) " function \
hgs
parents:
diff changeset
    56
            " - Memory (kB) - Free RAM: %d, Heap size: %d, Free heap: %d", \
hgs
parents:
diff changeset
    57
            gEntryFreeRam >> 10, \
hgs
parents:
diff changeset
    58
            gEntryTotalHeap >> 10, \
hgs
parents:
diff changeset
    59
            gEntryFreeHeap >> 10); \
hgs
parents:
diff changeset
    60
    }
hgs
parents:
diff changeset
    61
    
hgs
parents:
diff changeset
    62
    #define SCREENSAVER_TEST_FREERAM_EXIT(function) \
hgs
parents:
diff changeset
    63
    { \
hgs
parents:
diff changeset
    64
        TInt freeRAM(0); \
hgs
parents:
diff changeset
    65
        HAL::Get(HAL::EMemoryRAMFree, freeRAM); \
hgs
parents:
diff changeset
    66
        RHeap &heap = User::Heap(); \
hgs
parents:
diff changeset
    67
        TInt biggestBlock(0); \
hgs
parents:
diff changeset
    68
        TInt freeHeap = heap.Available(biggestBlock); \
hgs
parents:
diff changeset
    69
        TInt totalHeap = heap.Size(); \
hgs
parents:
diff changeset
    70
        qDebug("(snsr nft RAM out) " function \
hgs
parents:
diff changeset
    71
            " - Memory (kB) - Free RAM: %d (%+d), Heap size: %d (%+d), Free heap: %d (%+d)", \
hgs
parents:
diff changeset
    72
            freeRAM >> 10, (freeRAM-gEntryFreeRam) >> 10, \
hgs
parents:
diff changeset
    73
            totalHeap >> 10, (totalHeap-gEntryTotalHeap) >> 10, \
hgs
parents:
diff changeset
    74
            freeHeap >> 10, (freeHeap-gEntryFreeHeap) >> 10); \
hgs
parents:
diff changeset
    75
    }
hgs
parents:
diff changeset
    76
#else // NFT_RAM && Q_OS_SYMBIAN
hgs
parents:
diff changeset
    77
    #define SCREENSAVER_TEST_FREERAM_ENTRY(function)
hgs
parents:
diff changeset
    78
    #define SCREENSAVER_TEST_FREERAM_EXIT(function)
hgs
parents:
diff changeset
    79
#endif // NFT_RAM && Q_OS_SYMBIAN
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
    #define SCREENSAVER_TEST_TIME_ENTRY(function) \
hgs
parents:
diff changeset
    82
    QTime _ENTRY_TIME; \
hgs
parents:
diff changeset
    83
    _ENTRY_TIME.start(); \
hgs
parents:
diff changeset
    84
    { \
hgs
parents:
diff changeset
    85
        qDebug() << "(snsr nft time in)" << function << "-" << \
hgs
parents:
diff changeset
    86
            _ENTRY_TIME.toString("hh:mm:ss.zzz"); \
hgs
parents:
diff changeset
    87
    }
hgs
parents:
diff changeset
    88
        
hgs
parents:
diff changeset
    89
    #define SCREENSAVER_TEST_TIME_EXIT(function) \
hgs
parents:
diff changeset
    90
    { \
hgs
parents:
diff changeset
    91
        qDebug() << "(snsr nft time out)" << function << "-" << \
hgs
parents:
diff changeset
    92
            QTime::currentTime().toString("hh:mm:ss.zzz") << \
hgs
parents:
diff changeset
    93
            "elapsed:" << _ENTRY_TIME.elapsed() << "ms"; \
hgs
parents:
diff changeset
    94
    }
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
    #define SCREENSAVER_TEST_FUNC_ENTRY(function)   SCREENSAVER_TEST_TIME_ENTRY(function) \
hgs
parents:
diff changeset
    97
        SCREENSAVER_TEST_FREERAM_ENTRY(function)
hgs
parents:
diff changeset
    98
    #define SCREENSAVER_TEST_FUNC_EXIT(function)    SCREENSAVER_TEST_TIME_EXIT(function) \
hgs
parents:
diff changeset
    99
        SCREENSAVER_TEST_FREERAM_EXIT(function)
hgs
parents:
diff changeset
   100
#else //NFT
hgs
parents:
diff changeset
   101
    #define SCREENSAVER_TEST_FUNC_ENTRY(function)
hgs
parents:
diff changeset
   102
    #define SCREENSAVER_TEST_FUNC_EXIT(function)
hgs
parents:
diff changeset
   103
#endif //NFT
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
#endif // SNSRTEST_GLOBAL_H