mediasettings/videosettingsplugin/tsrc/testaccesspointentry/stub/inc/mpxvideo_debug.h
author hgs
Fri, 15 Oct 2010 16:29:10 +0300
changeset 67 72c709219fcd
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
67
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2008 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 the License "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
// Version : %version: 1 %
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
#ifndef __MPXVIDEO_DEBUG_H__
hgs
parents:
diff changeset
    21
#define __MPXVIDEO_DEBUG_H__
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
#include "stub/inc/cpitemdatahelper.h"
hgs
parents:
diff changeset
    24
#include "stub/inc/cpsettingformentryitemdata.h"
hgs
parents:
diff changeset
    25
#include "stub/inc/cmapplsettingsui.h"
hgs
parents:
diff changeset
    26
#include "stub/inc/cmconnectionmethod_shim.h"
hgs
parents:
diff changeset
    27
#include "stub/inc/cmmanager_shim.h"
hgs
parents:
diff changeset
    28
#include "stub/inc/videosettingsgroup.h"
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
// INCLUDES
hgs
parents:
diff changeset
    31
#include <e32std.h>
hgs
parents:
diff changeset
    32
#include <e32svr.h>
hgs
parents:
diff changeset
    33
#include <e32des16.h>
hgs
parents:
diff changeset
    34
#include <e32property.h>
hgs
parents:
diff changeset
    35
#include <flogger.h>
hgs
parents:
diff changeset
    36
#include <e32def.h>
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
// #define _MPX_FILE_LOGGING_
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
#ifdef _DEBUG
hgs
parents:
diff changeset
    43
    #define FU_DEBUG RDebug::Print
hgs
parents:
diff changeset
    44
#else
hgs
parents:
diff changeset
    45
    #ifdef _MPX_FILE_LOGGING_
hgs
parents:
diff changeset
    46
        #define FU_DEBUG MPXDebug::FileLog
hgs
parents:
diff changeset
    47
    #else
hgs
parents:
diff changeset
    48
        #define FU_DEBUG
hgs
parents:
diff changeset
    49
    #endif
hgs
parents:
diff changeset
    50
#endif
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
class MPXDebug
hgs
parents:
diff changeset
    54
{
hgs
parents:
diff changeset
    55
    public:
hgs
parents:
diff changeset
    56
        inline static void FileLog( TRefByValue<const TDesC16> aFmt, ... )
hgs
parents:
diff changeset
    57
        {
hgs
parents:
diff changeset
    58
            VA_LIST list;
hgs
parents:
diff changeset
    59
            VA_START(list,aFmt);
hgs
parents:
diff changeset
    60
            RFileLogger::WriteFormat( _L("Fusion"),
hgs
parents:
diff changeset
    61
                                      _L("fusion.log"),
hgs
parents:
diff changeset
    62
                                      EFileLoggingModeAppend,
hgs
parents:
diff changeset
    63
                                      aFmt,
hgs
parents:
diff changeset
    64
                                      list );
hgs
parents:
diff changeset
    65
        }
hgs
parents:
diff changeset
    66
};
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
// MACROS
hgs
parents:
diff changeset
    71
#ifdef _DEBUG
hgs
parents:
diff changeset
    72
    #define MPX_DEBUG             TFusionLog::FusionLog
hgs
parents:
diff changeset
    73
    #define MPX_ENTER_EXIT        TEnterExitLog _s
hgs
parents:
diff changeset
    74
#else
hgs
parents:
diff changeset
    75
    #define MPX_DEBUG
hgs
parents:
diff changeset
    76
    #define MPX_ENTER_EXIT
hgs
parents:
diff changeset
    77
#endif
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
class TFusionLog : public TDes16Overflow
hgs
parents:
diff changeset
    81
{
hgs
parents:
diff changeset
    82
    public:
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
        inline static void FusionLog( TRefByValue<const TDesC16> aFmt, ... )
hgs
parents:
diff changeset
    85
        {
hgs
parents:
diff changeset
    86
            TBuf< 496 > buffer;
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
            VA_LIST list;
hgs
parents:
diff changeset
    89
            VA_START( list, aFmt );
hgs
parents:
diff changeset
    90
            buffer.AppendFormatList( aFmt, list );
hgs
parents:
diff changeset
    91
            VA_END(list);
hgs
parents:
diff changeset
    92
hgs
parents:
diff changeset
    93
            FU_DEBUG(_L("#Fu# %S"), &buffer );
hgs
parents:
diff changeset
    94
        }
hgs
parents:
diff changeset
    95
};
hgs
parents:
diff changeset
    96
hgs
parents:
diff changeset
    97
class TEnterExitLog : public TDes16Overflow
hgs
parents:
diff changeset
    98
{
hgs
parents:
diff changeset
    99
    public:
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
        void Overflow(TDes16& /*aDes*/)
hgs
parents:
diff changeset
   102
        {
hgs
parents:
diff changeset
   103
            FU_DEBUG(_L("%S Logging Overflow"), &iFunctionName);
hgs
parents:
diff changeset
   104
        }
hgs
parents:
diff changeset
   105
hgs
parents:
diff changeset
   106
        TEnterExitLog( TRefByValue<const TDesC> aFunctionName,
hgs
parents:
diff changeset
   107
                       TRefByValue<const TDesC> aFmt, ... )
hgs
parents:
diff changeset
   108
        {
hgs
parents:
diff changeset
   109
            iFunctionName = HBufC::New( TDesC(aFunctionName).Length() );
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
            if ( iFunctionName )
hgs
parents:
diff changeset
   112
            {
hgs
parents:
diff changeset
   113
                iFunctionName->Des().Copy(aFunctionName);
hgs
parents:
diff changeset
   114
            }
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
            TBuf< 496 > buffer;
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
            VA_LIST list;
hgs
parents:
diff changeset
   119
            VA_START( list, aFmt );
hgs
parents:
diff changeset
   120
            buffer.AppendFormatList( aFmt, list, this );
hgs
parents:
diff changeset
   121
            VA_END(list);
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
            FU_DEBUG(_L("#Fu# --> %S %S"), iFunctionName, &buffer );
hgs
parents:
diff changeset
   124
        }
hgs
parents:
diff changeset
   125
hgs
parents:
diff changeset
   126
        TEnterExitLog( TRefByValue<const TDesC> aFunctionName )
hgs
parents:
diff changeset
   127
        {
hgs
parents:
diff changeset
   128
            iFunctionName = HBufC::New( TDesC(aFunctionName).Length() );
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
            if ( iFunctionName )
hgs
parents:
diff changeset
   131
            {
hgs
parents:
diff changeset
   132
                iFunctionName->Des().Copy(aFunctionName);
hgs
parents:
diff changeset
   133
            }
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
            FU_DEBUG(_L("#Fu# --> %S"), iFunctionName );
hgs
parents:
diff changeset
   136
        }
hgs
parents:
diff changeset
   137
hgs
parents:
diff changeset
   138
        ~TEnterExitLog()
hgs
parents:
diff changeset
   139
        {
hgs
parents:
diff changeset
   140
            FU_DEBUG(_L("#Fu# <-- %S"), iFunctionName );
hgs
parents:
diff changeset
   141
            delete iFunctionName;
hgs
parents:
diff changeset
   142
        }
hgs
parents:
diff changeset
   143
hgs
parents:
diff changeset
   144
    private:
hgs
parents:
diff changeset
   145
        HBufC*    iFunctionName;
hgs
parents:
diff changeset
   146
};
hgs
parents:
diff changeset
   147
hgs
parents:
diff changeset
   148
_LIT(_KMPXErrorInfo, "#Fu# MPXVideo Error : error %d file %s line %d");
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
#define MPX_S(a) _S(a)
hgs
parents:
diff changeset
   151
hgs
parents:
diff changeset
   152
#define MPX_ERROR_LOG(aErr) \
hgs
parents:
diff changeset
   153
    {\
hgs
parents:
diff changeset
   154
        if (aErr) \
hgs
parents:
diff changeset
   155
            FU_DEBUG(_KMPXErrorInfo, aErr, MPX_S(__FILE__), __LINE__);\
hgs
parents:
diff changeset
   156
    }
hgs
parents:
diff changeset
   157
hgs
parents:
diff changeset
   158
#ifdef _DEBUG
hgs
parents:
diff changeset
   159
    #define MPX_TRAP(_r, _s) TRAP(_r,_s);MPX_ERROR_LOG(_r);
hgs
parents:
diff changeset
   160
    #define MPX_TRAPD(_r, _s) TRAPD(_r,_s);MPX_ERROR_LOG(_r);
hgs
parents:
diff changeset
   161
#else // _DEBUG
hgs
parents:
diff changeset
   162
    #define MPX_TRAP(_r, _s) TRAP(_r,_s);(_r=_r);
hgs
parents:
diff changeset
   163
    #define MPX_TRAPD(_r, _s) TRAPD(_r,_s);(_r=_r);
hgs
parents:
diff changeset
   164
#endif // _DEBUG
hgs
parents:
diff changeset
   165
hgs
parents:
diff changeset
   166
#endif  // __MPXVIDEO_DEBUG_H__
hgs
parents:
diff changeset
   167
hgs
parents:
diff changeset
   168
// End of File