tsrc/testing/inc/mpxvideo_debug.h
author hgs
Thu, 04 Nov 2010 11:16:56 +0200
changeset 71 60b4b6493d7b
permissions -rw-r--r--
201044
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
71
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:    Debug print macros*
hgs
parents:
diff changeset
    15
*/
hgs
parents:
diff changeset
    16
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
// Version : %version: 1 %
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
#ifndef __MPXVIDEO_DEBUG_H__
hgs
parents:
diff changeset
    25
#define __MPXVIDEO_DEBUG_H__
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
// INCLUDES
hgs
parents:
diff changeset
    28
#include <e32std.h>
hgs
parents:
diff changeset
    29
#include <e32svr.h>
hgs
parents:
diff changeset
    30
#include <e32des16.h>
hgs
parents:
diff changeset
    31
#include <e32property.h>
hgs
parents:
diff changeset
    32
#include <flogger.h>
hgs
parents:
diff changeset
    33
#include <e32def.h>
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
#ifdef _DEBUG
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
class MPXDebug
hgs
parents:
diff changeset
    38
{
hgs
parents:
diff changeset
    39
    public:
hgs
parents:
diff changeset
    40
        inline static void NullLog( TRefByValue<const TDesC16> /*aFmt*/, ... )
hgs
parents:
diff changeset
    41
        {
hgs
parents:
diff changeset
    42
        }
hgs
parents:
diff changeset
    43
hgs
parents:
diff changeset
    44
        inline static void FileLog( TRefByValue<const TDesC16> aFmt, ... )
hgs
parents:
diff changeset
    45
        {
hgs
parents:
diff changeset
    46
            VA_LIST list;
hgs
parents:
diff changeset
    47
            VA_START(list,aFmt);
hgs
parents:
diff changeset
    48
            RFileLogger::WriteFormat( _L("Fusion"), 
hgs
parents:
diff changeset
    49
                                      _L("Fusion.txt"),
hgs
parents:
diff changeset
    50
                                      EFileLoggingModeAppend,
hgs
parents:
diff changeset
    51
                                      aFmt,
hgs
parents:
diff changeset
    52
                                      list );
hgs
parents:
diff changeset
    53
        }
hgs
parents:
diff changeset
    54
};
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
#define FU_DEBUG MPXDebug::FileLog
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
// MACROS
hgs
parents:
diff changeset
    59
#define MPX_ENTER_EXIT        TEnterExitLog _s
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
class TFusionLog : public TDes16Overflow
hgs
parents:
diff changeset
    62
{
hgs
parents:
diff changeset
    63
    public:
hgs
parents:
diff changeset
    64
        
hgs
parents:
diff changeset
    65
        inline static void FusionLog( TRefByValue<const TDesC16> aFmt, ... )
hgs
parents:
diff changeset
    66
        {
hgs
parents:
diff changeset
    67
            TBuf< 512 > buffer;
hgs
parents:
diff changeset
    68
            
hgs
parents:
diff changeset
    69
            VA_LIST list;
hgs
parents:
diff changeset
    70
            VA_START( list, aFmt );
hgs
parents:
diff changeset
    71
            buffer.AppendFormatList( aFmt, list );
hgs
parents:
diff changeset
    72
            VA_END(list);
hgs
parents:
diff changeset
    73
            
hgs
parents:
diff changeset
    74
            FU_DEBUG(_L("#Fu# %S"), &buffer );
hgs
parents:
diff changeset
    75
        }
hgs
parents:
diff changeset
    76
};
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
class TMpxLog : public TDes16Overflow
hgs
parents:
diff changeset
    79
{
hgs
parents:
diff changeset
    80
    public:
hgs
parents:
diff changeset
    81
        
hgs
parents:
diff changeset
    82
        inline static void MpxLog( TRefByValue<const TDesC16> aFmt, ... )
hgs
parents:
diff changeset
    83
        {
hgs
parents:
diff changeset
    84
            TBuf< 512 > buffer;
hgs
parents:
diff changeset
    85
            
hgs
parents:
diff changeset
    86
            VA_LIST list;
hgs
parents:
diff changeset
    87
            VA_START( list, aFmt );
hgs
parents:
diff changeset
    88
            buffer.AppendFormatList( aFmt, list );
hgs
parents:
diff changeset
    89
            VA_END(list);
hgs
parents:
diff changeset
    90
            
hgs
parents:
diff changeset
    91
            FU_DEBUG(_L("#Mpx# %S"), &buffer );
hgs
parents:
diff changeset
    92
        }
hgs
parents:
diff changeset
    93
};
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
#define MPX_DEBUG TMpxLog::MpxLog
hgs
parents:
diff changeset
    96
#define MPX_DEBUG1(s)             MPX_DEBUG(_L(#s))
hgs
parents:
diff changeset
    97
#define MPX_DEBUG2(s, a)          MPX_DEBUG(_L(#s), a)
hgs
parents:
diff changeset
    98
#define MPX_DEBUG3(s, a, b)       MPX_DEBUG(_L(#s), a, b)
hgs
parents:
diff changeset
    99
#define MPX_DEBUG4(s, a, b, c)    MPX_DEBUG(_L(#s), a, b, c)
hgs
parents:
diff changeset
   100
#define MPX_DEBUG5(s, a, b, c, d) MPX_DEBUG(_L(#s), a, b, c, d)
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
class TFunctionTrace
hgs
parents:
diff changeset
   103
    {
hgs
parents:
diff changeset
   104
    public:
hgs
parents:
diff changeset
   105
        TFunctionTrace(TRefByValue<const TDesC> aName, TAny* aThis=NULL):
hgs
parents:
diff changeset
   106
            iStr(aName), iThis(aThis)
hgs
parents:
diff changeset
   107
            {
hgs
parents:
diff changeset
   108
            //iThis ? MPX_DEBUG3("-->%S, 0x%08x",&iStr, iThis) : MPX_DEBUG2("-->%S",&iStr);
hgs
parents:
diff changeset
   109
            iThis ? MPX_DEBUG(_L("-->%S, 0x%08x"),&iStr, iThis) : MPX_DEBUG(_L("-->%S"),&iStr);
hgs
parents:
diff changeset
   110
            }
hgs
parents:
diff changeset
   111
        ~TFunctionTrace()
hgs
parents:
diff changeset
   112
            {
hgs
parents:
diff changeset
   113
            //iThis ? MPX_DEBUG3("<--%S, 0x%08x",&iStr, iThis) : MPX_DEBUG2("<--%S",&iStr);
hgs
parents:
diff changeset
   114
            iThis ? MPX_DEBUG(_L("<--%S, 0x%08x"),&iStr, iThis) : MPX_DEBUG(_L("<--%S"),&iStr);
hgs
parents:
diff changeset
   115
            }
hgs
parents:
diff changeset
   116
    private:
hgs
parents:
diff changeset
   117
        TPtrC iStr;
hgs
parents:
diff changeset
   118
        TAny* iThis;
hgs
parents:
diff changeset
   119
    };
hgs
parents:
diff changeset
   120
    
hgs
parents:
diff changeset
   121
class TEnterExitLog : public TDes16Overflow
hgs
parents:
diff changeset
   122
{
hgs
parents:
diff changeset
   123
    public:
hgs
parents:
diff changeset
   124
        
hgs
parents:
diff changeset
   125
        void Overflow(TDes16& /*aDes*/)
hgs
parents:
diff changeset
   126
        {
hgs
parents:
diff changeset
   127
            FU_DEBUG(_L("%S Logging Overflow"), &iFunctionName);
hgs
parents:
diff changeset
   128
        }
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
        TEnterExitLog( TRefByValue<const TDesC> aFunctionName,
hgs
parents:
diff changeset
   131
                       TRefByValue<const TDesC> aFmt, ... )
hgs
parents:
diff changeset
   132
        {
hgs
parents:
diff changeset
   133
            iFunctionName = HBufC::New( TDesC(aFunctionName).Length() );
hgs
parents:
diff changeset
   134
            
hgs
parents:
diff changeset
   135
            if ( iFunctionName )
hgs
parents:
diff changeset
   136
            {
hgs
parents:
diff changeset
   137
                iFunctionName->Des().Copy(aFunctionName);
hgs
parents:
diff changeset
   138
            }
hgs
parents:
diff changeset
   139
            
hgs
parents:
diff changeset
   140
            TBuf< 512 > buffer;
hgs
parents:
diff changeset
   141
            
hgs
parents:
diff changeset
   142
            VA_LIST list;
hgs
parents:
diff changeset
   143
            VA_START( list, aFmt );
hgs
parents:
diff changeset
   144
            buffer.AppendFormatList( aFmt, list, this );
hgs
parents:
diff changeset
   145
            VA_END(list);
hgs
parents:
diff changeset
   146
            
hgs
parents:
diff changeset
   147
            FU_DEBUG(_L("#Fu# --> %S %S"), iFunctionName, &buffer );
hgs
parents:
diff changeset
   148
        }
hgs
parents:
diff changeset
   149
        
hgs
parents:
diff changeset
   150
        TEnterExitLog( TRefByValue<const TDesC> aFunctionName )
hgs
parents:
diff changeset
   151
        {
hgs
parents:
diff changeset
   152
            iFunctionName = HBufC::New( TDesC(aFunctionName).Length() );
hgs
parents:
diff changeset
   153
            
hgs
parents:
diff changeset
   154
            if ( iFunctionName )
hgs
parents:
diff changeset
   155
            {
hgs
parents:
diff changeset
   156
                iFunctionName->Des().Copy(aFunctionName);
hgs
parents:
diff changeset
   157
            }
hgs
parents:
diff changeset
   158
            
hgs
parents:
diff changeset
   159
            FU_DEBUG(_L("#Fu# --> %S"), iFunctionName );
hgs
parents:
diff changeset
   160
        }
hgs
parents:
diff changeset
   161
        
hgs
parents:
diff changeset
   162
        ~TEnterExitLog()
hgs
parents:
diff changeset
   163
        {
hgs
parents:
diff changeset
   164
            FU_DEBUG(_L("#Fu# <-- %S"), iFunctionName );
hgs
parents:
diff changeset
   165
            delete iFunctionName;
hgs
parents:
diff changeset
   166
        }
hgs
parents:
diff changeset
   167
        
hgs
parents:
diff changeset
   168
    private:
hgs
parents:
diff changeset
   169
        HBufC*    iFunctionName;
hgs
parents:
diff changeset
   170
};
hgs
parents:
diff changeset
   171
hgs
parents:
diff changeset
   172
_LIT(_KMPXErrorInfo, "#Fu# MPXVideo Error : error %d file %s line %d");
hgs
parents:
diff changeset
   173
hgs
parents:
diff changeset
   174
#define MPX_S(a) _S(a)
hgs
parents:
diff changeset
   175
hgs
parents:
diff changeset
   176
#define MPX_ERROR_LOG(aErr) \
hgs
parents:
diff changeset
   177
    {\
hgs
parents:
diff changeset
   178
        if (aErr) \
hgs
parents:
diff changeset
   179
            FU_DEBUG(_KMPXErrorInfo, aErr, MPX_S(__FILE__), __LINE__);\
hgs
parents:
diff changeset
   180
    }
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
#define MPX_TRAP(_r, _s) TRAP(_r,_s);MPX_ERROR_LOG(_r);
hgs
parents:
diff changeset
   183
#define MPX_TRAPD(_r, _s) TRAPD(_r,_s);MPX_ERROR_LOG(_r);
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
///////////////////////////////////////////////////
hgs
parents:
diff changeset
   186
#else // UREL VERSION STARTS HERE
hgs
parents:
diff changeset
   187
///////////////////////////////////////////////////
hgs
parents:
diff changeset
   188
hgs
parents:
diff changeset
   189
#define FU_DEBUG 
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
// MACROS
hgs
parents:
diff changeset
   192
#define MPX_ENTER_EXIT        
hgs
parents:
diff changeset
   193
hgs
parents:
diff changeset
   194
#define MPX_DEBUG 
hgs
parents:
diff changeset
   195
#define MPX_DEBUG1(s)             
hgs
parents:
diff changeset
   196
#define MPX_DEBUG2(s, a)          
hgs
parents:
diff changeset
   197
#define MPX_DEBUG3(s, a, b)       
hgs
parents:
diff changeset
   198
#define MPX_DEBUG4(s, a, b, c)    
hgs
parents:
diff changeset
   199
#define MPX_DEBUG5(s, a, b, c, d) 
hgs
parents:
diff changeset
   200
hgs
parents:
diff changeset
   201
#define MPX_S(a) 
hgs
parents:
diff changeset
   202
hgs
parents:
diff changeset
   203
#define MPX_ERROR_LOG(aErr) 
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
#define MPX_TRAP(_r, _s) TRAP(_r,_s);
hgs
parents:
diff changeset
   206
#define MPX_TRAPD(_r, _s) TRAPD(_r,_s); 
hgs
parents:
diff changeset
   207
hgs
parents:
diff changeset
   208
#endif // _DEBUG
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
#endif  // __MPXVIDEO_DEBUG_H__
hgs
parents:
diff changeset
   211
hgs
parents:
diff changeset
   212
// End of File