usbuis/usbuinotif/inc/usbuinotifdebug.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 26 Jan 2010 12:55:41 +0200
changeset 3 47c263f7e521
parent 0 1e05558e2206
permissions -rw-r--r--
Revision: 201001 Kit: 201004

/*
* Copyright (c) 2005, 2006 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:  This file defines logging macros for USB UI Notifiers
*
*/


#ifndef USBUINOTIFDEBUG_H
#define USBUINOTIFDEBUG_H

#ifdef _DEBUG

#include <e32svr.h>
#include <e32std.h>

// ===========================================================================
#ifdef __WINS__     // File logging for WINS
// ===========================================================================
#define FLOG(a)   { FPrint(a); }
#define FTRACE(a) { a; }

#include <f32file.h>
#include <flogger.h>

_LIT(KLogFile,"usbuinotiflog.txt");
_LIT(KLogDir,"USBUI");

// Declare the FPrint function
inline void FPrint(const TRefByValue<const TDesC> aFmt, ...)
    {
    VA_LIST list;
    VA_START(list,aFmt);
    RFileLogger::WriteFormat(KLogDir, KLogFile, EFileLoggingModeAppend,
        aFmt, list);
    }


// ===========================================================================
#else               // Target HW
// ===========================================================================

// ===========================================================================
#ifdef _USBUINOTIF_FILE_LOGGING_ // File logging for target HW
// ===========================================================================

#define FLOG(a)   { FPrint(a); }
#define FTRACE(a) { a; }

#include <f32file.h>
#include <flogger.h>

_LIT(KLogFile,"usbuinotiflog.txt");
_LIT(KLogDir,"USBUI");

// Declare the FPrint function
inline void FPrint(const TRefByValue<const TDesC> aFmt, ...)
    {
    VA_LIST list;
    VA_START(list,aFmt);
    RFileLogger::WriteFormat(KLogDir, KLogFile, EFileLoggingModeAppend,
        aFmt, list);
    }

// ===========================================================================
#else    // RDebug logging for target HW
// ===========================================================================
#define FLOG(a) { RDebug::Print(a);  }
#define FTRACE(a) { a; }

//Declare the FPrint function with variable number of arguments.
inline void FPrint(const TRefByValue<const TDesC16> aFmt, ...)
    {
    VA_LIST list;
    VA_START(list,aFmt);
    TInt tmpInt = VA_ARG(list, TInt);
    TInt tmpInt2 = VA_ARG(list, TInt);
    TInt tmpInt3 = VA_ARG(list, TInt);
    VA_END(list);
    RDebug::Print(aFmt, tmpInt, tmpInt2, tmpInt3);
    }

//Declare the FPrint function with variable number of arguments.
inline void FPrint(TRefByValue<const TDesC8> aFmt, ...)
    {

    VA_LIST list;
    VA_START(list, aFmt);
    TBuf8<256> buf8;
    buf8.AppendFormatList(aFmt, list);

    TBuf16<256> buf16(buf8.Length());
    buf16.Copy(buf8);

    TRefByValue<const TDesC> tmpFmt(_L("%S"));
    RDebug::Print(tmpFmt, &buf16);
    }
#endif //_USBUINOTIF_FILE_LOGGING_    
#endif // __WINS__

// ===========================================================================
#else // // No loggings --> Reduced binary size
// ===========================================================================
#define FLOG(a)
#define FTRACE(a)

#endif // _DEBUG


#endif // USBUINOTIFDEBUG_H

// End of File